本文实例讲述了mysql数据类型和字段属性。分享给大家供大家参考,具体如下:

本文内容:

  • 数据类型

    • 数值类型

      • 整数型
      • 浮点型
      • 定点型
    • 日期时间类型
    • 字符串类型
    • 补充:
      • 显示宽度与zerofll
      • 记录长度
  • 字段属性

    • 空不为空值:NULL、NOT NULL
    • 主键:primary key
    • 唯一键:unique key
    • 自增长:auto_increment
    • 默认值:default
    • 字段描述:comment
    • 补充:
      • 复合键

数据类型:

mysql的数据类型就是存储数据的类型。

数值类型:

  • 整数类型:tinyint,smallint,mediumint,integer,bigint

    • 默认是有符号,如果需要使用无符号的数据类型要在后面加"UNSIGNED"
  • 小数类型:

    • 浮点类型:float(size,d),double(size,d)

      • size是数值的最大位数,d是小数点右侧的位数(即使你没输够那么多位也会补全那么多位)。
      • FLOAT的精度为6~7位(依据情况不同?毕竟机器是以二进制存储的),DOUBLE的精度为14~15位
      • 整数部分的个数为SIZE-D,直接存入的值的个数不能多于这个,但如果浮点数四舍五入导致整数进位而溢出超过最大位数的,系统允许成立(某些版本貌似已经不允许了,所以一般小数位也不要超过)。
      • 很多时候没必要关注两个浮点的数值范围大小(是极大的),注重点应该是它的精度。
  • 定点型:decimal(size,d)

    • size是数值的最大位数,最大为65,d是小数点右侧的最大位数,最大为30
    • 定点型不允许因为小数部分四舍五入导致整数部分长度超出范围。
    • DECIMAL是不会损失精度的。可以理解成使用“字符串”存储(MYSQL权威指南这么说)。
  • 直接不带括号的数据类型float、double、decimal代表没有小数部分

时间日期类型:

时间日期类型包括date,time,datetime,timestamp,year;

  • Datetime:时间日期,格式是YYYY-MM-DD HH:II:SS,表示的范围是从1000到9999年(有些版本已经允许0-9999?不确定);
  • Date:日期,格式是YYYY-MM-DD ,表示的范围是从1000到9999年
  • Time:时间段,格式是HH:II:SS, 指定的时间在某个区间之间,有正负。表示的范围 -838:59:59~838:59:59,这代表某个日期的前后时间范围【如果你仅仅想要用来表示24小时内的时间,可以忽略它的时间范围】
  • Timestamp:格式是YYYY-MM-DD HH:II:SS,表示的范围从1970-01-01 00:00:00到2038-01-19 03:14:07 【一旦该行记录被修改,那么timestamp会修改成当前时间。】
  • Year:年份,表示的范围1901-2156
  • 原本有两种格式,year(2)和year(4),但5.7中移除了year(2)。

字符串类型 :

  • set :集合字符串。将一个个特定的字符串放到集合里面。

    • 定义了集合之后,不能插入集合元素之外的字符串,(可以插入多个符合条件的字符串)
    • 集合字符串实际上也是仅仅存储数值,系统自动转换成对应的字符串。
    • 集合中每一个元素对应一个二进制位,被选中的为1,没选中的为0,左边为二进制中的低位,右边为高位,从右到左得到二进制结果
create table my_set(
hobby set('football','basketball','pingpong','computer')
)charset utf8;insert into my_set values('basketball,computer');
insert into my_set values(3);-- 3=0011
insert into my_set values(5);-- 5=0101

  • enum :枚举字符串

    • 有点类似set,但这里只能插入一个字符串(set类型的字段的值可以是多个set元素,但enum只能是其中一个元素)
    • 将可能出现的数据列举出来,实际存储的数据只能是列举出来的数据。
    • 使用枚举有利于统一数据,以及节省存储空间(枚举只是存储数值,系统转换成字符串)。
    • 枚举元素实际上按定义的顺序标号,从1开始,所以可以直接插入枚举元素对应的数值。
    • 如:
create table my_enum(
gender enum('male','female','unknown')
)charset utf8;

  • blob :二进制数据字符串

    • 存储二进制数据(少用)
  • text :文字字符串

    • 存储文字,当字符大于255时,一般使用text;
  • varchar :变长字符串

    • varchar(L),L代表字符长度,单位为字符,最大长度为65536。在实际存储中需要1到2个字节来存储长度(1还是2由实际大小决定,216=35536,<=255的一般一个字节),在使用时根据定义的大小来分配空间,但会根据实际需要使用的缩小空间(比如规定60大小,实际只有30,那么实际空间就是31~32)。
    • 当L大于255时,建议使用Text,而不是varchar;
  • char :定长字符串

    • char(L),L代表字符长度,单位为字符,最大长度为255,不使用L时默认为1
    • 不同环境中根据字符大小,实际占有的空间不同;在UTF8环境下,char(4)所用的字节数为4*3=12;

