mysql数据库中文选什么数据类型_Mysql 数据类型及选择原则
MySQL中的数据类型大的方面来分,可以分为:日期和时间、数值,以及字符串。下面就分开来进行总结。
数据库类型的选择对数据库的性能影响很大
1 . 数据类型会影响存储空间的开销
2 . 数据类型会影响数据查询性能
日期和时间数据类型
MySQL数据类型
含义
date
3字节,日期,格式:2014-09-18
time
3字节,时间,格式:08:42:30
datetime
8字节,日期时间,格式:2014-09-18 08:42:30
timestamp
4字节,自动存储记录修改的时间
year
1字节,年份
数值数据类型
整型
MySQL数据类型
含义(有符号)
tinyint
1字节,范围(-128~127)
smallint
2字节,范围(-32768~32767)
mediumint
3字节,范围(-8388608~8388607)
int
4字节,范围(-2147483648~2147483647)
bigint
8字节,范围(+-9.22*10的18次方)
上面定义的都是有符号的,当然了,也可以加上unsigned关键字,定义成无符号的类型,那么对应的取值范围就要翻翻了,比如:
tinyint unsigned的取值范围为0~255。
浮点型
MySQL数据类型
含义
float(m, d)
4字节,单精度浮点型,m总个数,d小数位
double(m, d)
8字节,双精度浮点型,m总个数,d小数位
decimal(m, d)
decimal是存储为字符串的浮点数
我在MySQL中建立了一个表,有一列为float(5, 3);做了以下试验:
1.插入123.45678,最后查询得到的结果为99.999;
2.插入123.456,最后查询结果为99.999;
3.插入12.34567,最后查询结果为12.346;
所以,在使用浮点型的时候,还是要注意陷阱的,要以插入数据库中的实际结果为准。
字符串数据类型
MySQL数据类型
含义
char(n)
固定长度,最多255个字符
varchar(n)
可变长度,最多65535个字符
tinytext
可变长度,最多255个字符
text
可变长度,最多65535个字符
mediumtext
可变长度,最多2的24次方-1个字符
longtext
可变长度,最多2的32次方-1个字符
1.char(n)和varchar(n)中括号中n代表字符的个数,并不代表字节个数,所以当使用了中文的时候(UTF8)意味着可以插入m个中文,但是实际会占用m*3个字节。
2.同时char和varchar最大的区别就在于char不管实际value都会占用n个字符的空间,而varchar只会占用实际字符应该占用的空间+1,并且实际空间+1<=n。
3.超过char和varchar的n设置后,字符串会被截断。
4.char的上限为255字节,varchar的上限65535字节,text的上限为65535。
5.char在存储的时候会截断尾部的空格,varchar和text不会。
6.varchar会使用1-3个字节来存储长度,text不会。
其它类型
1.enum(“member1″, “member2″, … “member65535″)
enum数据类型就是定义了一种枚举,最多包含65535个不同的成员。当定义了一个enum的列时,该列的值限制为列定义中声明的值。如果列声明包含NULL属性,则NULL将被认为是一个有效值,并且是默认值。如果声明了NOT NULL,则列表的第一个成员是默认值。
2.set(“member”, “member2″, … “member64″)
set数据类型为指定一组预定义值中的零个或多个值提供了一种方法,这组值最多包括64个成员。值的选择限制为列定义中声明的值。
数据类型属性
上面大概总结了MySQL中的数据类型,当然了,上面的总结肯定是不全面的,如果要非常全面的总结这些内容,好几篇文章都不够的。下面就再来总结一些常用的属性。
1.auto_increment
auto_increment能为新插入的行赋一个唯一的整数标识符。为列赋此属性将为每个新插入的行赋值为上一次插入的ID+1。
MySQL要求将auto_increment属性用于作为主键的列。此外,每个表只允许有一个auto_increment列。例如:
代码如下:
id smallint not null auto_increment primary key
2.binary
binary属性只用于char和varchar值。当为列指定了该属性时,将以区分大小写的方式排序。与之相反,忽略binary属性时,将使用不区分大小写的方式排序。例如:
代码如下:
hostname char(25) binary not null
3.default
default属性确保在没有任何值可用的情况下,赋予某个常量值,这个值必须是常量,因为MySQL不允许插入函数或表达式值。此外,此属性无法用于BLOB或TEXT列。如果已经为此列指定了NULL属性,没有指定默认值时默认值将为NULL,否则默认值将依赖于字段的数据类型。例如:
代码如下:
subscribed enum('0', '1') not null default '0'
4.index
如果所有其他因素都相同,要加速数据库查询,使用索引通常是最重要的一个步骤。索引一个列会为该列创建一个有序的键数组,每个键指向其相应的表行。以后针对输入条件可以搜索这个有序的键数组,与搜索整个未索引的表相比,这将在性能方面得到极大的提升。
代码如下:
create table employees
(
id varchar(9) not null,
firstname varchar(15) not null,
lastname varchar(25) not null,
email varchar(45) not null,
phone varchar(10) not null,
index lastname(lastname),
primary key(id)
);
我们也可以利用MySQL的create index命令在创建表之后增加索引:
代码如下:
create index lastname on employees (lastname(7));
这一次只索引了名字的前7个字符,因为可能不需要其它字母来区分不同的名字。因为使用较小的索引时性能更好,所以应当在实践中尽量使用小的索引。
5.not null
如果将一个列定义为not null,将不允许向该列插入null值。建议在重要情况下始终使用not null属性,因为它提供了一个基本验证,确保已经向查询传递了所有必要的值。
6.null
为列指定null属性时,该列可以保持为空,而不论行中其它列是否已经被填充。记住,null精确的说法是“无”,而不是空字符串或0。
7.primary key
primary key属性用于确保指定行的唯一性。指定为主键的列中,值不能重复,也不能为空。为指定为主键的列赋予auto_increment属性是很常见的,因为此列不必与行数据有任何关系,而只是作为一个唯一标识符。主键又分为以下两种:
(1)单字段主键
如果输入到数据库中的每行都已经有不可修改的唯一标识符,一般会使用单字段主键。注意,此主键一旦设置就不能再修改。
(2)多字段主键
如果记录中任何一个字段都不可能保证唯一性,就可以使用多字段主键。这时,多个字段联合起来确保唯一性。如果出现这种情况,指定一个auto_increment整数作为主键是更好的办法。
8.unique
被赋予unique属性的列将确保所有值都有不同的值,只是null值可以重复。一般会指定一个列为unique,以确保该列的所有值都不同。例如:
代码如下:
email varchar(45) unique
9.zerofill
zerofill属性可用于任何数值类型,用0填充所有剩余字段空间。例如,无符号int的默认宽度是10;因此,当“零填充”的int值为4时,将表示它为0000000004。例如:
代码如下:
orderid int unsigned zerofill not null
mysql数据库中文选什么数据类型_Mysql 数据类型及选择原则相关推荐
- mysql数据库中的int类型_mysql数据类型
mysql数据类型-int int 的有符号和无符号的区别 有符号的int可以插入负值,无符号的int不可以插入负值 整型的每一种都分无符号(unsigned)和有符号(signed)两种类型(flo ...
- mysql数据库中常用的类型_MySQL数据库中常用字段类型
MySQL数据库中常用字段类型 整数型:TINYINT,SMALLINT,INT,BIGINT 小数型:FLOAT,DOUBLE,DECIMAL(M,D) 字符型:CHAR,VARCHAR 日期型:D ...
- mysql数据库中插入表信息_mysql数据库中插入表
通过binlog恢复mysql数据库 在上一篇文章,我们讲解了有关mysql的binlog日志的基础知识.这篇文章,我们来讲解如何通过mysql的binlog日志来恢复数据库. 在使用binlog日志 ...
- oracle和mysql数据类型转换_oracle数据库和MySQL数据库中表格转换时的数据类型
下面是oracle数据库中的语句请问前辈将下面语句转换成MySQL里的语句是什么样的坐等CREATETABLE"LXA"."USERS"("U_ID& ...
- mysql数据库中的int类型_MySQL中int(M)和tinyint(M)数值类型中M值的意义
在一开始接触MySQL数据库时,对于int(M)及tinyint(M)两者数值类型后面的M值理解是最多能够插入数据库中的值不能大于M: 后来工作后,也是一边学习一边使用,之后的理解是其中的M的意思是插 ...
- 从mysql数据库中删除一行数据_mysql数据库删除一行数据
[MySQL]命令行工具和基本操作 原文:[MySQL]命令行工具和基本操作 一 MySQL命令行工具 (查看帮助 ---help,或 -?) 1)MySQL MySQL是一个简单的SQL外壳(有G ...
- mysql数据库中邮箱的属性_MySQL——数据库的操作、属性
操作数据库 > 操作数据库中的表 > 操作数据库中表的数据 注意:mysql关键字不分区大小写 1.1.操作数据库 1.创建数据库 CREATE DATABASE [IF NOT EXIS ...
- mysql数据库中count的作用_MySQL数据库中的count的用法
1.概念 在开发系统的时候,可能经常需要计算一个表的行数,比如一个交易系统的所有变更记录总数.这时候你可能会想,一条select count(*) from t 语句不就解决了吗? 但是,会发现随着系 ...
- mysql数据库中文选什么数据类型_数据库MySQL-选择合适的数据类型
三.数据库结构的优化 1.选择合适的数据类型 1.数据类型选择 数据类型的选择,重点在于"合适"二字,如何确定选择的数据类型是否合适了? 1.使用可以存下你的数据的最小的数据类型. ...
- mySQL数据库中的备份代码_MySQL中的备份数据库
我目前正在学习SQL.我在windows 10-cmd上运行mysql 8.0.16cli,我以root mysql用户身份登录,并以管理员身份运行cmd. 我想做的是备份我新创建的数据库. 这是我的 ...
最新文章
- python2连接mysql_mysql-2:python操作mysql
- python3学习笔记(9)_closure
- 将chart放入panel中出现滚动条_聊天场景在web前端开发中的体验与优化
- 行内元素中的非替换行内元素和替换行内元素
- python怎么分析数据结构_《利用Python进行数据分析》第五章-pandas的数据结构介绍...
- Springboot — 用更优雅的方式发HTTP请求(RestTemplate详解)
- 父与子的编程之旅 python 3 pdf_父与子的编程之旅pdf微盘
- 存储过程从入门到精通(转载)
- Pyinstaller 打包Pyside2 报错qt.qpa.plugin
- imitate wechat - 3
- nevada用计算机弹,Nevada吉他谱(gtp谱,指弹,独奏,演奏视频)_Vicetone
- 【洛谷】P1488 肥猫的游戏(博弈论+全网最详细!!!)
- 虚拟主播甜妹小给给戏腔演绎国风佳作,引爆抖音直播浪潮
- 嵌入式开发要学习哪些知识
- norflash/nandflash 启动分析
- PowerBuilder学习笔记(4)数据窗口(DataWindow)
- 【js】如何点击按钮通过onclick打开新页面 和 在本页面打开
- V-Rep虚拟机器人实验平台在Ubuntu18.04LTS安装与使用笔记
- iphone刷机各种错误
- 对PHP并发、多进程、多线程、异步处理、分布式系统的一些了解
热门文章
- Linux学习教程,Linux入门教程(超详细)
- 从0开始搭建微信小程序(前后端)的全过程
- SQL文件示例(Mysql)
- 我读《DOOM启世录》——成为一个真正厉害的人
- B/S WEB端条码打印系统 斑马条码打印解决方案
- vc2010解决方案项目编译顺序_安装及配置 VC2010 的详细步骤
- 任务 F :工时统计
- Ubuntu系统最简GCC安装方法
- [软件更新]暴风影音2009最新特别版光盘免费赠送(暴风门特别版)
- 【计算机网络】网络层 : RIP 协议 ( 路由选择协议分类 | RIP 协议简介 | 信息交换 | 距离向量算法 | 计算示例 )★