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

MySQL数据库——表的约束(非空约束、唯一约束、主键约束、外键约束)

目录 1 表的约束 约束,是对表中的数据进行限定,保证数据的正确性、有效性和完整性,约束分为以下几类: 主键约束:primary key 非空约束:not null 唯一约束:unique 外键约束:foreign...UNIQUE ); 注意:MySQL中唯一约束限定的列的值可以有多个null 2)删除唯一约束: -- alter table stu modify number varchar(20); 不同于非空约束的删除方法...主键约束:primary key 1)注意: 若某一列添加了该约束,则代表了非空,且唯一; 一张表只能有一个字段为主键; 主键就是表中记录的唯一标识; 2)创建表时添加主键约束 CREATE TABLE...以上仍然存在一个问题,当在员工表中输入不存的部门时,数据依然可以添加,不符合实际,因此,这里就可以通过使用外键约束来解决。 【概念】什么是外键约束?...外键,就是从表中与主表主键对应的那一列,如:员工表中的dep_id,其中,主表是一方,用来约束别人的表,从表可以是多方,被别人约束的表。 注意:外键可以为NULL,但是不能是不存在的外键值。 ?

14.6K21

mysql的约束

在mysql设计表中,有个概念叫做约束 什么是约束 约束英文:constraint 约束实际上就是表中数据的限制条件 约束种类 mysql的约束大概分为以下几种: 非空约束(not null) 唯一性约束...应用场景方面,例如用户邮箱,用户密码不能为空,都可以增加非空约束 唯一性约束 唯一性约束是使用unique关键字进行的约束,它有多种约束方式以及约束形式....主键约束 关于主键约束 表中的某个字段添加主键约束后,该字段为主键字段,主键字段中出现的每一个数据都称为主键值. 表中每一行都应该有可以唯一标识自己的一列(或一组列)。...,这里就不多做介绍了 外键约束 若有两个表A、B,id是A的主键,而B中也有id字段,则id就是表B的外键,外键约束主要用来维护两个表之间数据的一致性。...注意: 外键值可以为null 外键字段去引用一张表的某个字段的时候,被引用的字段必须具有unique约束(主键也算是unique约束) 有了外键引用之后,表分为父表和子表  member表:父表 member_point

2.1K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    XML的约束——DTD

    简单来说:文档类型定义(约束) 规范一点就是:是一套关于标记符的语法规则。它是XML1.0版规格的一部分,是XML文件的验证机制,属于XML文件组成的一部分。...XML文件提供应用程序一个数据交换的格式,DTD正是让XML文件能成为数据交换标准,因为不同的公司只需定义好标准DTD,各公司都能依DTD建立XML文件,并且进行验证,如此就可以轻易的建立标准和交换数据...一些模式是随意组成的(例如,本文中的示例XML代码纯粹是即兴创作的),而其他模式则由标准组织严格定义。...最基本的模式通常也是最严格的。在我的示例XML代码中,将发行版名称放在节点中是没有意义的,因为文档的隐含模式清楚地表明 mascot必须是发行版的“子”元素。 ) 3.XML的两种文档约束(的树结构所造成的,这种结构占用的内存较多) 4.XML格式要求(合法XML)     1)有且只有一个根节点;     2)由开始标签和结束标签组成;     3)XML标签区分大小写

    53230

    【MySql】表的约束

    概述 真正约束字段的是数据类型,但是数据类型约束很单一,需要有一些额外的约束,更好的保证数据的合法性,从业务逻辑角度保证数据的正确性。比如有一个字段是email,要求是唯一的。...表中一定要有各种约束,通过约束,让我们未来插入数据库表中的数据是符合预期的。约束的本质是通过技术收到逼迫程序员插入正确的数据,反过来,站在mysql的视角,凡是插入进来的数据,都是符合数据约束的。...约束的最终目标:保证数据的完整性和可预期性所以需要更多的约束。...而我们设计员工工号的时候,需要一种约束:而所有的员工工号都不能重复。 具体指的是在公司的业务上不能重复,我们设计表的时候,需要这个约束,那么就可以将员工工号设计成为唯一键。...外键foreign key 外键用于定义主表和从表之间的关系:外键约束主要定义在从表上,主表则必须是有主键约束或unique约束。

    21530

    MySQL表的约束

    一.表的约束的概念 真正约束字段的是数据类型,但是数据类型约束很单一,需要有一些额外的约束,更好的保证数据的合法性,从业务逻辑角度保证数据的正确性。...所谓约束,就是避免犯一些低级错误,比如类似于语法错误,编译器的编译失败实际上也算是一种约束。 表中一定要有各种约束,通过约束,让我们未来插入数据库表中的数据是符合预期的。...约束的本质: 通过技术手段倒逼程序员插入正确的数据。反过来站在mysql的视角,凡是插入进来的数据,都是符合数据约束的。 约束的最终目标: 保证数据的完整性和可预期性。 为什么数据库这么严格?...数据库作为维护用户数据的最后一道防线,必须要保证数据库的数据是满足预期的,因此数据库的约束必须严格。为了更好的约束,就需要更多的约束条件,这也是这一节的内容。...通过desc操作,其后四列就属于约束条件: 总结一下:约束就是表结构的设计者在其他人插入数据之前,预先把规则定好,再让被别人按照他的规则进行数据的增删查改,不满足约束的数据不会被插入到对应的表中,这样下来

    22650

    MySQL:表的约束

    表的约束和约束的目标 表的约束:表中一定要有各种约束,通过约束,让我们未来插入数据库中的数据是符合预期的。约束本质是通过技术手段,倒逼程序员,插入正确的数据。...反过来,站在MySQL角度,凡是插入进来的数据,都是符合数据约束的! 约束的最终目标:保证数据的完整性和可预期性。 二....这就是“约束”。...像这样主键是有唯一性的,这是没问题的。 如果我插入的元素电话列,发生了冲突,但是主键又只能有一个,所以这里就需要唯一键来约束,保证电话的唯一性。...外键 外键用于定义主表和从表之间的关系:外键约束主要定义在从表上,主表则必须是有主键约束或unique约束。当定义外键后,要求外键列数据必须在主表的主键列存在或为null。

    6710

    【MySQL】表的约束

    表的约束 表的约束:表中一定要有各种约束,通过约束,让我们未来插入数据库表中的数据是符合预期的。约束本质是通过技术手段,倒逼用户,插入正确的数据。...反过来,在 mysql 角度,凡是插入进来的数据,都是符合数据约束的!约束的最终目的就是保证数据的完整性和可预期性。因此我们需要更多的约束条件!...真正约束字段的是数据类型,但是数据类型约束很单一,需要有一些额外的约束,更好的保证数据的合法性,从业务逻辑角度保证数据的正确性。比如有一个字段是 email,要求是唯一的。...,它们只有对应的关联关系,并没有任何的约束关系。...: 如上就是外键约束为我们解决的问题。

    15510

    Discourse 的无效附件清理

    Discourse 对上传的附件会进行清理,对于一些没有任何被引用的附件,Discourse 会认为是垃圾而清理掉。...原因应该是为了降低存储空间的使用,但是我们目前使用的是 S3 ,所以对存储空间并没有太多的要求。...根据我们备份恢复的情况来看,我们估计可能是这个表 upload_references 丢数据了,导致 uploads 中标的数据被清理掉了。本地查询我们本地查询了下操作前 3 天的记录。...服务器查询同时,我们对服务器上的表进行了查询。查询结果返回的是:6000 多。很明显这里有差距,那肯定是在恢复的过程中可能丢数据了。我们需要做的就是把本地表中的数据恢复到服务器上。...运行 SQL: select count(*) from upload_references;来查看下服务器上的记录,貌似服务器上的参考引用全部被恢复了。

    17300

    Excel中的无效链接(1)

    打开Excel文件的时候,时常会遇到说外部链接无效的警告。 无效链接大致有这么几种方式,有的很好解决,有的可就有些费神了。...自定义的名字 函数、数式的参照 粘贴过来的link 指向图形(文本框等)、cell的link 图表 透视表 这里说第一种的解决方法。...image.png 删除test.xlsx文件,再打开test2.xlsx的时候,会报【无效链接】的错误。如果这个excel内容比较多的时候,要找到哪一些cell使用了无效链接,有些许难度的。...我们可以断定是C4和G4这两个单元格使用了“河北省”,修改他们的值即可消除无效链接的错误。...G4"> 河北省 当然,如果是多个sheet的话,需要都搜索一下,看是否有这个无效的

    2.5K10

    ARC无效时block的赋值

    总所周知,当ARC无效时,block默认是在栈区或全局数据区,要想复制到堆区,需要一些特殊手段,这些手段在《Objective-C高级编程》都有介绍,例如将block声明为类的属性,block调用copy...但是《高级编程》里有个地方写错了,不过也有可能书上没写清楚是否开启ARC,不过通过我的实验验证,当ARC关闭时,在类方法中给block属性赋值,如果不加上copy,还是在栈上,但是在对象外部赋值却是在堆上...self->_index=10; }; } @end 此时如果定义一个MyObject对象,调用setInnerBlock后,再调用_blk,将会报出BAD_ADDRESS错误,因为栈上的block...要是查看blk的class也是stackblock,正确的赋值方式如下: MyObject* obj=[[MyObject alloc] init]; int a=0; // [

    81430

    写不好的SDC约束

    #笔记 SDC约束中出现的坑 在做综合时,需要对模块内部的小cell进行特定的时序约束,因此需要手写sdc文件,但是在这其中出现了一些自己没想到的情况,记录一下。...这个模块很简单,就是一个逻辑结构再加上一个MUX单元,如下图所示: 本意是对每级逻辑之间的延迟进行约束,使其固定在一个合理的范围内。...这个其实比较好理解,因为我是想约束logic1/o到logic2/o,但是net约束不能往回约束,因此MUX2/In0和MUX2/In1直接确实没有path,因此这个约束和本意是有区别的。...set_max_delay 0.1 -from [get_pins logic1/o] -through [get_pins logic2/o] -to [get_pins MUX2/In1] 很不幸,这个约束也是有问题的...这篇文章的意思是,我们在设置了sdc以后,综合不出现error不代表约束就真正约束好了,还是需要各种check timing,特别需要注意这种根本就没约上的情况。

    98010

    基于资源的约束委派

    基于资源的约束委派利用 基于资源的约束委派,(Resource-based constrained delegation),与前文提到的约束委派不同,它在信任的传递关系上是不同的,这也是它工作方向相反的一个因素...在约束委派中,账户A到账户B的约束委派在账户A的 msDS-AllowedToDelegateTo 属性中配置,并且定义了A到B的传出信任,而在基于资源的约束委派当中,委派在账户B的msDS-AllowedToActOnBehalfOfOtherIdentity...如图为在Elad师傅中的文章中所得的导图,通过此图,我们可以看出基于资源的约束委派与传统约束委派的工作方式有何不同。...在基于资源的约束委派当中,我们不需要再像传统的约束委派一样,通过域管理员权限,为用户设置相关的属性以便于请求相关服务,另一点就是传统的约束委派S4U2Self返回的票据,一定要是可转发的TGS(forwardableST...获得会话shell 利用基于资源的约束委派进行权限维持 根据基于资源的约束委派进行权限维持,主要有两种思路: 配置注册的机器账户到Krbtgt基于资源的约束委派 配置注册的机器账户到域控基于资源的约束委派

    1.1K10

    【MySQL】详解表的约束

    DEFAULT ' 男 ' COMMENT ' 性别 ' ) ENGINE=MyISAM DEFAULT CHARSET=gbk 三、主键 主键:primary key用来唯一的约束该字段里面的数据...一张表中有往往有很多字段需要唯一性,数据不能重复,但是一张表中只能有一个主键:唯一键就可以解决表中有多个字段需要唯一性约束的问题。...六、外键 外键用于定义主表和从表之间的关系: 外键约束主要定义在从表上,主表则必须是有主键约束或unique约束。当定义外键后,要求外键列数据必须在主表的主键列存在或为null 。...如果两张表在业务上是有相关性的,但是在业务上没有建立约束关系,那么就可能出现问题。解决方案就是通过外键完成的。...建立外键的本质其实就是把相关性交给 mysql去审核了,提前告诉mysql表之间的约束关系,那么当用户插入不符合业务逻辑的数据的时候,mysql不允许你插入。

    9510

    扫码

    添加站长 进交流群

    领取专属 10元无门槛券

    手把手带您无忧上云

    扫码加入开发者社群

    相关资讯

    热门标签

    活动推荐

      运营活动

      活动名称
      广告关闭
      领券