补充:

  • 显示宽度 与填充 :

    • 在列类型后面显示的数值,代表数据最终显示的最少位数(包含符号)。
    • 一般不够显示宽度的数据都会采用空格填充,也可以使用zerofill来使用零填充(零填充会导致数据类型自动变成无符号的)。
    • tiny(3)的空格填充效果:

,zerofill效果:

create table myInt(t1 TINYINT(3));
drop table myInt;
insert into myInt values(127),(1);
select * from myInt;
alter table myInt modify t1 tinyint(3) zerofill;
select * from myInt;

  • 不要轻易的使用最大限度来存储字符串,因为涉及记录长度问题 :

    • MySQL中规定任何一条数据最长不能超过65535个字节
    • 如果有任何一个字段允许为空,那么系统会自动从整个记录中保存一个字节来存储NULL;
    • text文本不占用记录长度,额外存储。
    • UTF8中varchar的最大限度:65535-2(需要两个字节来存储长度) /3=21844,所以最大字符数为21844
    • GBK中varchar的最大限度:65535-2(需要两个字节来存储长度) /2=32766

字段属性:

字段属性是字段除数据类型外的属性,一般有空不为空值、主键、唯一键、自增长、默认值、描述等属性。

空不为空值:NULL、NOT NULL

  • 字段的数据默认情况下是允许为空的,比如说一条人的信息记录中可以没有邮箱(或许有些人考虑用“空字符串”来代表),我们允许可以不填入数据的字段可以设置为null;但比如说某些必填数据,我们不想填入的时候留空,可以设置这个字段为not null
  • 允许为空时的数据,空的数据显示为null:
  • 不为空的字段,插入null时,会报错:
  • nullnot null属性的定义方式(因为默认允许空,所以主要关注not null):

;当然也可以通过修改字段的形式来给字段定义not null属性

主键:primary key

  • 主键用于唯一标识每一条记录(每个人都有自己唯一的身份证)
  • 每一张表只能有一个主键。
  • 因为唯一标识,所以主键字段的数据不能为空,并且主键字段的数据值不能重复
  • 主键也是一种索引,可以提高查找速率。
  • 主键的定义:
    • 1.定义表结构的时候定义成字段的属性。
  • 2.修改表结构,增加一个带主键的字段。
  • 3.修改表结构,给某一字段增加主键属性。
  • 主键的用途:主键的主要用途是用来唯一标识每一条记录,比如我们想将两个表(学生表跟老师表)的多对多关系封装到一个表中,这个抽取的映射字段一般都是各自的主键。

;并且由于主键的数据的不可重复性,也用来约束数据的唯一性。

  • 主键的删除:1alter table 表名 drop primary key;

唯一键:unique key

  • 唯一键的功能与主键有点类型,但不同的是主键只能有一个,唯一键可以有多个,而且唯一键的字段的数据允许为空。
  • 唯一键可以约束字段,使得字段的数据不能重复
  • 如果唯一键同时也有not null,并且表中没有主键的话,在desc查看表结构中会显示成主键
  • 如果唯一键也不允许为空,那么功能与主键相同
  • 唯一键的定义方法可以参考主键的。
  • 唯一键的删除:1alter table 表名 drop index 唯一键名; -- 唯一键默认使用字段名来定义名字

自增长:auto_increment

  • 自增长的功能是可以使某个字段的数据随着记录的插入而进行增长(不给这个字段插入数据的情况下)
  • 自增长的前提是这个字段必须是一个“索引”,比如主键、唯一键
  • 自增长的前提这个字段的数据类型是一个数值型的,(如果给了float,也不会增长成小数,而仅仅是整数)
  • 一个表只能有一个自增长。
  • 只有不给值,或者给null的情况下,才能正确自增长;如果某一次自增长失败了,那么下一次会从当前字段的最大值开始继续自增长。
  • 自增长的定义方法:

;当然也可以通过修改字段的形式来给字段定义not null属性

  • 自增长的修改:

    • 修改增长速度:set auto_increment = 值;
    • 修改下次增长的值:alter table 表名 auto_increment = 值; 【修改的值只能变大,不能变小,因为可能导致数据重复问题】
  • 自增长的查看:show vairable like "auto_increment%";
  • 自增长的删除:利用alter来删除,alter修改字段属性的时候如果不带上原来的属性就会被删掉:

默认值:default

  • 默认值的功能是当我们不给一个字段赋值的时候,使用默认值作为数据,比如不选择性别的时候,默认使用“保密”;
  • 默认值的定义方式:

字段描述:comment

  • 字段描述是用来描述字段的,能在查看数据表创建语句的时候显示出来(不会再select结果中显示出来),可以帮助我们了解某一个字段的意义。
  • 定义方式:

补充:

  • 复合键:可以将多个字段组成一个键,比如学生可以选多门课,但学生号跟课程号一起的时候应该是唯一的,这里使用主键来限制这个情况

    • 定义方法(复合以主键为例):
  • 数据约束(以上面的表为例):

