mysql8.0.19基础数据类型详解
网络编程 2021-07-05 14:37www.168986.cn编程入门
这篇文章主要介绍了mysql8.0.19基础数据类型的相关知识,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值 ,需要的朋友可以参考下
mysql基础数据类型
mysql常用数据类型概览
![1036857-20170801181433755-146301178](D:\笔记\mysql\复习\1036857-20170801181433755-146301178.png)1. 数字 整型tinyinit int bigint 小数 float 在位数比较短的情况下不精准 double 在位数比较长的情况下不精准 0.000001230123123123 存成0.000001230000 decimal(如果用小数,则用推荐使用decimal) 精准 内部原理是以字符串形式去存 2. 字符串 char(10)简单粗暴,浪费空间,存取速度快 root存成root000000 varchar精准,节省空间,存取速度慢 sql优化创建表时,定长的类型往前放,变长的往后放 比如性别 比如地址或描述信息 >255个字符,超了就把文件路径存放到数据库中。 比如图片,视频等找一个文件服务器,数据库中只存路径或url。 3. 时间类型 最常用datetime 4. 枚举类型与集合类型
数值类型
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-HAIxWM9Z-1585063057990)(D:\笔记\mysql\复习\1036857-20170801181433755-146301178.png)]
1、整数类型
- 整数类型TINYINT,SMALLINT,MEDIUMINT,INT,BIGINT
- 作用存储年龄,等级,id,各种号码等
整型类型测试 默认是有符号的 mysql> create table t1(money tinyint); #注意,创建表时一个字段后面不能有逗号,错误写法mysql> create table t1(money tinyint,); mysql> insert into t1 values(11); Query OK, 1 row affected (0.28 sec) mysql> select from t1; mysql> insert into t1 values(-10); Query OK, 1 row affected (0.11 sec) mysql> select from t1; mysql> insert into t1 values(-200); Query OK, 1 row affected, 1 warning (0.10 sec) mysql> select from t1; 设置了数据类型,会有一个约束效果,只能表示自己范围内的数 创建 无符号数值类型 的写法: mysql> create table t2(id tinyint unsigned);
2、浮点型
- 浮点类型float double
- 作用存储薪资、身高、温度、体重、体质参数等
测试 mysql> create table t3(id float(60,30)); # 60代表小数位+整数位总数 Query OK, 0 rows affected (1.70 sec) # 30表示小数位最高30位 mysql> create table t4(id double(60,30)); Query OK, 0 rows affected (0.88 sec) mysql> create table t5(id decimal(60,30)); # decimal能够存储精确值的原因在于其内部按照字符串存储。 Query OK, 0 rows affected (0.96 sec) mysql> insert into t3 values(1.1111111111111111111111); Query OK, 1 row affected (0.13 sec) mysql> insert into t4 values(1.1111111111111111111111); Query OK, 1 row affected (0.22 sec) mysql> insert into t5 values(1.1111111111111111111111); Query OK, 1 row affected (0.09 sec) mysql> select from t3; mysql> select from t4; mysql> select from t5;
1.创建表 create table t2(f1 float(5,2),f2 float,f3 double(5,2),f4 double); float(5,2) 保留两位小数 并且四舍五入 double(5,2) 2.写入数据 insert into t2 values(5.2336,5.2336,5.336,5.2336); 3.查看表中数据 select from t2; 4.指定写入数据 insert into t2(f2,f4) values(5.1783682169875975,5.1783682169875975); insert into 表名(字段1,字段3) values (值1,值3); 1.创建t3表 create table t3(f1 float,d1 double,d2 decimal(30,20),d3 decimal); 2.查看表结构 desc t3; 3.写入数据 insert into t3 values(5.1783682169875975179,5.1783682169875975179,5.1783682169875975179,5.1783682169875975179); int--------不约束长度,最多表示10位数 float(m,n) m-----一共多少位 n-----小数部分多少位
日期类型
- 类型DATE,TIME,DATETIME ,IMESTAMP,YEAR
- 作用存储用户注册时间,文章发布时间,员工入职时间,出生时间,过期时间等
mysql> create table t6(d1 year ,d2 date,d3 datetime); Query OK, 0 rows affected (1.75 sec) mysql> insert into t6 values(now(),now(),now()); Query OK, 1 row affected, 1 warning (0.12 sec) mysql> select from t6;
字符串类型
char和varchar性能对比 以char(5)和varchar(5)来比较,加入我要存三个人名sb,ssb1,ssbb2 char 优点简单粗暴,不管你是多长的数据,我就按照规定的长度来存,5个5个的存,三个人名就会类似这种存储sb ssb1 ssbb2,中间是空格补全,取数据的时候5个5个的取,简单粗暴速度快 缺点貌似浪费空间,并且我们将来存储的数据的长度可能会参差不齐 varchar varchar类型不定长存储数据,更为精简和节省空间 例如存上面三个人名的时候类似于是这样的sbssb1ssbb2,连着的,如果这样存,请问这三个人名你还怎么取出来,你知道取多长能取出第一个吗? varchar在存数据的时候,会在每个数据前面加上一个头,这个头是1-2个bytes的数据,这个数据指的是后面跟着的这个数据的长度,1bytes能表示28=256,两个bytes表示216=65536,能表示0-65535的数字,所以varchar在存储的时候是这样的1bytes+sb+1bytes+ssb1+1bytes+ssbb2,所以存的时候会比较麻烦,导致效率比char慢,取的时候也慢,先拿长度,再取数据。 优点节省了一些硬盘空间,一个acsii码的字符用一个bytes长度就能表示,也并不一定比char省,看一下官网给出的一个表格对比数据,当你存的数据正好是你规定的字段长度的时候,varchar反而占用的空间比char要多。 Value CHAR(4) Storage Required VARCHAR(4) Storage Required '' ' ' 4 bytes '' 1 byte 'ab' 'ab ' 4 bytes 'ab' 3 bytes 'abcd' 'abcd' 4 bytes 'abcd' 5 bytes 'abcdefgh' 'abcd' 4 bytes 'abcd' 5 bytes 缺点存取速度都慢 对于InnoDB数据表,内部的行存储格式没有区分固定长度和可变长度列(所有数据行都使用指向数据列值的头指针),在本质上,使用固定长度的CHAR列不一定比使用可变长度VARCHAR列性能要好。因而,主要的性能因素是数据行使用的存储总量。由于CHAR平均占用的空间多于VARCHAR,使用VARCHAR来最小化需要处理的数据行的存储总量和磁盘I/O是比较好的。
适合使用char 身份证号、手机号码、QQ号、username、password、银行卡号 适合使用varchar 评论、朋友圈、微博 1.创建表 create table t6(c1 char(1),v1 varchar(1),c2 char(8),v2 varchar(8)); 2.写入数据 insert into t6 values('alexq','alexq','alexq','alexq'); 3.查询表中数据 select from t6;
枚举和集合类型
enum: 单选行为------枚举类型 只允许从值集合中选取单个值,而不能一次取多个值 1.创建表 create table t8(id int, name char(18),gender enum('male','female')); 2.写入数据 insert into t8 values(1,'alex','不详'); ---------不详无法写入 3.查询表中数据 select from t8; 4.写入数据 insert into t8 values(1,'alex','male');-------------male可以写入 5.查询表中数据 select from t8; 2.写入数据 insert into t8 values(1,'alex','female');------------female可以写入 3.查询表中数据 select from t8;
set 多选行为 可以允许值集合中任意选择1或多个元素进行组合。对超出范围的内容将不允许注入,而对重复的值将进行自动去重。 1.创建表 create table t9(id int,name char(18),hobby set('抽烟','喝酒','洗脚','按摩','烫头')); 2.写入数据 insert into t9 values(1,'太白','烫头,抽烟,喝酒,按摩‘); 3.查询表中数据 select from t8; 4.写入数据 insert into t9 values(1,'大壮','洗脚,洗脚,洗脚,按摩,按摩,打游戏‘); 5.查询表中数据 select from t8;
到此这篇关于mysql8.0.19-基础数据类型的文章就介绍到这了,更多相关mysql8.0.19-基础数据类型内容请搜索狼蚁SEO以前的文章或继续浏览狼蚁网站SEO优化的相关文章希望大家以后多多支持狼蚁SEO!
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程