首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

mysql怎么存储整数

MySQL存储整数的基础概念:

MySQL中的整数类型主要包括TINYINT、SMALLINT、MEDIUMINT、INT和BIGINT。这些类型用于存储不同范围的整数值。整数类型的存储空间和取值范围如下:

  • TINYINT:占用1字节,取值范围为-128到127(有符号)或0到255(无符号)。
  • SMALLINT:占用2字节,取值范围为-32768到32767(有符号)或0到65535(无符号)。
  • MEDIUMINT:占用3字节,取值范围为-8388608到8388607(有符号)或0到16777215(无符号)。
  • INT:占用4字节,取值范围为-2147483648到2147483647(有符号)或0到4294967295(无符号)。这是最常用的整数类型。
  • BIGINT:占用8字节,取值范围为-9223372036854775808到9223372036854775807(有符号)或0到18446744073709551615(无符号)。

相关优势:

  1. 效率:整数类型的数据在数据库中存储和处理的速度非常快。
  2. 空间效率:相对于其他数据类型,整数类型通常占用较少的存储空间。
  3. 简单性:整数类型的数据操作简单,易于理解和使用。

类型及应用场景:

  • TINYINT和SMALLINT适用于存储小范围的整数,如年龄、评分等。
  • MEDIUMINT适用于存储中等范围的整数,如产品ID、订单数量等。
  • INT是最常用的整数类型,适用于大多数场景,如用户ID、时间戳等。
  • BIGINT适用于存储大范围的整数,如社交媒体上的粉丝数量、金融交易金额等。

遇到的问题及解决方法:

问题1:插入超出范围的整数值。

解决方法:确保插入的整数值在所选整数类型的取值范围内。如果需要存储超出范围的值,可以考虑使用BIGINT类型或使用其他数据类型(如DECIMAL)来存储。

问题2:整数类型的精度问题。

解决方法:整数类型本身没有精度问题,因为它们不包含小数部分。但是,如果需要进行精确的数值计算,可以考虑使用DECIMAL类型来存储数据。

示例代码:

代码语言:txt
复制
-- 创建一个包含整数类型的表
CREATE TABLE users (
    id INT AUTO_INCREMENT PRIMARY KEY,
    age TINYINT,
    score SMALLINT,
    product_id MEDIUMINT,
    transaction_amount BIGINT
);

-- 插入数据
INSERT INTO users (age, score, product_id, transaction_amount)
VALUES (25, 95, 12345, 9876543210);

-- 查询数据
SELECT * FROM users;

参考链接地址:MySQL整数类型文档

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

怎么优雅的选择 MySQL 存储引擎

对于数据库这一块询问比较多的就是在 MySQL 中怎么去选择一种何时当前业务需求的存储引擎,而 MySQL 中支持的存储引擎又有很多种,那么 MySQL 中分别又有那些,怎么优雅的使用呢?...不同的存储引擎保存数据和索引的方式是不同的,但表的定义则是在 MySQL 服务层wk统一处理的。...查看支持引擎 想了解 MySQL 中支持的引擎的情况,可以使用如下命令查看: show engines; 结果如下(MySQL版本:Ver 8.0.19): mysql> show engines; +...MySQL 存储引擎分类有 MyISAM、InnoDB、Memory、Merge等,可以看上面表中列出的支持引擎,但是其中最为常用的就是 MyISAM 和 InnoDB 两个引擎,其中针对于以上讲到的存储引擎...参考文章 Mysql 存储引擎的区别和比较 – zgrgfr – CSDN Mysql的存储引擎之:MERGE存储引擎 – 翔之天空 – CSDN MySQL存储引擎之Merge引擎 MySQL存储引擎

74540

【mysql】整数类型

