《MySQL技术内幕——SQL编程》读书笔记(二)——数

在MySQL中实际存储的还是1。可以用HEX函数检查:

 

 

将数字类型无符号化。

 

CREATE TABLE t (a INT UNSIGNED,b INT UNSIGNED);
INSERT INTO t SELECT 1,2;
SELECT a - b FROM t;
SELECT a,b FROM tG;
a: 0001
b:2

1、通常来说,如果一个页内可以存放尽可能多的行,那么数据库的性能就越好,因此选择一个正确的数据类型至关重要。

对数据类型的选择将影响与数据库交互的应用程序的性能。

 

 

INT UNSIGNED 的 类型范围是 0 ~ 42967295

-1 的 16进制表示是:0xfff fff ff
4 294 967 295 的16进制表示是 : 0xfff fff ff
在MySQL数据库中,对于UNSIGNED数的操作,其返回值都UNSIGNED的。

2、ZEROFILL

在部分窗口可能看不到,mysql命令行可以看到。

看起来很不错的属性 ,但会有一些负面作用。

像是一个显示的属性。

ALTER TABLE t CHANGE COLUMN a a int(4) UNSIGNED ZEROFILL;

例如:

可以看到a的值由原来的1 变为 0001,这就是ZEROFILL属性的作用,如果宽度小于设定的宽度,则自动填充 0。

 

尽量不要使用UNSIGNED,INT 类型可能存放不了的数据,INT UNSIGNED 同样可能存放不了,与其如此,还不如在数据库设计阶段将INT类型提升为BIGINT类型。

如果想要得到 - 1 这个值,只要对SQL_MODE这个参数进行设置即可:

2、另一方面,如果在数据库中创建表时选择了错误的数据类型,那么后期的维护成本可能非常大,用户需要花大量时间进行ALTER TABLE 操作。

造成这种结果的原因是:

 

注意:

SET sql_mode='NO_UNSIGNED_SUBTRACTION';

修改了a列后,搜索t表的数据,会出现不一样的显示:

INT 的类型范围是 -2147483648 ~ 2147483647

执行最后一条sql后会报错,如果没有报错得到的结果应该是4 294 967 295。

 

  1. 数据类型

  2. UNSIGNED

 

SELECT a,HEX(a) FROM tG; 

本文由金沙官网线上发布于数据库,转载请注明出处:《MySQL技术内幕——SQL编程》读书笔记(二)——数

您可能还会对下面的文章感兴趣: