当前位置: 首页 > article >正文

【MySQL】第五弹---数据类型全解析:从基础到高级应用

个人主页: 熬夜学编程的小林

💗系列专栏: 【C语言详解】 【数据结构详解】【C++详解】【Linux系统编程】【MySQL】

目录

1. 数据类型

1.1 数据类型分类

1.2 数值类型

1.2.1 tinyint类型

1.2.2 bit类型

1.2.3 浮点数(小数)类型

1.2.3.1 float

1.2.3.2 decimal

1.3 字符串类型

1.3.1 char

1.3.2 varchar

1.3.3 char和varchar比较

1.4 日期和时间类型

1.5 enum和set


1. 数据类型

1.1 数据类型分类

分类

数据类型

说明

数值类型

bit(m)

位类型。m指定位数,默认值1,范围1-64

tinyint[unsigned]

带符号的范围-128~127,无符号范围0~255,默认有符号

bool

使用0和1表示真假

smallint[unsigned]

带符号的范围-2^15 ~2^15 - 1,无符号范围0~2^16 - 1

int[unsigned]

带符号的范围-2^31 ~2^31 - 1,无符号范围0~2^32 - 1

bigint [unsigned]

带符号的范围-2^63 ~2^63 - 1,无符号范围0~2^64 - 1

float[(m,d)] [unsigned]

m指定显示长度,d指定小数位数,占用4字节

double[(m,d)] [unsigned]

表示比float精度更大的小数,占用8字节

decimal(m,d) [unsigned]

定点数m指定长度,d表示小数点的位数

文本、二进制类型

char(size)

固定长度字符串,最大255个字符

varchar(size)

可变长度字符串,最大长度65535字节

blob

二进制数据

text

大文本,不支持全文索引,不支持默认值

时间日期

date/datetime/ytimestamp

日期类型(yyyy-mm-dd)(yyyy-mm-dd hh:mm:ss) timestamp时间戳

string类型

enum类型

enum是一个字符串对象,其值来自表创建时在列规定中显示枚举的一个列值

set类型

set是一个字符串对象,可以有零或多个值,其值来自表创建时规定的允许的一列值。指定包括多个set成员的set列值时成员之间用逗号间隔开。这样的set成员值本身不能包含逗号。

1.2 数值类型

1.2.1 tinyint类型

数值越界测试:

创建数据库

mysql> create database test1_db; # 创建数据库
Query OK, 1 row affected (0.00 sec)

mysql> use test1_db; // 使用数据库
Database changed

创建数据库表

mysql> create table t1 (num tinyint); // 创建数据库表
Query OK, 0 rows affected (0.02 sec)

mysql> desc t1; // 查看表结构
+-------+------------+------+-----+---------+-------+
| Field | Type       | Null | Key | Default | Extra |
+-------+------------+------+-----+---------+-------+
| num   | tinyint(4) | YES  |     | NULL    |       |
+-------+------------+------+-----+---------+-------+
1 row in set (0.00 sec)

插入数据

mysql> insert into t1 values(1); // 插入数值1
Query OK, 1 row affected (0.00 sec)

mysql> insert into t1 values(-1);
Query OK, 1 row affected (0.01 sec)

mysql> insert into t1 values(255); // 插入数值255,超出范围直接报错
ERROR 1264 (22003): Out of range value for column 'num' at row 1
mysql> insert into t1 values(127);
Query OK, 1 row affected (0.00 sec)

mysql> insert into t1 values(127);
Query OK, 1 row affected (0.00 sec)

mysql> select * from t1; // 查看数据内容
+------+
| num  |
+------+
|    1 |
|   -1 |
|  127 |
|  127 |
+------+
4 rows in set (0.00 sec)

说明:

  • 在MySQL中,整型可以指定是有符号的和无符号的,默认是有符号的。
  • 可以通过UNSIGNED来说明某个字段是无符号的。
  • 无符号案例:
mysql> create table t2 (num tinyint unsigned);// 创建数据库表,无符号类型
Query OK, 0 rows affected (0.03 sec)

