手机网站建站 服务器,网页qq官网登录入口,微盟商户助手app下载,网站字号多大目录
1.数据类型分类
2 数值类型
2.1 tinyint类型
2.2 bit类型
2.3 小数类型
2.3.1 float
2.3.2 decimal
3 字符串类型
3.1 char
3.2 varchar
3.3 char和varchar比较
4 日期和时间类型
5 enum和set mysql表中建立属性列#xff1a; 列名称#xff0c;类型在后 n…目录
1.数据类型分类
2 数值类型
2.1 tinyint类型
2.2 bit类型
2.3 小数类型
2.3.1 float
2.3.2 decimal
3 字符串类型
3.1 char
3.2 varchar
3.3 char和varchar比较
4 日期和时间类型
5 enum和set mysql表中建立属性列 列名称类型在后 num tinyint unsinged
1.数据类型分类 2 数值类型 2.1 tinyint类型
数值越界测试
mysql create table tt1(num tinyint);
Query OK, 0 rows affected (0.02 sec)mysql insert into t1 values(1);
Query OK, 1 row affected (0.00 sec)mysql insert into t1 values(128); -- 越界插入报错
ERROR 1264 (22003): Out of range value for column num at row 1mysql select * from t1;
------
| num |
------
| 1 |
------
1 row in set (0.00 sec)
说明: ● 在MySQL中整型可以指定是有符号的和无符号的默认是有符号的。 ● 可以通过UNSIGNED来说明某个字段是无符号的 ● 无符号案例
mysql create table t2(num tinyint unsigned);
mysql insert into t2 values(-1); -- 无符号范围是 0 - 255
ERROR 1264 (22003): Out of range value for column num at row 1mysql insert into t2 values(255);
Query OK, 1 row affected (0.02 sec)mysql select * from t2;
------
| num |
------
| 255 |
------
1 row in set (0.00 sec) 会发现如果我们向mysql特定的类型中插入不合法的数据MySQL一般都是直接拦截不让进行对应的操作;
相反如果我们已经有数据被成功插入到mysql中插入的数据一定是合法的
所以在mysql中一般而言数据类型本身也是一种 约束
约束倒逼程序员让程序员尽可能进行正确的插入。约束使用者
另外如果你不是一个很好的使用者mysql也能保证数据插入的合法性。
这样就能保证数据库中的数据是可预期的完整的。
● 其他类型自己推导 注意尽量不使用unsigned对于int类型可能存放不下的数据int unsigned同样可能存放不 下与其如此还不如设计时将int类型提升为bigint类型。 2.2 bit类型
基本语法
bit[(M)] : 位字段类型。M表示每个值的位数范围从1到64。如果M被忽略默认为1。
举例
mysql create table t3 ( id int, a bit(8));
Query OK, 0 rows affected (0.01 sec)mysql insert into t3 values(10, 10);
Query OK, 1 row affected (0.01 sec)mysql select * from t3; #发现很怪异的现象a的数据10没有出现
------------
| id | a |
------------
| 10 | |
------------
1 row in set (0.00 sec)mysql select id,hex(online) from t3; //十六进制打印
-------------------
| id | hex(online) |
-------------------
| 123 | 0 |
| 124 | 1 |
-------------------
2 rows in set (0.01 sec)bit使用的注意事项 ● bit字段在显示时是按照ASCII码对应的值显示而非实际数值显示。
mysql insert into t3 values(65, 65);
mysql select * from t3;
------------
| id | a |
------------
| 10 | |
| 65 | A |
------------ ● 如果我们有这样的值只存放0或1这时可以定义bit(1)。这样可以节省空间。
mysql create table t4(gender bit(1));
mysql insert into t4 values(0);
Query OK, 1 row affected (0.00 sec)mysql insert into t4 values(1);
Query OK, 1 row affected (0.00 sec)mysql insert into t4 values(2); -- 当插入2时已经越界了
ERROR 1406 (22001): Data too long for column gender at row 1
2.3 小数类型 2.3.1 float
语法
float[(m, d)] [unsigned] : M指定显示长度d指定小数位数占用空间4个字节
案例 小数float(4,2)表示的范围是-99.99 ~ 99.99MySQL在保存值时会进行四舍五入。
mysql create table t5(id int, salary float(4,2));
Query OK, 0 rows affected (0.01 sec)mysql insert into t5 values(100, -99.99);
Query OK, 1 row affected (0.00 sec)mysql insert into t5 values(101, -99.991); #多的这一点被拿掉了
Query OK, 1 row affected (0.00 sec)mysql select * from t5;
--------------
| id | salary |
--------------
| 100 | -99.99 |
| 101 | -99.99 |
--------------
2 rows in set (0.00 sec)
问题 当我们的float(4,2)如果是一个有符号的则表示范围是-99.99 ~ 99.99如果float(6,3)猜一下范围是多少
-999.999~999.999
案例 如果定义的是float(4,2) unsigned 这时因为把它指定为无符号的数范围是 0 ~ 99.99
mysql create table t6(id int, salary float(4,2) unsigned);
Query OK, 0 rows affected (0.01 sec)mysql insert into t6 values(100, -0.1);
Query OK, 1 row affected, 1 warning (0.00 sec)mysql show warnings;
----------------------------------------------------------------
| Level | Code | Message |
----------------------------------------------------------------
| Warning | 1264 | Out of range value for column salary at row 1 |
----------------------------------------------------------------
1 row in set (0.00 sec)mysql insert into t6 values(100, -0);
Query OK, 1 row affected (0.00 sec)mysql insert into t6 values(100, 99.99);
Query OK, 1 row affected (0.00 sec)
2.3.2 decimal 语法
decimal(m, d) [unsigned]; 定点数m指定长度d表示小数点的位数
● decimal(5,2) 表示的范围是 -999.99 ~ 999.99
● decimal(5,2) unsigned 表示的范围 0 ~ 999.99 decimal和float很像但是有区别: float和decimal表示的精度不一样
mysql create table t7 ( id int, salary float(10,8), salary2
decimal(10,8));mysql insert into t7 values(100,23.12345612, 23.12345612);
Query OK, 1 row affected (0.00 sec)mysql select * from t7;
--------------------------------
| id | salary | salary2 |
--------------------------------
| 100 | 23.12345695 | 23.12345612 | # 发现decimal的精度更准确因此如果我们希望某
个数据表示高精度选择decimal
--------------------------------
说明float表示的精度大约是7位。 ● decimal整数最大位数m为65。支持小数最大位数d是30。如果d被省略默认为0.如果m被省 略默认是10。 建议如果希望小数的精度高推荐使用decimal。 3 字符串类型 3.1 char
语法
char(2) 表示可以存放两个字符可以是字母或汉字但是不能超过2个 最多只能是255
案例char
mysql create table t8(id int, name char(2));
Query OK, 0 rows affected (0.00 sec)mysql insert into t8 values(100, ab);
Query OK, 1 row affected (0.00 sec)mysql insert into t8 values(101, 中国);
Query OK, 1 row affected (0.00 sec)mysql select * from t8;
--------------
| id | name |
--------------
| 100 | ab |
| 101 | 中国 |
--------------
mysql create table t8(id int ,name char(256));
ERROR 1074 (42000): Column length too big for column name (max 255); use
BLOB or TEXT instead
varchar(L): 可变长度字符串L表示字符长度最大长度65535个字节说明
char(2) 表示可以存放两个字符可以是字母或汉字但是不能超过2个 最多只能是255
mysql create table t8(id int ,name char(256));
ERROR 1074 (42000): Column length too big for column name (max 255);
use BLOB or TEXT instead3.2 varchar 语法 char(L): 固定长度字符串L是可以存储的长度单位为字符最大长度值可以为255 案例
mysql create table t9(id int ,name varchar(6)); --表示这里可以存放6个字符
mysql insert into t9 values(100, hello);
mysql insert into t9 values(100, 我爱你中华);
mysql select * from t9;
--------------------------
| id | name |
--------------------------
| 100 | hello |
| 100 | 我爱你中华 |
--------------------------
说明
关于varchar(len),len到底是多大这个len值和表的编码密切相关 ● varchar长度可以指定为0到65535之间的值但是有1 - 3 个字节用于记录数据大小 所以说有效字节数是65532。 ● 当我们的表的编码是utf8时varchar(n)的参数n最大值是65532/321844 [因为utf中 一个字符占用3个字节]如果编码是gbkvarchar(n)的参数n最大是65532/232766 因为gbk中一个字符占用2字节。
mysql create table t10(name varchar(21845))charsetutf8; --验证了
utf8确实是不能超过21844ERROR 1118 (42000): Row size too large. The maximum row size for the used
table type, not counting BLOBs, is 65535. You have to change some columns to
TEXT or BLOBsmysql create table t10(name varchar(21844)) charsetutf8;Query OK, 0 rows affected (0.01 sec)
3.3 char和varchar比较 如何选择定长或变长字符串 ● 如果数据确定长度都一样就使用定长char比如身份证手机号md5 ● 如果数据长度有变化,就使用变长(varchar), 比如名字地址但是你要保证最长的能存的进去。 ● 定长的磁盘空间比较浪费但是效率高。 ● 变长的磁盘空间比较节省但是效率低。 ● 定长的意义是直接开辟好对应的空间 ● 变长的意义是在不超过自定义范围的情况下用多少开辟多少。
4 日期和时间类型 常用的日期有如下三个 ● date :日期 yyyy-mm-dd 占用三字节 ● datetime 时间日期格式 yyyy-mm-dd HH:ii:ss 表示范围从 1000 到 9999 占用八字节 ● timestamp 时间戳从1970年开始的 yyyy-mm-dd HH:ii:ss 格式和 datetime 完全一致占用四字节
案例
//创建表mysql create table birthday (t1 date, t2 datetime, t3 timestamp);
Query OK, 0 rows affected (0.01 sec)//插入数据mysql insert into birthday(t1,t2) values(1997-7-1,2008-8-8 12:1:1); --插入
两种时间
Query OK, 1 row affected (0.00 sec)mysql select * from birthday;
------------------------------------------------------
| t1 | t2 | t3 |
------------------------------------------------------
| 1997-07-01 | 2008-08-08 12:01:01 | 2024-11-12 18:28:55 | --添加数据时时间戳自动补
上当前时间
------------------------------------------------------//更新数据mysql update birthday set t12000-1-1;
Query OK, 1 row affected (0.00 sec)
Rows matched: 1 Changed: 1 Warnings: 0mysql select * from birthday;
------------------------------------------------------
| t1 | t2 | t3 |
------------------------------------------------------
| 2000-01-01 | 2008-08-08 12:01:01 | 2024-11-12 18:32:09 | -- 更新数据时间戳会更新
成当前时间
------------------------------------------------------ 5 enum和set 语法 ● enum枚举“单选”类型 enum(选项1,选项2,选项3,...);
该设定只是提供了若干个选项的值最终一个单元格中实际只存储了其中一个值而且出于效率考虑这些值实际存储的是“数字”因为这些选项的每个选项值依次对应如下数字1,2,3,....最多65535个当我们添加枚举值时也可以添加对应的数字编号。 ● set集合“多选”类型 set(选项值1,选项值2,选项值3, ...);
该设定只是提供了若干个选项的值最终一个单元格中设计可存储了其中任意多个值而且出于效率考虑这些值实际存储的是“数字”因为这些选项的每个选项值依次对应如下数字1,2,4,8,16,32....最多64个。 说明不建议在添加枚举值集合值的时候采用数字的方式因为不利于阅读。 案例 有一个调查表votes需要调查人的喜好 比如跑步羽毛球篮球乒乓球中去选择(可以多选)男女[单选]
mysql create table votes(- username varchar(30),- hobby set(跑步,羽毛球,篮球,乒乓球), --注意使用数字标识每个爱好的时候
想想Linux权限采用比特位位置来个set中的爱好对应起来- gender enum(男,女)); --注意使用数字标识的时候就是正常的数组下标
Query OK, 0 rows affected (0.02 sec) -- 插入雷锋的数据
INSERT INTO votes (username, hobby, gender) VALUES (雷锋, 跑步,乒乓球, 男);
-- 插入Juse的数据
INSERT INTO votes (username, hobby, gender) VALUES (Juse, 跑步,乒乓球, 女);
-- 插入LiLei跑步的数据
INSERT INTO votes (username, hobby, gender) VALUES (LiLei, 跑步, 男);
-- 插入LiLei篮球的数据这里假设在业务逻辑上同一个username可以有不同的爱好记录
INSERT INTO votes (username, hobby, gender) VALUES (LiLei, 篮球, 男);
-- 插入HanMeiMei的数据
INSERT INTO votes (username, hobby, gender) VALUES (HanMeiMei, 羽毛球, 女);
有如下数据想查找所有喜欢登山的人 ----------------------------------
| username | hobby | gender |
----------------------------------
| 雷锋 | 跑步,乒乓球 | 男 |
| Juse | 跑步,乒乓球 | 女 |
| LiLei | 跑步 | 男 |
| LiLei | 篮球 | 男 |
| HanMeiMei | 羽毛球 | 女 |
----------------------------------
使用如下查询语句
mysql select * from votes where hobby跑步;
--------------------------
| username | hobby | gender |
--------------------------
| LiLei | 跑步 | 男 |
--------------------------
不能查询出所有爱好为跑步的人。集合查询使用find_ in_ set函数 find_in_set(sub,str_list) 如果 sub 在 str_list 中则返回下标如果不在返回0 str_list 用逗号分隔的字符串
mysql select * from votes where find_in_set(a, a,b,c);
---------------------------
| find_in_set(a, a,b,c) |
---------------------------
| 1 |
---------------------------mysql select * from votes where find_in_set(d, a,b,c);
---------------------------
| find_in_set(d, a,b,c) |
---------------------------
| 0 |
---------------------------
查询爱好跑步的人
mysql select * from votes where find_in_set(登山, hobby);
---------------------------------
| username | hobby | gender |
---------------------------------
| 雷锋 | 跑步,乒乓球 | 男 |
| Juse | 跑步,乒乓球 | 女 |
| LiLei | 跑步 | 男 |
---------------------------------