数据库约束

  1.基础限制

    ① 单一表内字节量总和不能超过65535,null 占用一个字节空间

    ② varchar存储255 以内字节占用一个字节表示长度,255以上自己则占用两个字节表示长度

    ③ 例如int(10)这里10指的是10字节宽度并非数字10,且 utf8下 一字符=3字节,gbk下一字符=2字节 ,具体如下

  数字类型

       根据字节数即可算出表示的范围了 
  • TINYINT                                    1 字节
  • SMALLINT                                 2 个字节
  • MEDIUMINT                              3 个字节
  • INT                                           4 个字节
  • INTEGER                                   4 个字节
  • BIGINT                                      8 个字节
  • FLOAT(X)                                  4 如果 X < = 24 或 8 如果 25 < = X < = 53
  • FLOAT                                       4 个字节
  • DOUBLE                                    8 个字节
  • DOUBLE PRECISION                  8 个字节
  • REAL                                         8 个字节
  • DECIMAL(M,D)                          M字节(D+2 , 如果M < D)
  • NUMERIC(M,D)                          M字节(D+2 , 如果M < D)
     日期和时间类型
  • DATE                                        3 个字节
  • DATETIME                                 8 个字节
  • TIMESTAMP                               4 个字节
  • TIME                                         3 个字节
  • YEAR                                         1 字节
     字符串类型
  • CHAR(M)                                        M字节,1 <= M <= 255
  • VARCHAR(M)                                 L+1 字节, 在此L <= M和1 <= M <= 255
  • TINYBLOB, TINYTEXT                     L+1 字节, 在此L< 2 ^ 8
  • BLOB, TEXT                                   L+2 字节, 在此L< 2 ^ 16
  • MEDIUMBLOB, MEDIUMTEXT         L+3 字节, 在此L< 2 ^ 24
  • LONGBLOB, LONGTEXT                 L+4 字节, 在此L< 2 ^ 32
  • ENUM('value1','value2',...)                1 或 2 个字节, 取决于枚举值的数目(最大值65535)
  • SET('value1','value2',...)                    1,2,3,4或8个字节, 取决于集合成员的数量(最多64个成员)

  2.主键

    主键关键字primary key ,规则 唯一,非空,索引凭据

    创建方式,例如:

      create table tb1(id int primary key not null auto_increment)engin=innodb chrset=utf8;

      create table tb1(id int not null auto_increment , primary key(id) )engin=innodb chrset=utf8;

    修改主键时需要 使用关键字 modify ,也可设置主键起始值,或者给主键赋值,但是主键赋值之后再次插入数据时候会根据末尾ID进行自增+1

    自增主键可设置起始值

      create table tb1(id int not null auto_increment , primary key(id) )engin=innodb auto_increment=9 chrset=utf8;

    修改主键使用drop关键字,修改主键使用modify

      alter table tb1 drop primary key;

      alter table tb1 modify id int;--这里是去掉了自增

    

    

    查看刚刚生成的主键 last_insert_id() 函数,类似鱼SQL中的 select scope_identity;

      select last_insert_id();   

      

  3.外键

    外键关键字 foreign key(class_id) references tb1(id) ,外键可以为空,可以重复,不符合外键约束值则无法添加,且外键关系是相互的其中一方无效则外键无效

      create table class(id int not null primary key auto_increment,name varchar(20))engine=innodb charset=utf8;

      create table student(id not null primary key auto_increment,name varchar(20),class_id int,foreign(class_id) references class(id))engine=innodb charset=utf8;

      insert into class (name) values('a','b','c');

      insert into student(name,class_id) values('1',1),('2',2),('3',null);

    

    

    

    

    删除外键使用关键字drop,添加外键使用add关键字,删除外键索引index

    注意删除外键之前需要查看外键,直接删除外键名称则找不到外键

    

    

    

  4.非空

    限制字段不润许取NULL值,但是可以存空字符,修改非空与否 与修改表字段相同只是不添加限制条件

    

  ·5.唯一

    限制字段取值,不能取出重复的值,允许null值,若字段中村财重复值则无法加入唯一,当然也可以设置多个字段同时拥有唯一约束

    

  6.检测

    check,该约束在数据插入的时候并不生效,所以一般忽略不计用法类似判断条件,一般会使用enum枚举来代替或者触发器trigger 。。then 代替。

    