mysql> insert into t2 values(1);
Query OK, 1 row affected (0.00 sec)

mysql> insert into t2 values(-1);// 插入负数会直接报错
ERROR 1264 (22003): Out of range value for column 'num' at row 1
mysql> insert into t2 values(155);
Query OK, 1 row affected (0.01 sec)

mysql> insert into t2 values(255);
Query OK, 1 row affected (0.00 sec)

mysql> insert into t2 values(256);// 插入超出范围的数值也会报错
ERROR 1264 (22003): Out of range value for column 'num' at row 1

mysql> select * from t2;// 查看数据内容
+------+
| num  |
+------+
|    1 |
|  155 |
|  255 |
+------+
3 rows in set (0.00 sec)

  • 其他类型自己推导

注意:尽量不使用unsigned,对于int类型可能存放不下的数据,int unsigned同样可能存放不
下,与其如此,还不如设计时,将int类型提升为bigint类型。

1.2.2 bit类型

基本语法:

bit[(M)] : 位字段类型。M表示每个值的位数,范围从1到64。如果M被忽略,默认为1。

举例一:

mysql> create table t3 (online bit); // 创建表,bit类型位数默认为1
Query OK, 0 rows affected (0.02 sec)

mysql> desc t3; // 查看表结构
+--------+--------+------+-----+---------+-------+
| Field  | Type   | Null | Key | Default | Extra |
+--------+--------+------+-----+---------+-------+
| online | bit(1) | YES  |     | NULL    |       |
+--------+--------+------+-----+---------+-------+
1 row in set (0.00 sec)

mysql> insert into t3 values(0);
Query OK, 1 row affected (0.01 sec)

mysql> insert into t3 values(1);
Query OK, 1 row affected (0.01 sec)

mysql> insert into t3 values(2);// 插入2,超出范围,报错
ERROR 1406 (22001): Data too long for column 'online' at row 1
mysql> select * from t3; // 查看内容,bit类型存的是ASCII码值,前面的数字显示不出效果
+--------+
| online |
+--------+
|        |
|       |
+--------+
2 rows in set (0.00 sec)

bit使用的注意事项: 

  • bit字段在显示时,是按照ASCII码对应的值显示。

举例二:

mysql> create table t4 (online bit(8)); // 创建表,bit类型位数为8
Query OK, 0 rows affected (0.03 sec)

mysql> desc t4;
+--------+--------+------+-----+---------+-------+
| Field  | Type   | Null | Key | Default | Extra |
+--------+--------+------+-----+---------+-------+
| online | bit(8) | YES  |     | NULL    |       |
+--------+--------+------+-----+---------+-------+
1 row in set (0.00 sec)

mysql> insert into t4 values('a'); // 插入字符a,打印字符a
Query OK, 1 row affected (0.01 sec)

mysql> insert into t4 values(65); // ASCII码值65为A,因此打印A
Query OK, 1 row affected (0.00 sec)

mysql> insert into t4 values(97); // ASCII码值97为A,因此打印a
Query OK, 1 row affected (0.00 sec)

mysql> select * from t4;
+--------+
| online |
+--------+
| a      |
| A      |
| a      |
+--------+
3 rows in set (0.00 sec)

1.2.3 浮点数(小数)类型


1.2.3.1 float

语法:

float[(m, d)] [unsigned] : M指定显示长度,d指定小数位数,占用空间4个字节

案例一:

  • 小数:float(4,2)表示的范围是-99.99 ~ 99.99,MySQL在保存值时会进行四舍五入

创建表

mysql> create table t5 (id int,salary float(4,2)); // 创建表,数值位数为4,小数位2 <=> 小数位为2位,整数位最多为2位
Query OK, 0 rows affected (0.03 sec)

