一:表介绍

表相当于文件, 表中的一条记录就相当于文件的一行内容, 不同的是,表中的一条记录有对应的标题,称为表的字段:

id,name, age, sex,称为字段, 其余的一行内容称为一条记录。

二:创建表

语法:
create table 表名(
字段名1 类型[(宽度) 约束条件]),
字段名2 类型[(宽度) 约束条件]),
字段名3 类型[(宽度) 约束条件])
);

解释:类型:使用限制字段必须以什么样的数据类型传值约束条件:约束条件是在类型之外添加一种额外的限制注意
1:在同一张表中, 字段名 是不能相同的
2:宽度和约束条件可选
3:字段名和类型是必须的4:注意注意注意:表中的最后一个字段不要加逗号

三 查看表结构

MariaDB [db1]> describe t1; #查看表结构,可简写为desc 表名
+-------+-----------------------+------+-----+---------+-------+
| Field | Type                  | Null | Key | Default | Extra |
+-------+-----------------------+------+-----+---------+-------+
| id    | int(11)               | YES  |     | NULL    |       |
| name  | varchar(50)           | YES  |     | NULL    |       |
| sex   | enum('male','female') | YES  |     | NULL    |       |
| age   | int(3)                | YES  |     | NULL    |       |
+-------+-----------------------+------+-----+---------+-------+MariaDB [db1]> show create table t1\G; #查看表详细结构,可加\G

四:数据类型

存储引擎决定了表的类型,而表内存放的数据也要有不同的类型,每种数据类型都有自己的宽度,但宽度是可选的

mysql 常用的数据类型概览