答案:不会对插入的数据有任何影响,还是按照类型的实际宽度进行保存,即显示宽度与类型可以存储的值范围无关。从MySQL 8.0.17开始,整数数据类型不推荐使用显示宽度属性。...中显式如下,MySQL8中不再显式范围) mysql> desc test_int11; +-------+--------------+------+-----+---------+-------+...所以,如果需要在MySQL数据库中保存非负整数值时,可以将整数类型设置为无符号类型。 int类型默认显示宽度为int(11),无符号int类型默认显示宽度为int(10)。...如果整数值超过M位,就按照实际位数存储。只是无须再用字符 0 进行填充。 3. 适用场景 TINYINT:一般用于枚举数据,比如系统设定取值范围很小且固定的场景。...在评估用哪种整数类型的时候,需要考虑存储空间和可靠性的平衡问题:一方面,用占用字节数少的整数类型可以节省存储空间;另一方面,要是为了节省存储空间, 使用的整数类型取值范围太小,一旦遇到超出取值范围的情况

1.9K20
  • 数据在内存中的存储之整数存储

    整数在内存中的存储 整数的2进制表示方法有三种,即原码、反码和补码 三种表示方法均有符号位和数值位两部分,符号位都是0表用示“正”,用1表示“负”,而最高的一位是被当做符号位,剩余的都是数值位。...正整数的原、反、补码都相同。 负整数的三种表示方法各不相同。 原码:直接将数值按照正负数的形式翻译成二进制得到的就是原码。 反码:将原码的符号位不变,其他位依次按位取反就可以得到反码。...在计算机系统中,数值一律用补码来表示和存储。...1.1大小端字节序和字节序判断 大小端:         其实超过一个字节的数据在内存中存储的时候,就有存储顺序的问题,按照不同的存储顺序,我们分为大端字节序存储和小端字节序存储,下面是具体的概念:...举一个简单整数存储例子 : #include int main() { char a = -1;//char是否有符号,取决于编译器,在这里,我们以有符号举例 signed

    13010

    MySQL 的 InnoDB 存储引擎是怎么设计的?

    这其中,第一张图的最底下的存储引擎层(Storage Engines),它决定了 MySQL 会怎样存储数据,怎样读取和写入数据,也在很大程度上决定了 MySQL 的读写性能和数据可靠性。...对于这么重要的一层能力,MySQL 提供了极强的扩展性,你可以定义自己要使用什么样的存储引擎:InnoDB、MyISAM、MEMORY、CSV,甚至可以自己开发一个存储引擎然后使用它。...通常我们说 Mysql 高性能高可靠,都是指基于 InnoDB 存储引擎的 Mysql,所以,这一讲,先让我们来看看,除了 redo log,InnoDB 里还有哪些成员,他们都有什么能力,承担了什么样的角色...,他们之间又是怎么配合的?...怎么理解呢? 前面提到过,MySQL 以「页」为读取和写入单位,一个「页」里面有多行数据,写入数据时,MySQL 会先写内存中的页,然后再刷新到磁盘中的页。

    1.3K10

    mysql储存过程怎么写_oracle的存储过程写法

    存储过程写法是什么存储过程的写作是什么,存储过程的编写如下:1 .用代码[创建进程名]创建一个存储过程;2.用[EXECSP _ NAME]代码调用存储过程。...存储过程写法是: 1、创建存储过程 创建过程sp_name @[参数名][类型],@[参数名][类型] 作为 开始 .....结束 /*注意:“sp_name”是要创建的存储过程的名称,不能以阿拉伯数字开头*/2、调用存储过程 存储过程可以在三种环境中调用: 在命令命令下,基本语法是exec sp _ name参数名]; 在SQL...预防 (1)不能在一个存储过程中删除另一个存储过程,但只能调用另一个存储过程 4、其他常用命令 1 .显示程序状态 显示数据库中所有存储过程的基本信息,包括数据库、存储过程名称、创建时间等。...2 .显示创建过程sp_name 显示mysql存储过程的详细信息 3.exec sp_helptext sp_name 显示由sp_name对象创建的文本。以上是存储过程写什么的详细内容。

    4K20

    「干货」MySQL 的 InnoDB 存储引擎是怎么设计的?

    这其中,第一张图的最底下的存储引擎层(Storage Engines),它决定了 MySQL 会怎样存储数据,怎样读取和写入数据,也在很大程度上决定了 MySQL 的读写性能和数据可靠性。...对于这么重要的一层能力,MySQL 提供了极强的扩展性,你可以定义自己要使用什么样的存储引擎:InnoDB、MyISAM、MEMORY、CSV,甚至可以自己开发一个存储引擎然后使用它。...通常我们说 Mysql 高性能高可靠,都是指基于 InnoDB 存储引擎的 Mysql,所以,这一讲,先让我们来看看,除了 redo log,InnoDB 里还有哪些成员,他们都有什么能力,承担了什么样的角色...,他们之间又是怎么配合的?...怎么理解呢? 前面提到过,MySQL 以「页」为读取和写入单位,一个「页」里面有多行数据,写入数据时,MySQL 会先写内存中的页,然后再刷新到磁盘中的页。

    1.5K20

    mysql 的一行记录是怎么存储的?

    mysql 的一行记录,最终肯定是存储在磁盘上,也就是肉眼可见的文件上,今天我们的目标很简单,就是看看它到底是怎么存的。...可是与后面怎么也对应不上,这是咋回事呢? 还记不记得,mysql 每行记录会有几个隐藏列,rowid,事务 ID,回滚指针?没错,就是他们。...就是 mysql 规定了一种将一行记录存储在磁盘中的格式,以便于 mysql 自己的程序可以根据这个结构认识这一行记录。...所以不难想到,它一定利用了 frm 文件中存储的表结构信息。 其次,要让 mysql 在知道这些信息的同时,还能更方便地利用这个结构,占用更少的存储空间,以及提升程序的便利性。...拿占用更少存储空间这块来讲,NULL 值完全可以当做普通列,也存储在后面,然后规定一个 NULL 值的二进制标识符即可。

    1.8K30

    MySQL的存储过程_MySQL创建存储过程

    什么是存储过程 存储过程就是事先经过编译并存储在数据库中的一段 SQL 语句的集合; 为什么使用存储过程 调用存储过程可以简化应用开发人员的很多工作,减少数据在数据库和应用服务器之间的传输,对于提高数据处理的效率是有好处的...([ 参数 ]); 调用上面的存储过程 call p1(); 3、查看存储过程 SHOW CREATE PROCEDURE 存储过程名称 ; -- 查询某个存储过程的定义 4、删除存储过程 DROP...delimiter 指定SQL语句的结束符 存储过程中的变量 在MySQL中,变量一般可分为分为三种类型: 系统变量、用户定义变量、局部变量; 一、系统变量 系统变量是MySQL服务器系统自身提供的...注意点: mysql服务重新启动之后,所设置的全局参数会失效,要想不失效,可以在 /etc/my.cnf 中配置; 全局变量(GLOBAL): 全局变量针对于所有的会话; 会话变量(SESSION):...循环语句在编程中经常被用到,常用于对批量的数据进行循环处理,在mysql的存储过程中,也提供了几种常用的循环语句,包括:while循环,repeat循环,和loop循环; 1、while循环语句 while

    22.3K21

    MySQL:MySQL 存储过程

    MySQL 存储过程(了解) 1 什么是存储过程 MySQL 5.0 版本开始支持存储过程 存储过程(Stored Procedure)是一种在数据库中存储复杂程序,以便外部程序调用的一种数据 库对象。...存储过程是为了完成特定功能的SQL语句集,经编译创建并保存在数据库中,用户可通过 指定存储过程的名字并给定参数(需要时)来调用执行。 简单理解: 存储过程其实就是一堆 SQL 语句的合并。...中间加入了一些逻辑控制 2 存储过程的优缺点 优点:   存储过程一旦调试完成后,就可以稳定运行,(前提是,业务需求要相对稳定,没有变化)   存储过程减少业务系统与数据库的交互,降低耦合...,数据库交互更加快捷(应用服务器,与 数据库服务器不在同一个地区) 缺点:    在互联网行业中,大量使用MySQL,MySQL的存储过程与Oracle的相比较弱,所以较少使用,并且互联网行业需求变化较快也是原因之一...goods; END $$ 3) 调用存储过程 语法格式 call 存储过程名 -- 调用存储过程 查询goods表所有数据 call goods_proc; 方式2 1) IN 输入参数:表示调用者向存储过程传入值

    16.1K10

    mysql存储过程执行_mysql存储过程不执行

    实战mysql存储程序与定时器 存储过程定时器eventprocedure实战 需求:一个庞大的日志表,现每天做定时统计一天的总数,放另一个表中,方便查看,运营。...本文重点,用mysql定时器定时执行存储程序。...第一步:编写存储程序(需了解基本的存储程序的语法) Sql代码 create procedure inproc() begin declare done int default 0; declare a...定时器 如果不是on,就执行 Sql代码 set global event_scheduler=1; 不需要重启mysql 会发现mysql多起了一个daemon进程 (注: 对于我们线上环境来说,使用...在重复的计划任务中,时间(单位)的数量可以是任意非空(Not Null)的整数式,时间单位是关键词:YEAR,MONTH,DAY,HOUR,MINUTE 或者SECOND。

    16.7K20

    MySQL有哪些存储引擎(MySQL存储引擎大全)

    MyISAM在所有MySQL版本里被支持;不支持事务处理;它是MySQL的默认的存储引擎; MEMORY MEMORY存储引擎,别称HEAP存储引擎;提供“内存中”表,将数据存储在内存中。...MEMORY存储引擎不支持事务处理;MySQL的所有版本都支持InnoDB存储引擎;注释:MEMORY存储引擎正式地被确定为HEAP引擎。...InnoDB存储引擎;它支持事务处理; BDB BDB存储引擎,别名BERKELEYDB;BDB存储引擎提供事务安全表;mysql 5.1以下版本才支持此存储引擎; EXAMPLE EXAMPLE存储引擎是一个...你可以用这个引擎创建表,但没有数据被存储于其中或从其中检索。这个引擎的目的是服务,在MySQL源代码中的一个例子,它演示说明如何开始编写新存储引擎。同样,它的主要兴趣是对开发者。...NDB NDB存储引擎,别名NDBCLUSTER;NDB Cluster是被MySQL Cluster用来实现分割到多台计算机上的表的存储引擎。它在MySQL-Max 5.1二进制分发版里提供。

    6.2K41

    # MySQL server 层和存储引擎层是怎么交互数据的?

    MySQL 存储引擎是用插件方式实现的,所以在源码里分为两层:server 层、存储引擎层。 server 层负责解析 SQL、选择执行计划、条件过滤、排序、分组等各种逻辑。...写数据就是把 MySQL 传给存储引擎的数据存到磁盘文件或者内存中(对于 Memory 引擎是存储到内存),读数据就是把数据从磁盘或者内存读出来返回给 server 层。...由于 InnoDB 中,内容是按大端模式存储的(内容高位在前,低位在后),而 server 层是按照小端模式读取的,所以在写入整数字段内容到 record[0] 之前会进行大小端存储模式的转换。...enum 类型在存储引擎中是用整数存储的,存储引擎读取 e1 字段内容后,会对内容进行大小端转换,把转换后的内容写入 ptr 属性指向的内在空间。...set 类型在存储引擎中也是按照整数存储的,存储引擎读取 s1 字段内容后,也需要对内容进行大小端转换,把转换后的内容写入 ptr 属性指向的内存空间。

    1.3K30

    【MySQL】MySQL的存储引擎

    不同的存储引擎提供不同的存储机制、索引技巧、锁定水平等功能。现在 许多不同的数据库管理系统都支持多种不同的数据引擎。MySQL的核心就是存储引擎。...用户可以 根据不同的需求为数据表选择不同的存储引擎 可以使用 SHOW ENGINES 命令 可以查看Mysql的 所有执行引擎我们 可以到 默认的执行引擎是innoDB 支持事务,行级锁定和外键。...拥有较高的插入,查询速度,但不支持事 务 InnoDB:事务型速记的首选引擎,支持ACID事务,支持行级锁定,MySQL5.5成为默认数据库引 擎 Memory: 所有数据置于内存的存储引擎,拥有极高的插入...并且其内容会在MYSQL重新启动是会丢失。 Archive :非常适合存储大量的独立的,作为历史记录的数据。因为它们不经常被读取。...关闭mysql服务 2. 找到mysql安装目录下的my.ini文件: 3.

    5.3K20
    领券