mysql> desc t5;
+--------+------------+------+-----+---------+-------+
| Field  | Type       | Null | Key | Default | Extra |
+--------+------------+------+-----+---------+-------+
| id     | int(11)    | YES  |     | NULL    |       |
| salary | float(4,2) | YES  |     | NULL    |       |
+--------+------------+------+-----+---------+-------+
2 rows in set (0.00 sec)

插入数据 

mysql> insert into t5 (id,salary) values(1,23.44);
Query OK, 1 row affected (0.00 sec)

mysql> insert into t5 (id,salary) values(1,99.99);
Query OK, 1 row affected (0.01 sec)

mysql> insert into t5 (id,salary) values(1,-99.99);
Query OK, 1 row affected (0.00 sec)

mysql> insert into t5 (id,salary) values(1,-99.994); // 四舍五入,实际插入为-99.99
Query OK, 1 row affected (0.00 sec)

mysql> insert into t5 (id,salary) values(1,-99.995);// 四舍五入,实际插入为-100.00 超出范围因此报错
ERROR 1264 (22003): Out of range value for column 'salary' at row 1
mysql> insert into t5 (id,salary) values(1,-100.0); // 根据表结构,整数为最多为2位,超出范围因此报错
ERROR 1264 (22003): Out of range value for column 'salary' at row 1
mysql> insert into t5 (id,salary) values(1,-10.0);
Query OK, 1 row affected (0.01 sec)

mysql> select * from t5;
+------+--------+
| id   | salary |
+------+--------+
|    1 |  23.44 |
|    1 |  99.99 |
|    1 | -99.99 |
|    1 | -99.99 |
|    1 | -10.00 |
+------+--------+
5 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); // 创建表,数值位数为4,小数位2 <=> 小数位为2位,整数位最多为2位
Query OK, 0 rows affected (0.04 sec)

mysql> desc t6;
+--------+---------------------+------+-----+---------+-------+
| Field  | Type                | Null | Key | Default | Extra |
+--------+---------------------+------+-----+---------+-------+
| id     | int(11)             | YES  |     | NULL    |       |
| salary | float(4,2) unsigned | YES  |     | NULL    |       |
+--------+---------------------+------+-----+---------+-------+
2 rows in set (0.00 sec)

插入数据

mysql> insert into t6 (id,salary) values(1,-1.99); // 无符号类型不能为负数
ERROR 1264 (22003): Out of range value for column 'salary' at row 1
mysql> insert into t6 (id,salary) values(1,1.99);
Query OK, 1 row affected (0.01 sec)

mysql> insert into t6 (id,salary) values(1,99.99);
Query OK, 1 row affected (0.01 sec)

mysql> insert into t6 (id,salary) values(1,99.994);
Query OK, 1 row affected (0.00 sec)

mysql> insert into t6 (id,salary) values(1,99.995); // 四舍五入,超过最大范围
ERROR 1264 (22003): Out of range value for column 'salary' at row 1

mysql> insert into t6 (id,salary) values(1,100.0); // 整数位数超出范围
ERROR 1264 (22003): Out of range value for column 'salary' at row 1

 案例二:

  • float 和 double 精度是有损失的。
mysql> create table t7 (id int,salary float(12,8)); # 创建表,数值位数为12,小数位8 <=> 小数位为8位,整数位最多为4位
Query OK, 0 rows affected (0.03 sec)

mysql> desc t7;
+--------+-------------+------+-----+---------+-------+
| Field  | Type        | Null | Key | Default | Extra |
+--------+-------------+------+-----+---------+-------+
| id     | int(11)     | YES  |     | NULL    |       |
| salary | float(12,8) | YES  |     | NULL    |       |
+--------+-------------+------+-----+---------+-------+
2 rows in set (0.00 sec)

mysql> insert into t7 (id,salary) values(1,5511.1456);
Query OK, 1 row affected (0.01 sec)

mysql> insert into t7 (id,salary) values(1,1122.14567895);
Query OK, 1 row affected (0.00 sec)

