首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

mysql创建数据表及约束

MySQL中,表是存储数据的基本单位,每张表有若干列,每一行代表一条数据记录。在MySQL中,数据是按行存储的。...创建数据表的基本语法如下 CREATE [TEMPORARY] TABLE [IF NOT EXISTS] table_name( 列名1 数据类型 [约束条件] [默认值], 列名2 数据类型 [约束条件...主键约束要求主键列数据唯一,且不能为空。主键可以标识表的唯一一条记录。表的主键相当于表的目录。为表创建主键后,使用主键列作为查询条件可以大大加快表的查询速度。...,列名n) 创建用户表user_tmp3,指定id列和name列为联合主键,语法如下: CREATE TABLE user_tmp3( id int(11), name varchar(128), age...| name | +------+----------+ | 1 | new_user | +------+----------+ 1 row in set (0.00 sec) mysql

3.7K40

主、外键约束_创建主键约束

主、外键约束 点关注不迷路,欢迎再来! 精简博客内容,尽量已专业术语来分享。 努力做到对每一位认可自己的读者负责。 帮助别人的同时更是丰富自己的良机。...主键和外键是两种类型的约束; 1.主键是能唯一的标识表中的每一行,就是说这一列非空且值不重复,可以指定为主键;作用是用来强制约束表中的每一行数据的唯一性; 2.外键是b表中的某一列引用的值来源于a表中的主键列...也是约束b表中的外键列的值必须取致a表中的主键列值,不是其中的值就不能插入b表中。可以形成a表b表的联系,保持数据的约束和关联性。...创建主表主键: CREATE table dept ( deptno NUMBER(11) PARIMARY KEY, dname VARCHAR2(14) not null, loc...VARCHAR2(13) ); 创建副表及外键: CREATE table emp( empno NUMBER(4,0) PRIMARY KEY, ename VARCHAR2

1.9K20
您找到你想要的搜索结果了吗?
是的
没有找到

MySQL 约束

注意,上述所有约束中,一个数据表中,无论是单一主键还是复合主键,只能有一个主键约束,其它约束可以有多个。 3.创建约束 创建主键约束 建表时在字段后添加 PRIMARY KEY 表明是主键。...创建唯一约束 建表时在字段后使用 UNIQUE 创建唯一约束。 例如,在用户信息表中,要避免表中的用户名重名,就可以把用户名列设置为唯一约束。...); 创建检查约束MySQL 8.0.16 之前,CREATE TABLE 仅允许以下有限版本的表 CHECK 约束语法,该语法将被解析并忽略: CHECK (expr) 从 MySQL 8.0.16...这意味着在插入、更新或删除数据时,MySQL 将检查约束条件(expr)是否满足,如果条件不满足,则不允许进行相应的操作。 如果指定为 NOT ENFORCED,则创建约束但不强制执行。...MySQL 为另一个生成一个名称。 创建默认值约束 建表时在字段后使用 DEFAULT 添加默认值可创建默认值约束

17010

MySQL约束

约束 约束是一种限制,它通过对表的行或列的数据做出限制,来确保表的数据的完整性、唯一性。...非空约束 (not null 被设置非空约束的字段值不能为空) - 建表时添加非空约束: - create table student( - id int not null, - id_number...字段名; 创建表之后添加唯一约束:alter table 表名 modify 字段名 数据类型 unique; 主键约束 (primary key 同时保证了唯一和非空) - 创建表时添加主键约束...,自增长列一般和主键搭配 创建的时候添加:id int primary key auto_increment, 删除自动增长:alter table 表名 modify 字段名 数据类型; 添加自动增长...外键约束 (foreign key , 让多个表之间关联,从而保证数据的正确性) - 创建表时添加外键约束: - 删除键外键约束:alter table 表名 drop foreign key 外键名称

1.6K20

MySQL 约束介绍

唯一性约束允许列值为空。 在创建唯一约束的时候,如果不给唯一约束命名,就默认和列名相同。 MySQL会给唯一约束的列上默认创建一个唯一索引。...如果是多列组合的复合主键约束,那么这些列都不允许为空值,并且组合的值不允许重复 当创建主键约束时,系统默认会在所在的列或列组合上建立对应的主键索引 CREATE TABLE 表名称( 字段名 数据类型...字段名 数据类型; 5、外键约束 限定某个表的某个字段的引用完整性 从表的外键列,必须引用/参考主表的主键或唯一约束的列 在创建外键约束时,如果不给外键约束命名,默认名不是列名,而是自动产生一个外键名...创建(CREATE)表时就指定外键约束的话,先创建主表,再创建从表 删表时,先删从表(或先删除外键约束),再删除主表 从表的外键列与主表被参照的列名字可以不相同,但是数据类型必须一样,逻辑意义一致 在“...从表”中指定外键约束,并且一个表可以建立多个外键约束创建外键约束时,系统默认会在所在的列上建立对应的普通索引,索引名是外键的约束名,删除外键约束后,必须手动删除对应的索引 CREATE TABLE

1.6K41

mysql约束

mysql设计表中,有个概念叫做约束 什么是约束 约束英文:constraint 约束实际上就是表中数据的限制条件 约束种类 mysql约束大概分为以下几种: 非空约束(not null) 唯一性约束...(unique) 主键约束(primary key) PK 外键约束(foreign key) FK 检查约束(目前MySQL不支持、Oracle支持,本文不做介绍) 为了能继续看下去,打开mysql,... default 0,## 没有约束   `add_time` datetime ## 没有约束 )engine =InnoDb charset = 'utf8'; 在这个创建语句中,我们使用到了3种约束...(非空约束,主键约束,唯一性约束);在后面会使用到外键约束 非空约束 非空约束是我们最常见的一种约束方式,它规定了我们插入数据不允许为空(在mysql中,''不是空,null才是),例如以下插入语句:...表:子表 创建创建父表 删除先删除子表数据 插入先插入父表数据 外键约束将会让mysql在插入,删除,更新会增加额外的判断,严格来说,不允许使用外键约束,如果需要限制,请在代码层限制

2.1K10

Mysql外键约束

外键是用来实现参照完整性的,不同的外键约束方式将可以使两张表紧密的结合起来,特别是修改或者删除的级联操作将使得日常的维护工作更加轻松。...外键主要用来保证数据的完整性和一致性 两个表必须是InnoDB表,MyISAM表暂时不支持外键 外键列必须建立了索引,MySQL 4.1.2以后的版本在建立外键时会自动创建索引,但如果在较早的版本则需要显示建立...如果父表试图UPDATE或者DELETE任何子表中存在或匹配的外键值,最终动作取决于外键约束定义中的ON UPDATE和ON DELETE选项。...外键约束使用最多的两种情况: 1)父表更新时子表也更新,父表删除时如果子表有匹配的项,删除失败; 2)父表更新时子表也更新,父表删除时子表匹配的项也删除。...DEFAULT CHARSET=utf8 AUTO_INCREMENT=2 ; INSERT INTO `category` (`id`, `name`) VALUES (1, '分类1'); 创建外键约束

5.8K81

MySQL约束详接

可以在创建表时规定约束(通过 CREATE TABLE 语句),或者在表创建之后通过 ALTER TABLE 语句规定约束。  ...唯一约束可以是某一个列的值唯一,也可以多个列组合的值唯一。 唯一性约束允许列值为空。在创建唯一约束的时候, 如果不给唯一约束命名,就默认和列名相同。...MySQL会给唯一约束的列上默认创建一个唯一索引。 添加唯一约束 举例:    删除唯一约束 添加唯一性约束的列上也会自动创建唯一索引。 删除唯一约束只能通过删除唯一索引的方式删除。...删除时需要指定唯一索引名,唯一索引名就和唯一约束名一样。 如果创建唯一约束时未指定名称,如果是单列,就默认和列名相同;如果是组合列,那么默认和()中排在第一个的列名相同。也可以自定义唯一性约束名。... 建表后 alter table 表名称 modify 字段名 数据类型 auto_increment;  MySQL 8.0将自增主键的计数器持久化到重做日志中。

1.8K10

MySQL】:约束全解析

本文将深入介绍MySQL中的各种约束类型及其使用方法,包括非空约束、唯一约束、主键约束、默认约束、检查约束和外键约束,以及如何在创建表和修改表时添加约束,以及外键约束的相关知识。 一....,保证数据的一致 性和完整性 FOREIGN KEY 注意:约束是作用于表中字段上的,可以在创建表/修改表的时候添加约束 。...约束演示 如何在创建表、修改表的时候来指定约束呢,接下来我们就通过一个案例,来演示一下。...我们执行上面的SQL把表结构创建完成,然后接下来,就可以通过一组数据进行测试,从而验证一下,约束是否可以生效。...CONSTRAINT 外键名称 FOREIGN KEY (外键字段) REFERENCES 主表名 (主表字段名) ON UPDATE CASCADE ON DELETE CASCADE; ️全篇总结 本文详细介绍了MySQL

16310

Mysql约束、分组查询

tip: 通过 desc 表名命令查看当前表信息 tip2: as 关键字可以为我们的字段或者表取别名 Mysql约束 顾名思义就是对表中的数据进行限定, 目的是保证数据的正确性, 有效性和完整性 主键约束...only one auto column and it must be defined as a key 联合主键 主键其实只能有一个, 如果在图形界面当中选择多个字段作为主键, 那么程序会自动帮我们创建联合主键...NOT NULL 只能约束程序层面上没有操作该表中的某个字段, 不能约束人行为上对其赋值为空白字符....唯一约束 UNIQUE NULL可以重复 比如统计店铺业绩, 该店铺不可以重复, 那就可以使用唯一约束 外键约束foreign key 外键的作用 保持数据的一致性和完整性, 通过外键来表达主表和从表的关系...维护成本 需要有专业DBA来维护庞大的数据库关系 default 默认约束, 默认会填充当前字段.

3.7K30

MySql】表的约束

表中一定要有各种约束,通过约束,让我们未来插入数据库表中的数据是符合预期的。约束的本质是通过技术收到逼迫程序员插入正确的数据,反过来,站在mysql的视角,凡是插入进来的数据,都是符合数据约束的。...) 复合主键 在创建表的时候,在所有字段之后,使用primary key(主键字段列表)来创建主键,如果有多个字段作为主键,可以使用复合主键。...对于自增长:默认是从1开始插入的,如果默认插入了一个值作为起始值,则从这个起始值加1开始 所以我们在创建表的时候可以给自增长设置一个起始值: mysql> create table t22( -...,上面的例子,我们不创建外键约束,就正常建立学生表,以及班级表,该有的字段我们都有。...建立外键的本质其实就是把相关性交给mysql去审核了,提前告诉mysql表之间的约束关系,那么当用户插入不符合业务逻辑的数据的时候,mysql不允许你插入。

17130

MYSQL】表的约束

前言 真正约束字段的是数据类型,但是数据类型约束很单一,需要有一些额外的约束,更好的保证数据的合法性,从业务逻辑角度保证数据的正确性。比如有一个字段是email,要求是唯一的。...'学号', name varchar(5) ); 创建好表之后,我们可以追加主键 2.删除主键 alter table 表名 drop primary key; 案例: 3.复合主键 在创建表的时候...而我们设计员工工号的时候,需要一种约束:而所有的员工工号都不能重复。 具体指的是在公司的业务上不能重复,我们设计表的时候,需要这个约束,那么就可以将员工工号设计成为唯一键。...,主表则必须是有主键约束或unique约束。...因此诞生了外键来约束

21740
领券