好了,文章就分享到这里。

求关注点赞,

我是一咻,读快点就是 咻er~
一个没有节操的Java程序员

asp怎么循环增加字段和字段对应的值_MySQL数据类型和字段属性原理与用法详解相关推荐

  1. mysql字段类型原理_mysql数据类型和字段属性原理与用法详解

    本文实例讲述了mysql数据类型和字段属性.分享给大家供大家参考,具体如下: 本文内容: 数据类型 数值类型 整数型 浮点型 定点型 日期时间类型 字符串类型 补充: 显示宽度与zerofll 记录长 ...

  2. Java 循环队列原理与用法详解

    点击上方 好好学java ,选择 星标 公众号 重磅资讯.干货,第一时间送达 今日推荐:iphone 也是办公神器,用了就知道了,不行送你一个试试个人原创+1博客:点击前往,查看更多 链接:https ...

  3. JAVA循环与分支语句edu_Java分支结构和循环结构原理与用法详解

    本文实例讲述了Java分支结构和循环结构.分享给大家供大家参考,具体如下: 流程控制分类 顺序语句:从上到下按顺序依次执行 分支语句:根据条件不同,执行不同语句 循环语句:重复执行某些动作 单分支条件 ...

  4. csh for循环_shell中的for循环用法详解_linux shell

    这篇文章主要介绍了shell中的for循环用法详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧 for 命令: for i i ...

  5. c语言while将字符循环,C语言 while语句的用法详解

    在C语言中,共有三大常用的程序结构: 顺序结构:代码从前往后执行,没有任何"拐弯抹角": 选择结构:也叫分支结构,重点要掌握 if else.switch 以及条件运算符: 循环结 ...

  6. asp怎么循环增加字段和字段对应的值_ASP.NET Core教程「三」实体字段属性

    实体字段属性 再来看看我们的实体类 说明,上面的代码需要引用:using System.ComponentModel.DataAnnotations; Display属性标志这个字段在页面上显示的时候 ...

  7. asp怎么循环增加字段和字段对应的值_索引该怎么创建?

    1.2.索引 B+Tree 结构的特性: ①.B+Tree 只有叶子节点会存储真实的数据,非叶子节点只会存储索引字段值: ②.B+Tree的叶子节点之间使用 双向链表 链接,所以更加适合范围查询和排序 ...

  8. java中的字段是_Java – 获取类中特定数据类型的字段

    原文链接作者:mkyong 译者:王乐(2270134103@qq.com) 一些Java反射API的例子. 1.显示所有字段和数据类型 使用反射遍历一个类声明的所有字段. CompanyA.java ...

  9. BULK INSERT用法详解,文本导入SQL,字段数量不等实例.

    Bulk Insert命令详解 BULK INSERT 以用户指定的格式复制一个数据文件至数据库表或视图中. 语法 BULK INSERT [ [ 'database_name'.][ 'owner' ...

最新文章

  1. 如何卸载Exchange Server 2010
  2. NuGet学习笔记(2) 使用图形化界面打包自己的类库
  3. 尝试去读SQLMAP源码(一)
  4. 研发效能提升最佳实践的探索
  5. cookie 在线人数列表_前端学习随笔2 在线简历
  6. 解决远程服务器ssh登陆慢等问题
  7. Lucene查询结果高亮
  8. python 年月日转换日期_python 二〇二〇年九月二十四日 汉字日期转化为数字日期...
  9. CSDN日报20170224——《程序员该用哪种姿势来理财》
  10. php框架 猪婆,猪婆塘_三湖文学社_新高淳论坛 - Powered by Discuz!
  11. 【自建exe】使用Electronjs为自己写windows软件
  12. python爬取收费漫画_Python爬虫,爬取腾讯漫画实战
  13. [QT_041]Qt学习之通用对话框:QErrorMessage、QFileDialog、QProgressDialog
  14. java随机生成标点符号_java去除空格、标点符号的方法实例
  15. JavaWeb问题记录——IDEA换了图片前端不更新。
  16. 记一次北航软件学院复试
  17. 【博客546】组播IP地址与组播MAC地址的联系与转换
  18. $forceUpdate的使用详解
  19. job是什么 oracle12c_oracle12c版本容器模式下job管理的问题
  20. iMAIL邮件监控程序终于可以试用了

热门文章

  1. 变配电站综合监控平台
  2. 【IoT案例征集文章】60 万年薪招聘物联网工程师!此专业要火!
  3. FPGA速度等级问题(Speed Grade)
  4. 正则表达式:正负小数或正负整数
  5. 搜索框、微信发红包、水杯、QQ登录、聊天窗口、两台电梯的测试用例
  6. vim速查图(可能是全网最高清中文版本)-适合打印
  7. 微信小程序开发【知识点大全】
  8. SMILES:一种简化的分子语言
  9. FFMPEG编码实现:pcm编码为acc
  10. 张天钰 内大计算机学院,20175305张天钰Java结对编程四则运算