mysql> select * from t7; # 查看数据内容,插入的数值都有精度损失,且整数位数较大时也会有精度损失
+------+---------------+
| id   | salary        |
+------+---------------+
|    1 | 5511.14550781 |
|    1 | 1122.14562988 |
+------+---------------+
2 rows in set (0.00 sec)
1.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表示的精度不一样,float精度有损失,decimal精度没有损失

mysql> create table t8 (id int,salary decimal(14,8)); # 创建表,数值位数为14,小数位8 <=> 小数位为8位,整数位最多为6位
Query OK, 0 rows affected (0.04 sec)

mysql> desc t8;
+--------+---------------+------+-----+---------+-------+
| Field  | Type          | Null | Key | Default | Extra |
+--------+---------------+------+-----+---------+-------+
| id     | int(11)       | YES  |     | NULL    |       |
| salary | decimal(14,8) | YES  |     | NULL    |       |
+--------+---------------+------+-----+---------+-------+
2 rows in set (0.00 sec)

mysql> insert into t8 (id,salary) values(12,12345.65412);
Query OK, 1 row affected (0.00 sec)

mysql> insert into t8 (id,salary) values(12,123457.654124);
Query OK, 1 row affected (0.00 sec)

mysql> select * from t8; // 查看数据内容,精度没有损失
+------+-----------------+
| id   | salary          |
+------+-----------------+
|   12 |  12345.65412000 |
|   12 | 123457.65412400 |
+------+-----------------+
2 rows in set (0.00 sec)

说明:float表示的精度大约是7位

  • decimal整数最大位数m为65。支持小数最大位数d是30。如果d被省略,默认为0.如果m被省略,默认是10。

建议:如果希望小数的精度高,推荐使用decimal。

1.3 字符串类型

1.3.1 char
 

语法:

char(L): 固定长度字符串,L是可以存储的长度,单位为字符(utf8编码一个字符等于3字节,gbk编码一个字符等于2字节),最大长度值可以为255

案例(char):

mysql> create table t9 (id int,name char(2));
Query OK, 0 rows affected (0.02 sec)

mysql> insert into t9 (id,name) values(1,'a');
Query OK, 1 row affected (0.01 sec)

mysql> insert into t9 (id,name) values(1,'ab');
Query OK, 1 row affected (0.00 sec)

mysql> insert into t9 (id,name) values(1,'中国');
Query OK, 1 row affected (0.01 sec)

mysql> insert into t9 (id,name) values(1,'中国人');// 三个字符,超出范围报错
ERROR 1406 (22001): Data too long for column 'name' at row 1

mysql> select * from t9;
+------+--------+
| id   | name   |
+------+--------+
|    1 | a      |
|    1 | ab     |
|    1 | 中国   |
+------+--------+
3 rows in set (0.00 sec)

说明:

  • char(2) 表示可以存放两个字符,可以是字母或汉字,但是不能超过2个, 最多只能是255

1.3.2 varchar


语法:

varchar(L): 可变长度字符串,L表示字符长度,最大长度65535个字节

案例:

mysql> create table t10 (id int,name varchar(6)); # 最多存放6个字符
Query OK, 0 rows affected (0.02 sec)

mysql> insert into t10 values(10,'abc');
Query OK, 1 row affected (0.00 sec)

mysql> insert into t10 values(10,'hello');
Query OK, 1 row affected (0.00 sec)

mysql> insert into t10 values(10,'hello!!'); # 超过6个字符报错
ERROR 1406 (22001): Data too long for column 'name' at row 1

mysql> select * from t10;
+------+-------+
| id   | name  |
+------+-------+
|   10 | abc   |
|   10 | hello |
+------+-------+
2 rows in set (0.00 sec)

说明:

关于varchar(len),len到底是多大,这个len值和表的编码密切相关

  • varchar长度可以指定为0到65535之间的值,但是有1 - 3 个字节用于记录数据大小,所以说有效字节数是65532
  • 当我们的表的编码是utf8时,varchar(n)的参数n最大值是65532/3=21844[因为utf中,一个字符占用3个字节],如果编码是gbk,varchar(n)的参数n最大是65532/2=32766(因为gbk中,一个字符占用2字节)。
