一、数据类型介绍

数据类型 字节长度 范围或用法
bigint 8 无符号[0,2^64-1],有符号[-2^63 ,2^63 -1]
binary(M) M 类似Char的二进制存储,只包含byte串而非字符串,它们没有字符集的概念,排序和比较操作都是基于字节的数字值
bit 1 无符号[0,255],有符号[-128,127]
blob Max:64K 二进制的对象,大小写敏感
char(M)  M 定长字符串
date 3 以YYYY-MM-DD的格式显示,比如:2009-07-19
datetime 8 以YYYY-MM-DD HH:MM:SS的格式显示,比如:2009-07-19 11:22:30
decimal(M,D) M+1或M+2 存储精确的数值
double(M,D) 8 双精度浮点
enum 1或2  最大可达65535个不同的枚举值,单选字符串数据类型,适合存储表单界面中的“单选值”
float(M,D) 单精度浮点数
geometry   存储空间点数据
geometrycollection   geometry集合类
int 4 无符号[0,2^32-1],有符号[-2^31,2^31-1] 
integer 无符号[0,2^32-1],有符号[-2^31,2^31-1] 
json   json格式数据
linestring   点之间的线性插值曲线
longblob Max:4G  大小写敏感 
longtext Max:4G 大小写不敏感
mediumblob Max:16M 大小写敏感
mediumint 3 无符号[0,2^24-1],有符号[-2^23,2^23-1]
mediumtext Max:16M 大小写不敏感
multilinestring   点之间的线性插值曲线的集合 
multipoint   点的集合 
multipolygon   多边形的集合 
numeric(M,D) M+1或M+2 精确存储数值,同decimal
point   二维空间中的点 
polygon   多边形 
real(M,D)   浮点数,REAL就是DOUBLE ,如果SQL服务器模式包括REAL_AS_FLOAT选项,REAL是FLOAT的同义词而不是DOUBLE的同义词 
set  

多选字符串数据类型,适合存储表单界面的“多选值”

insert into enum_set_table(id,gender,hobby) values(null,'F','music,movie,footbal');

smallint 无符号[0,65535],有符号[-32768,32767] 
text Max:64K  大小写不敏感 
time 以HH:MM:SS的格式显示。比如:11:22:30 
timestamp 以YYYY-MM-DD的格式显示,比如:2009-07-19 
tinyblob Max:255  大小写敏感 
tinyint 整数[0,255] 
tinytext Max:255  大小写不敏感 
varbinary(M) 类似varchar的变长二进制存储 
varchar(M) 变长字符串,MySQL要求一个行定义长度不能超过65535个字节,不包括text、blob等大字段类型,varchar长度受此长度限制,和其他非大字段加起来不能超过65535个字节。字符类型若为gbk,每个字符占用2个字节,字符类型若为utf8,每个字符最多占用3个字节。
year 以YYYY的格式显示。比如:2009 

二、外键删除更新规则

CASCADE:父表delete、update的时候,子表会delete、update关联记录

SET NULL:父表delete、update的时候,子表会将关联记录的外键字段所在列设为null,所以注意在设计子表时外键不能设为not null

RESTRICT:如果想要删除父表的记录时,而在子表中有关联该父表的记录,则不允许删除父表中的记录

NO ACTION:标准SQL的关键字,在MySQL中与RESTRICT相同