1数字:
整型:tinyinit     int      bigint
小数:float: 在位数比较短的情况下不精准double:在位数比较长的情况下不精准0.000001230123123123存成:0.000001230000decimal:(如果用小数,则推荐使用decimal)精准内部原理是以字符串形式去存2  字符串char (6):简单粗暴,浪费空间,存取速度快root存成root00(#这里00表示空格,方便看)varchar:精准,节省空间, 存取速度慢sql 优化:创建表时,定长的类型往前放,变长的往后放比如性别       比如地址或描述信息> 255个字符,超了就把文件路径存放到数据库中。比如图片,视频等找一个文件服务器, 数据库中值存路径或url.3:时间类型:
最常用:datetime4:
枚举类型与集合类型

一:数值类型

1、整数类型

整数类型:TINYINT SMALLINT MEDIUMINT INT BIGINT

作用:存储年龄, 等级, id,各种号码等

==============================
tinyint[(m)] [unsigned]  [zerofill]小整数,数据类型用于保存一些范围的整数数值范围:
有符号:
-128~127无符号:
0~255ps:MySQL 中无布尔值,使用tinyint(1)构造。===============================int[(m)][unsigned][zerofill]整数,数据类型用于保存一些范围的整数数值范围:
有符号:-2147483648 ~ 2147483647无符号:0 ~ 4294967295=================================bigint[(m)][unsigned][zerofill]
大整数 数据类型用于保存一些范围的整数数值范围:
有符号:-9223372036854775808 ~ 9223372036854775807无符号:0  ~  18446744073709551615

测试验证

#创建W1 表 字段名为X ,为其赋值 128,-129。 都超出 了 tinyint 有符号的范围, 结果显示如下, 为127,-128.

int      0 ~ 4294967295

强调:

对于整型来说,数据类型后的宽度并不是存储限制,而是显示限制,

所以在创建表时,如果字段采用的是整型类型,完全无需指定显示宽度,默认的显示宽度

足够显示完整当初存放的数据。

如下:

查看以及修改 sql_mode :

mysql> show variables like "%sql_mode%";
+----------------------------+---------------------+
| Variable_name              | Value               |
+----------------------------+---------------------+
| binlogging_impossible_mode | IGNORE_ERROR        |
| block_encryption_mode      | aes-128-ecb         |
| gtid_mode                  | OFF                 |
| innodb_autoinc_lock_mode   | 1                   |
| innodb_strict_mode         | OFF                 |
| pseudo_slave_mode          | OFF                 |
| slave_exec_mode            | STRICT              |
| sql_mode                   | STRICT_TRANS_TABLES |
+----------------------------+---------------------+
8 rows in set (0.00 sec)#修改sql_mode为严格模式:在该模式下,如果插入的数据超过限制,则会立即报错
mysql> set global sql_mode="strict_trans_tables";

int的存储宽度是4个Bytes,即32个bit,即2**32

无符号最大值为:4294967296-1

有符号最大值:2147483648-1

有符号和无符号的最大数字需要的显示宽度均为10,而针对有符号的最小值则需要11位才能显示完全,所以int类型默认的显示宽度为11是非常合理的

最后:整形类型,其实没有必要指定显示宽度,使用默认的就ok

2:浮点型 float:

作用:存储身高, 体重,薪资

====================================
#FLOAT[(M,D)] [UNSIGNED] [ZEROFILL]
定义:
单精度浮点数(非准确小树值),m 是数字总个数,d 是小数点后个数,m最大值为255,d最大值为30.有符号:-3.402823466E+38 to -1.175494351E-38,1.175494351E-38 to 3.402823466E+38
无符号:1.175494351E-38 to 3.402823466E+38精确度: **** 随着小数的增多,精度变得不准确 ****===========================================#DOUBLE[(M,D)] [UNSIGNED] [ZEROFILL]定义:双精度浮点数(非准确小数值),m是数字总个数,d是小数点后个数。m最大值为255,d最大值为30有符号:-1.7976931348623157E+308 to -2.2250738585072014E-3082.2250738585072014E-308 to 1.7976931348623157E+308无符号:2.2250738585072014E-308 to 1.7976931348623157E+308精确度:****随着小数的增多,精度比float要高,但也会变得不准确 ****=========================================
decimal[(m[,d])] [unsigned] [zerofill]定义:准确的小数值,m是数字总个数(负号不算),d是小数点后个数。 m最大值为65,d最大值为30。精确度:**** 随着小数的增多,精度始终准确 ****对于精确数值计算时需要用此类型decaimal能够存储精确值的原因在于其内部按照字符串存储

相同点

1:对于三者来说都能存放30位小数,

不同点:

1:精度的排序从低到高:floa,double,decimal

2:float 与double 类型能存放的整数位比decimal 更多。

验证如下:

3、字符串类型

有char 和varchar字符串类型;注意:char 和varchar 括号内的参数指的都是字符的长度

char 类型:定长 ,简单粗暴, 浪费空间, 存取速度快字符长度范围:0-255(一个中文是一个字符,是utf8编码的3个字节)存储:存储char类型的值时, 会往右填充空格来满足长度例如:指定长度为10 时,存>10个字符则报错, 存<10 个字符则用空            格填充直到凑够10个字符存储检索:
在检索或者说查询时, 查出的结果会自动删除尾部的空格, 除非我们打开pad_char_to_full_length SQL模式(SET sql_mode = 'PAD_CHAR_TO_FULL_LENGTH';)#varchar 类型:变长,精准, 节省空间, 存取速度慢字符长度范围 0-65535(如果大于21845会提示用其他类型 。mysql行最大限制为65535字节,字符编码为utf-8:
存储:varchar类型存储数据的真实内容,不会用空格填充,如果'ab  ',尾部的空格也会被存起来强调:varchar类型会在真实数据前加1-2Bytes的前缀,该前缀用来表示真实数据的bytes字节数(1-2Bytes最大表示65535个数字,正好符合mysql对row的最大字节限制,即已经足够使用)如果真实的数据<255bytes则需要1Bytes的前缀(1Bytes=8bit 2**8最大表示的数字为255)如果真实的数据>255bytes则需要2Bytes的前缀(2Bytes=16bit 2**16最大表示的数字为65535)检索:尾部有空格会保存下来,在检索或者说查询时,也会正常显示包含空格在内的内容

官网图:在字符数小于限定值时, 用varchar 更省空间, 但是当字符数到到限定值时, 用char 更省空间

#备注:了解两个函数

length:查看字节数

char_length:查看字符数

#注意:

针对 char 类型,mysql 在存储时会将数据用空格补全放到硬盘中

但会在读出结果时,自动去掉末尾的空格, 因为末尾的空格在以下场景中是无用

mysql> select * from t14 where name="lxx"; # name字段明确地等于一个值,该值后填充空格是没有用mysql> select * from t14 where name like "lxx"; # name字段模糊匹配一个值,该值后填充空格是有用的

总结:

常用字符串系列:char 与varchar

注:虽然varchar 使用起来较为灵活,但是从整个系统的性能角度来说,char数据类型的处理书读更快,  有时甚至可以超出varchar 处理书读的50%,因此用户在设计数据库时应当综合考虑各方面的因素 ,以求达到最佳的平衡。

4:日期类型:

作用:存储用户注册时间, 文章发布时间,员工入职时间, 出生时间, 过期时间等

        YEARYYYY(1901/2155)DATEYYYY-MM-DD(1000-01-01/9999-12-31)TIMEHH:MM:SS('-838:59:59'/'838:59:59')DATETIMEYYYY-MM-DD HH:MM:SS(1000-01-01 00:00:00/9999-12-31 23:59:59    Y)TIMESTAMPYYYYMMDD HHMMSS(1970-01-01 00:00:00/2037 年某时)
============注意啦,注意啦,注意啦===========
1. 单独插入时间时,需要以字符串的形式,按照对应的格式插入
2. 插入年份时,尽量使用4位值
3. 插入两位年份时,<=69,以20开头,比如50,  结果2050      >=70,以19开头,比如71,结果1971

表示方法如下:

date:1999-01-27
time: 11:11:11
datetime:1999-01-27 11:11:11
year:1999

测试:

datetime 与timestamp 的 区别

在实际应用的很多场景中,MySQL的这两种日期类型都能够满足我们的需要,存储精度都为秒,但在某些情况下,会展现出他们各自的优劣。下面就来总结一下两种日期类型的区别。1.DATETIME的日期范围是1001——9999年,TIMESTAMP的时间范围是1970——2038年。2.DATETIME存储时间与时区无关,TIMESTAMP存储时间与时区有关,显示的值也依赖于时区。在mysql服务器,操作系统以及客户端连接都有时区的设置。3.DATETIME使用8字节的存储空间,TIMESTAMP的存储空间为4字节。因此,TIMESTAMP比DATETIME的空间利用率更高。4.DATETIME的默认值为null;TIMESTAMP的字段默认不为空(not null),默认值为当前时间(CURRENT_TIMESTAMP),如果不做特殊处理,并且update语句中没有指定该列的更新值,则默认更新为当前时间。

5:枚举类型与集合类型

字段的值只能在给定范围中选择, 如单选框吗多选框

enum单选,只能在给定的范围内选一个值, 如性别sex, 男 male /女 female

set 多选  在给定的范围内可以选择一个或者一个以上的值(爱好1,爱好2, 爱好3。。。)

转载于:https://www.cnblogs.com/lx3822/p/9010942.html

msq 表操作与其数据类型相关推荐

  1. 数据库表操作、数据类型及完整性约束

    数据库表操作.数据类型及完整性约束 库操作补充 数据库命名规则: 可以由字母.数字.下划线.@.#.$ 区分大小写 唯一性 不能使用关键字如 create select 不能单独使用数字 最长128位 ...

  2. 注册表操作(VC_Win32)

    注册表操作(VC_Win32) 数据类型 注册表的数据类型主要有以下四种: 显示类型(在编辑器中)  数据类型   说明 REG_SZ    字符串   文本字符串 REG_MULTI_SZ      ...

  3. python进阶与数据操控_python进阶(mysql:表操作、数据操作、数据类型)(示例代码)...

    3.mysql数据库 3.4 表和数据的基础操作 3.4.1. 创建表 create create table 表名( 字段名1 类型[(宽度) 约束条件], 字段名2 类型[(宽度) 约束条件], ...

  4. Hive:命令行界面、数据类型、DDL数据定义(数据库及表操作/分区分桶)、DML数据操作(数据导入导出)

    目录 1.Hive命令行界面 1.1.选项列表 1.2.变量和属性 1.2.1.Hive中变量和属性命名空间 1.2.2.用户自定义变量 1.2.3..hiverc文件 1.3.一次使用的命令 1.4 ...

  5. mysql option 类型_mysql之数据类型与表操作

    关系数据库的注释 -- 单行注释 /* 多行注释 */ 数据类型 数值 整数 只能保存整数,如果是小数,则自动四舍五入取整. mediumint smallint tinyint(6) zerofil ...

  6. CDA数据分析师 - SQL数据库基础 数据类型表操作语句

    SQL 基础概念 [领会] 关系型数据库基本概念 表的基本概念(字段.记录) 表的约束条件(主键.外键.非空.唯一.自增.默认值) 实体关系图(E-R 图) ANSI-SQL 以及不同的数据库实现的关 ...

  7. 线性表抽象数据类型定义与顺序表操作

    作业3-线性表抽象数据类型定义与顺序表操作 1-1 对于顺序存储的长度为N的线性表, 访问结点和增加结点的时间复杂度 分别对应为O(1)和O(N).(T) [解析]增加结点,不同位置复杂度不同,但平均 ...

  8. 扩增子分析解读5物种注释,OTU表操作

    本网对Markdown排版支持较差,请跳转"宏基因组"公众号阅读: 写在前面 之前发布的<扩增子图表解读>系列,相信关注过我的朋友大部分都看过了(链接直达7月文章目录) ...

  9. SQL2K数据库开发六之表操作创建产品表products

    1.在SQL Server企业管理器中的数据库下的"表"节点上右击鼠标,在弹出的菜单上点击"新建表". 2.在出现的表设计器中,为表中加入五个列:Product ...

最新文章

  1. linux中pipe
  2. 折腾Java设计模式之责任链模式
  3. 漫漫运维路——基于CentOS6平台软件包管理2
  4. 227. 基本计算器 II
  5. 征战蓝桥 —— 2015年第六届 —— C/C++A组第10题——灾后重建
  6. 漫画:什么是拜占庭将军问题
  7. 青年教师大讲堂 计算机,浙海大青年教师大讲堂之船机学院“知识改变命运”...
  8. erlang的随机数 及 random:uniform()函数
  9. 远程工作两个月的体会(转)
  10. 20191107每日一句
  11. HTML5CSS3网页设计仿微信通讯录页
  12. Ps 快速更改头发颜色
  13. php怎么统计运营天数,zblog教程:如何给网站内容添加运行天数统计
  14. 如何选购一款优质的台式电脑电源?
  15. 使用D2D出现的错误
  16. Linux7密钥,centos7秘钥验证
  17. 数据库基本术语DDL,DML, DCL
  18. 【opencv】18、视频操作
  19. 一文带你看懂JAVA IO流,史上最全面的IO教学啦(附送JAVA IO脑图
  20. PCIE-5565PIORC GE 光纤网络节点卡

热门文章

  1. cookie和session的学习
  2. 视频编解码 — 卡顿与花屏
  3. Redis的SpringBoot配置(RedisTemplate配置)
  4. CH0104 起床困难综合症
  5. Medium 架构实践:避免微服务综合症
  6. thinkphp的数据库操作(上)
  7. mysql对接GaussDB高斯数据库出现的问题以及解决方式
  8. python画螺旋图
  9. 【Android面试】Android面试题集锦 (陆续更新)(最新2012-6-18) eoe上看到的
  10. js比较两个时间的大小