mysql> create table t11 (id int,name varchar(21845)); # n最大值为21844,超出范围报错
ERROR 1118 (42000): Row size too large. The maximum row size for the used table type, not counting BLOBs, is 65535. This includes storage overhead, check the manual. You have to change some columns to TEXT or BLOBs

mysql> create table t11 (id int,name varchar(21844)); # n最大值为21844,但是id也需要占4个字节,(65535-3-4)/3 = 21,842.66 ,因此需要小于21843
ERROR 1118 (42000): Row size too large. The maximum row size for the used table type, not counting BLOBs, is 65535. This includes storage overhead, check the manual. You have to change some columns to TEXT or BLOBs

mysql> create table t11 (id int,name varchar(21841)); # n < 21843 正确创建 
Query OK, 0 rows affected (0.03 sec)

mysql> create table t12 (id int,name varchar(21842));
Query OK, 0 rows affected (0.03 sec)

mysql> create table t13 (id int,name varchar(21843)); # n 等于21843 不能创建
ERROR 1118 (42000): Row size too large. The maximum row size for the used table type, not counting BLOBs, is 65535. This includes storage overhead, check the manual. You have to change some columns to TEXT or BLOBs

1.3.3 char和varchar比较

如何选择定长或变长字符串?

  • 如果数据确定长度都一样,就使用定长(char),比如:身份证,手机号,md5。
  • 如果数据长度有变化,就使用变长(varchar), 比如:名字,地址,但是你要保证最长的能存的进去。
  • 定长的磁盘空间比较浪费,但是效率高。
  • 变长的磁盘空间比较节省,但是效率低。
  • 定长的意义是,直接开辟好对应的空间。
  • 变长的意义是,在不超过自定义范围的情况下,用多少,开辟多少。 

1.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 t13 (t1 date,t2 datetime,t3 timestamp);

Query OK, 0 rows affected (0.04 sec)

mysql> desc t13;
+-------+-----------+------+-----+-------------------+-----------------------------+
| Field | Type      | Null | Key | Default           | Extra                       |
+-------+-----------+------+-----+-------------------+-----------------------------+
| t1    | date      | YES  |     | NULL              |                             |
| t2    | datetime  | YES  |     | NULL              |                             |
| t3    | timestamp | NO   |     | CURRENT_TIMESTAMP | on update CURRENT_TIMESTAMP |
+-------+-----------+------+-----+-------------------+-----------------------------+
3 rows in set (0.00 sec)

插入数据 

# 插入数据 --- 添加数据时,时间戳自动补上当前时间
mysql> insert into t13 (t1,t2) values('2001-1-1','2001-1-1 10:10:10');
Query OK, 1 row affected (0.01 sec)

mysql> select * from t13;
+------------+---------------------+---------------------+
| t1         | t2                  | t3                  |
+------------+---------------------+---------------------+
| 2001-01-01 | 2001-01-01 10:10:10 | 2024-09-09 21:51:21 |
+------------+---------------------+---------------------+
1 row in set (0.00 sec)

添加数据时,时间戳自动补上当前时间。 

更新数据 

# 更新数据 --- 更新数据,时间戳会更新成当前时间
mysql> update t13 set t1='2002-2-2';
Query OK, 1 row affected (0.01 sec)
Rows matched: 1  Changed: 1  Warnings: 0

mysql> select * from t13;
+------------+---------------------+---------------------+
| t1         | t2                  | t3                  |
+------------+---------------------+---------------------+
| 2002-02-02 | 2001-01-01 10:10:10 | 2024-09-09 21:52:19 |
+------------+---------------------+---------------------+
1 row in set (0.00 sec)

更新数据,时间戳会更新成当前时间。

1.5 enum和set


语法:

  • enum:枚举,“单选”类型
  • enum('选项1','选项2','选项3',...);