mysql知识汇总的更多相关文章

  1. 理论篇-MySQL知识汇总

    1. 唯一索引 普通索引允许被索引的数据列包含重复的值.唯一索引则是不允许有重复的值,当然 null 除外,唯一索引不仅仅可以存储 null , 还可以存储多个 null.这么做的好处是: 简化了My ...

  2. 【数据库_Mysql】Mysql知识汇总

    1.将多列字段合并显示用CONCAT(XX,XX,...): 2.查询表中某字段重复的数据: 查重复字段:select 字段 from table group by 字段 having count(* ...

  3. MySql面试题、知识汇总、牛客网SQL专题练习

    点击名字直接跳转到链接: Linux运维必会的100道MySql面试题之(一) Linux运维必会的100道MySql面试题之(二) Linux运维必会的100道MySql面试题之(三) Linux运 ...

  4. web前端project师知识汇总

    分类: Web开发应用  一.何为Web前端project师?           前端project师,也叫Web前端开发project师.他是随着web发展.细分出来的行业.Web前端开发proj ...

  5. Oracle手边常用70则脚本知识汇总

    Oracle手边常用70则脚本知识汇总 作者:白宁超 时间:2016年3月4日13:58:36 摘要: 日常使用oracle数据库过程中,常用脚本命令莫不是用户和密码.表空间.多表联合.执行语句等常规 ...

  6. Oracle 数据库知识汇总篇

    Oracle 数据库知识汇总篇(更新中..) 1.安装部署篇 2.管理维护篇 3.数据迁移篇 4.故障处理篇 5.性能调优篇 6.SQL PL/SQL篇 7.考试认证篇 8.原理体系篇 9.架构设计篇 ...

  7. Vertica 数据库知识汇总篇

    Vertica 数据库知识汇总篇(更新中..) 1.Vertica 集群软件部署,各节点硬件性能测试 2.Vertica 创建数据库,创建业务用户测试 3.Vertica 数据库参数调整,资源池分配 ...

  8. 【转】ACM博弈知识汇总

    博弈知识汇总 转自:http://www.cnblogs.com/kuangbin/archive/2011/08/28/2156426.html 有一种很有意思的游戏,就是有物体若干堆,可以是火柴棍 ...

  9. 最全的jQuery知识汇总

    本帖最后由 断天涯大虾 于 2016-12-26 10:22 编辑<ignore_js_op> jQuery是什么? jQuery是javascript编写一个可重用的JavaScript ...

随机推荐

  1. Django之ORM字段和字段参数

    ORM介绍 ORM概念 ORM由来 ORM的优势 ORM的劣势 ORM总结 Django中的ORM Django项目使用MySQL数据库 Model 快速入门 字段 自定义字段 字段参数 Model ...

  2. NEO区块链-DAPP开发直通车-第零篇

    什么是DAPP DAPP 是以太坊发明的词汇 Decentralized Application. 目前基于区块链技术开发的应用程序广泛的接受使用了这一名称.   NEL将为开发DAPP提供全面的服务 ...

  3. 面试题fugui02

    一.概念题 1.描述对super.pass.yield.lambda关键字修饰的理解 2.大致描述一下python GIL的机制,以及python中多线程和多进程的区别 GIL全局解释器锁,是pyth ...

  4. 浅谈KMP“串”的模式匹配问题

    感悟:预处理next[ ]数组求解B串的"自我匹配过程",思路与KMP类似,目标得到最大相同的前缀.后缀. ([1->k]==[i-k+1,i]),可以根据由前往后,利用前面 ...

  5. [Codeforces113C]Double Happiness(数论)

    题意 给定闭区间[l,r] [l,r] [l,r],找出区间内满足t=a2+b2 t=a^{2}+b^{2} t=a2+b2的所有素数t t t的个数( a,b a,b a,b为任意正整数). 思路 ...

  6. python系统编程(二)

    多次fork问题 如果在一个程序,有2次的fork函数调用,是否就会有3个进程呢? #coding=utf-8 import os import time # 注意,fork函数,只在Unix/Lin ...

  7. echarts动态添加数据

    数据异步加载 EChart中实现异步数据的更新非常简单,在图表初始化后不管任何时候只要通过 jQuery 等工具异步获取数据后通过 setOption 填入数据和配置项就行. 绑定数据的方式有两种,一 ...

  8. PAT Basic 1006

    1006 换个格式输出整数 (15 分) 让我们用字母 B 来表示“百”.字母 S 表示“十”,用 12...n 来表示不为零的个位数字 n(<10),换个格式来输出任一个不超过 3 位的正整数 ...

  9. 11-30 js高级

    1.事件: 浏览器客户端上客户触发的行为都称为事件 所有的事件都是天生自带的,不需要我们去绑定,只需要我们去触发. 通过obj.事件名=function(){} 事件名:onmouseover onm ...

  10. nested exception is java.lang.ClassNotFoundException

    当出现nested exception is java.lang.ClassNotFoundException这个异常的时候,首先排查类是否存在.如果存在,是maven项目的话,clean.insta ...