JAVA基础--MySQL(二)的更多相关文章

  1. java 基础知识二 基本类型与运算符

    java  基础知识二 基本类型与运算符 1.标识符 定义:为类.方法.变量起的名称 由大小写字母.数字.下划线(_)和美元符号($)组成,同时不能以数字开头 2.关键字 java语言保留特殊含义或者 ...

  2. java基础(二章)

    java基础(二章) 一,变量 1.变量是内存中的一个标识符号,用于存储数据 2.变量命名规则 l  必须以字母.下划线 _ .美元符号 $ 开头 l  变量中,可以包括数字 l  变量中,不能出现特 ...

  3. Java基础十二--多态是成员的特点

    Java基础十二--多态是成员的特点 一.特点 1,成员变量. 编译和运行都参考等号的左边. 覆盖只发生在函数上,和变量没关系. Fu f = new Zi();System.out.println( ...

  4. java基础-多线程二

    java基础-多线程二 继承thread和实现Runnable的多线程每次都需要经历创建和销毁的过程,频繁的创建和销毁大大影响效率,线程池的诞生就可以很好的解决这一个问题,线程池可以充分的利用线程进行 ...

  5. JAVA基础(二)—— 常用的类与方法

    JAVA基础(二)-- 常用的类与方法 1 Math类 abs ceil floor 绝对值 大于等于该浮点数的最小整数 小于等于该浮点数的最大整数 max min round 两参数中较大的 两参数 ...

  6. Java实习生常规技术面试题每日十题Java基础(二)

    目录 1. JAVA 的反射机制的原理. 2.静态嵌套类(Static Nested Class)和内部类(Inner Class)的不同? 3.如何将String类型转化成Number类型. 4.什 ...

  7. Java基础系列二:Java泛型

    该系列博文会告诉你如何从入门到进阶,一步步地学习Java基础知识,并上手进行实战,接着了解每个Java知识点背后的实现原理,更完整地了解整个Java技术体系,形成自己的知识框架. 一.泛型概述 1.定 ...

  8. Java 基础(二)| 使用 lambad 表达式的正确姿势

    前言 为跳槽面试做准备,今天开始进入 Java 基础的复习.希望基础不好的同学看完这篇文章,能掌握 lambda 表达式,而基础好的同学权当复习,希望看完这篇文章能够起一点你的青涩记忆. 一.什么是 ...

  9. Java基础(十二)--clone()方法

    Clone在Java中就是用来复制对象,通过分配一个和源对象相同大小的内存空间,然后创建一个新的对象,那么他和=的区别在哪? 通过=实现对象拷贝: @Data @NoArgsConstructor @ ...

  10. Java基础教程——二维数组

    二维数组 Java里的二维数组其实是数组的数组,即每个数组元素都是一个数组. 每个数组的长度不要求一致,但最好一致. // 同样有两种风格的定义方法 int[][] _arr21_推荐 = { { 1 ...

随机推荐

  1. ubuntu Ifconfig只显示一个lo

    第一步启动网卡 是网卡未启动 命令: ifconfig -a,显示所有网络接口的信息. ifconfig显示当前激活的网络接口信息 ifconfig eth0 up 启动网卡 ifconfig -a ...

  2. Jmeter websocket插件安装与使用

    Jmeter websocket插件安装与使用 Apache JMeter是Apache组织开发的基于Java的压力测试工具.用于对软件做压力测试,它最初被设计用于Web应用测试,但后来扩展到其他测试 ...

  3. linux安装php nginx mysql

    linux装软件方式: systemctl status firewalld.service 查看防火墙systemctl stop firewalld.service systemctl disab ...

  4. webdriver 属于selenium 体系中设计出来操作浏览器的一套API

    1.元素的定位   1.id属性定位 实例:   find_element_by_id("kw")  2.name属性定位,同id一样是属性值 实例:  find_element_ ...

  5. 动态路由 RIP

    不同网段之间进行通信,中间有多个路由器的情况下,我们可以通过配置RIP动态路由来实现数据转发. 实验拓扑 如图所示连接,地址规划如下: 名称 接口 IP地址 R1 f0/0 192.168.10.1/ ...

  6. 【Netty】初识Netty

    一.为什么会出现Netty 之前我们使用通用的应用程序或库来相互通信.例如,我们经常使用HTTP客户机库从web服务器检索信息,并通过web服务调用远程过程调用.然而,通用协议或其实现有时伸缩性不是很 ...

  7. 【Git】Git如何合并某一次commit的内容到指定分支

    一.我是在什么场景下会用到该Git操作 当某同事,将开发分支dev2合并到开发分支dev1时(两个不同的功能,不能合并),其他同事不知情的情况下,继续在dev1上开发并提交了代码. 后面发现了该合并, ...

  8. 神舟笔记本Hasee安装Ubuntu Desktop和Gnome

    目录 1. 安装Ubuntu-desktop 2. 解决hasee T97 WiFi.声音输入输出.无法关机问题 3. 更新grub启动引导 4. 安装缺失的驱动(否则4.15内核无法进入桌面) 5. ...

  9. 《linux就该这么学》课堂笔记03 命令初识 echo、date、reboot、poweroff、wget...

    Linux进程的六种状态(R.S.D.T.Z.X): R --- TASK_RUNNING(可执行状态) S --- TASK_INTERRUPTIBLE(可中断的睡眠状态) D --- TASK_U ...

  10. jenkins权限管理插件role-based(二)

    一.安装role-based插件 jenkins默认自带“configure global security/全局安全配置”比较简陋,不建议使用 系统管理-->插件管理-->可选插件--& ...