该设定只是提供了若干个选项的值,最终一个单元格中,实际只存储了其中一个值;而且出于效率考虑,这些值实际存储的是“数字”,因为这些选项的每个选项值依次对应如下数字:1,2,3,....最多65535个;当我们添加枚举值时,也可以添加对应的数字编号。

  • set:集合,“多选”类型
  • set('选项值1','选项值2','选项值3', ...);

该设定只是提供了若干个选项的值,最终一个单元格中,设计可存储了其中任意多个值;而且出于效率考虑,这些值实际存储的是“数字”,因为这些选项的每个选项值依次对应如下数字:1,2,4,8,16,32,....最多64个。

说明:不建议在添加枚举值,集合值的时候采用数字的方式,因为不利于阅读。

案例:

创建表

mysql> create table t14 (username varchar(30),gender enum('男','女'),hobby set('.码','羽毛球','乒乓球','足球','游泳'));
Query OK, 0 rows affected (0.03 sec)

mysql> show create table t14 \G;
*************************** 1. row ***************************
       Table: t14
Create Table: CREATE TABLE `t14` (
  `username` varchar(30) DEFAULT NULL,
  `gender` enum('男','女') DEFAULT NULL,
  `hobby` set('代码','羽毛球','乒乓球','足球','游泳') DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8
1 row in set (0.00 sec)

按照内容插入数据

mysql> insert into t14 values('张三','男','代码'); # 插入集合内的数据插入成功
Query OK, 1 row affected (0.00 sec)

mysql> insert into t14 values('李四','女','羽毛球');
Query OK, 1 row affected (0.01 sec)

mysql> insert into t14 values('李四','unknown','羽毛球'); # 插入集合外的数据插入失败
ERROR 1265 (01000): Data truncated for column 'gender' at row 1

mysql> insert into t14 values('李四','unknown','unknown'); # 插入集合外的数据插入失败
ERROR 1265 (01000): Data truncated for column 'gender' at row 1

mysql> select * from t14;
+----------+--------+-----------+
| username | gender | hobby     |
+----------+--------+-----------+
| 张三     | 男     | 代码      |
| 李四     | 女     | 羽毛球    |
+----------+--------+-----------+
2 rows in set (0.00 sec)

set插入多个使用逗号隔开插入即可。 

按照数字插入数据(enum)

mysql> insert into t14 values('李四',0,'羽毛球'); # 0不插入
ERROR 1265 (01000): Data truncated for column 'hobby' at row 1


mysql> insert into t14 values('李四',1,'羽毛球'); # 1表示第一个选项
Query OK, 1 row affected (0.01 sec)

mysql> insert into t14 values('李四',2,'羽毛球'); 
Query OK, 1 row affected (0.00 sec)

mysql> insert into t14 values('李四',3,'羽毛球'); # 超出范围,插入失败
ERROR 1265 (01000): Data truncated for column 'gender' at row 1
mysql> select * from t14;
+----------+---------+-----------+
| username | gender  | hobby     |
+----------+---------+-----------+
| 张三     | 男      | 代码      |
| 李四     | 女      | 羽毛球    |
| 李四     | 男      | 羽毛球    |
| 李四     | 女      | 羽毛球    |
+----------+---------+-----------+
4 rows in set (0.00 sec)

按照数字插入数据(set)

mysql> insert into t14 values('王五','男',0); # 0插入空,空格
Query OK, 1 row affected (0.00 sec)

mysql> select * from t14;
+----------+--------+-----------+
| username | gender | hobby     |
+----------+--------+-----------+
| 张三     | 男     | 代码      |
| 李四     | 女     | 羽毛球    |
| 李四     | 男     | 羽毛球    |
| 李四     | 女     | 羽毛球    |
| 王五     | 男     |           |
+----------+--------+-----------+
5 rows in set (0.00 sec)

mysql> insert into t14 values('王五','男',1); # 1插入第一个选项
Query OK, 1 row affected (0.01 sec)

mysql> select * from t14;
+----------+--------+-----------+
| username | gender | hobby     |
+----------+--------+-----------+
| 张三     | 男     | 代码      |
| 李四     | 女     | 羽毛球    |
| 李四     | 男     | 羽毛球    |
| 李四     | 女     | 羽毛球    |
| 王五     | 男     |           |
| 王五     | 男     | 代码      |
+----------+--------+-----------+
6 rows in set (0.00 sec)

mysql> insert into t14 values('王五','男',3); # 3的二进制数为11,表示插入第一个和第二个选项
Query OK, 1 row affected (0.00 sec)

mysql> select * from t14;
+----------+--------+------------------+
| username | gender | hobby            |
+----------+--------+------------------+
| 张三     | 男     | 代码             |
| 李四     | 女     | 羽毛球           |
| 李四     | 男     | 羽毛球           |
| 李四     | 女     | 羽毛球           |
| 王五     | 男     |                  |
| 王五     | 男     | 代码             |
| 王五     | 男     | 代码,羽毛球      |
+----------+--------+------------------+
7 rows in set (0.00 sec)

按照数值插入都是通过位图的二进制位来表示,第几位为1则插入第几项。

查找所有喜欢打羽毛球的人:

mysql> select * from t14 where hobby='羽毛球';
+----------+--------+-----------+
| username | gender | hobby     |
+----------+--------+-----------+
| 李四     | 女     | 羽毛球    |
| 李四     | 男     | 羽毛球    |
| 李四     | 女     | 羽毛球    |
+----------+--------+-----------+
3 rows in set (0.00 sec)

查到的是单纯喜欢羽毛球的人,我们想要的结果是只要喜欢羽毛球即可。

集合查询使用find_ in_ set函数:

  • find_in_set(sub,str_list) :如果 sub 在 str_list 中,则返回下标;如果不在,返回0;str_list 用逗号分隔的字符串。

改进

mysql> select * from t14 where find_in_set('羽毛球',hobby);
+----------+--------+------------------+
| username | gender | hobby            |
+----------+--------+------------------+
| 李四     | 女     | 羽毛球           |
| 李四     | 男     | 羽毛球           |
| 李四     | 女     | 羽毛球           |
| 王五     | 男     | 代码,羽毛球      |
+----------+--------+------------------+
4 rows in set (0.00 sec)

查询爱写代码和打羽毛球的人

mysql> select * from t14 where find_in_set('羽毛球',hobby) and find_in_set('代码',hobby);
+----------+--------+------------------+
| username | gender | hobby            |
+----------+--------+------------------+
| 王五     | 男     | 代码,羽毛球      |
+----------+--------+------------------+
1 row in set (0.00 sec)

and 符号类似于C/C++中的 &&(与)。


http://www.kler.cn/a/547904.html

相关文章:

  • 标贝科技参编国内首个AIGC大模型功能测试标准
  • 2025年二级建造师报名流程图解
  • 借助 OpenCV 库实现实时的脸部识别
  • 2月15日星期六今日早报简报微语报早读
  • 08模拟法 + 技巧 + 数学 + 缓存(D1_模拟法)
  • html css js网页制作成品——HTML+CSS+js情人节网页设计(5页)附源码
  • vue+springboot+webtrc+websocket实现双人音视频通话会议
  • 仿 RabbitMQ 消息队列6(实战项目)
  • DeepSeek 从入门到精通学习指南,2025清华大学《DeepSeek从入门到精通》正式发布104页pdf版超全解析
  • CAS单点登录(第7版)16.模仿
  • 如何使用Three.js制作3D月球与星空效果
  • Deesek:新一代数据处理与分析框架实战指南
  • TypeScript type 和 interface 的区别
  • 1-YIUI总览
  • 基于Python豆瓣电影数据可视化分析系统的设计与实现
  • vscode调试redis
  • Uniapp 从入门到精通:数据绑定与响应式原理
  • 使用pocketpal-ai在手机上搭建本地AI聊天环境
  • 基于大数据的北京市天气数据分析系统的设计与实现
  • 今日AI和商界事件(2025-02-15)