首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

【MySQL知识点】默认约束、非空约束

常见的约束分为默认约束、非空约束、唯一约束、主键约束、外键约束。...本期主要学习默认约束、非空约束~ ---- 默认约束 定义 默认约束用于为数据表中的字段指定默认值,即当在表中插入一条新纪录时,如果没有给这个字段赋值,那么,数据库系统会自动为这个字段插入默认值。...为现有的表添加或者删除默认约束,使用alter table 修改列属性就可以了。...表,准备n1、n2和n3两个字段进行测试,为n2添加非空约束,为n3添加默认约束,设置默认值为18,然后使用desc查看表结构,结果如 当省略了n2字段时,插入失败,提示n2没有默认值。...注意:为现有的表添加或删除非空约束的方式与默认约束类似,使用alter table修改列属性即可。但若目标列中已经保存了null值,添加非空约束会失败,此时只要将null值改为其他值即可解决。

3.1K30

数据库约束-主键约束-唯一约束-非空约束-默认

数据库约束-主键约束-唯一约束-非空约束-默认约束概述 约束其实就是一种限制,用于修饰表中的列. 通过这种限制来保证表中数据的正确性、有效性和完整性。...约束的类型 约束约束关键字 主键 primary key 非空 not null 唯一 unique 外键 foreign key ... references 默认 default 1....ALTER TABLE 表名 DROP PRIMARY KEY; 具体操作: 删除user1表的主键 ALTER TABLE user1 DROP PRIMARY KEY; 执行如下: -- 删除主键之前的表结构...默认值 DEFAULT 往表中添加数据时,如果不指定这个字段的数据,就使用默认值 4.1 默认值格式 字段名 字段类型 DEFAULT 默认值 4.2 实现字段默认值 具体操作: 创建一个学生表 st9...DEFAULT '广州' ); 添加一条记录,使用默认地址 INSERT INTO st9 (id, NAME) VALUES (1, '刘德华'); 添加一条记录,不使用默认地址 INSERT

6.1K10

MySQL删除约束_mysql查看表字段

desc 表名; #删除默认值 drop alter table alter 字段名 drop default; desc ; 5.删除字段 (drop) alter table drop 字段名;...非空约束 (not null) 非空约束即字段的内容不希望设置为空; CREATE TABLE (字段名 数据类型 NOT NULL); #修改数据类型时也可添加约束 2.默认约束(default) 为字段设置默认值...#创建表的时候,添加默认约束 CREATE TABLE (字段名 数据类型 default ‘默认值’); #删除默认约束 alter table alter 字段名 drop default; 3....); #添加唯一约束 ALTER TABLE ADD unique(字段名); #删除约束 ALTER TABLE DROP INDEX 约束字段; 5.自增约束(AUTO_INCREMENT)自增长的字段必须是...如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除

2.6K30

如何解决逻辑删除与数据库唯一约束冲突

前言 不知道大家有没有遇到这么一种业务场景,在业务中有个唯一约束A,当该业务进行逻辑删除后(设置标记为删除状态),再往唯一约束列插入相同的值时,此时会报Duplicate entry,但在业务上,该值时必须要插入的...今天我们就来聊聊处理这种业务场景的几种思路 解决思路 方案一:不采用逻辑删除,直接物理删除 方案二:新建历史表 主表进行物理删除,同时将删除的记录保存到历史表中 方案三:取消表的唯一约束,同时引入redis...来保证唯一约束 取消表的唯一约束,在项目中引入redis,通过redis来判重,新增时往redis set记录,删除时,删除redis记录 方案四:变更删除标记为时间戳 将删除状态不以0,1表示,而是以时间戳为值...,然后将删除状态为与之前的唯一约束A重新组成唯一联合约束index(A、del_flag),删除时变更del_flag的时间戳 方案五:保留删除标记,同时新建一个字段del_unique_key 保留删除状态位...,再新增一个字段del_unique_key,该字段默认值为0,字段类型和大小与主键id保持一致,同时与原先的唯一约束重新组成联合唯一约束index(A,del_unique_key),业务进行逻辑删除

4.1K11

如何解决逻辑删除与数据库唯一约束冲突

01前言 不知道大家有没有遇到这么一种业务场景,在业务中有个唯一约束A,当该业务进行逻辑删除后(设置标记为删除状态),再往唯一约束列插入相同的值时,此时会报Duplicate entry,但在业务上,该值时必须要插入的...今天我们就来聊聊处理这种业务场景的几种思路 02解决思路 方案一:不采用逻辑删除,直接物理删除 方案二:新建历史表 主表进行物理删除,同时将删除的记录保存到历史表中 方案三:取消表的唯一约束,同时引入redis...来保证唯一约束 取消表的唯一约束,在项目中引入redis,通过redis来判重,新增时往redis set记录,删除时,删除redis记录 方案四:变更删除标记为时间戳 将删除状态不以0,1表示,而是以时间戳为值...,然后将删除状态为与之前的唯一约束A重新组成唯一联合约束index(A、del_flag),删除时变更del_flag的时间戳 方案五:保留删除标记,同时新建一个字段del_unique_key 保留删除状态位...,再新增一个字段del_unique_key,该字段默认值为0,字段类型和大小与主键id保持一致,同时与原先的唯一约束重新组成联合唯一约束index(A,del_unique_key),业务进行逻辑删除

57320

sql2008删除默认实例_sql2000默认实例名

1.删除 SQL Server 的特定实例 若要删除 SQL Server 的某个特定实例,请按照以下步骤操作: 找到并删除%drive%:\\Program Files\\Microsoft SQL...备注:如果要删除默认实例,必须删除除Client 项之外的所有项。...默认实例的显示名称为 MSSQLSERVER,而命名实例的显示名称则为给这些实例所取的名称。...2.删除 SQL Server 的默认实例 若要删除 SQL Server 的默认实例,请找到并删除以下注册表项: HKEY_LOCAL_MACHINE\\SOFTWARE\\Microsoft\...如何解决Reporting Services目录数据库文件存在的问题 错误提示:自检时提示“Reporting Services目录数据库文件存在”失败,“Reporting Services目录临时数据库文件存在

3.5K10

【MySQL】外键约束删除和更新总结

外键约束删除/更新行为 行为 说明 NO ACTION 当在父表中删除/更新对应记录时,首先检查该记录是否有对应外键,如果有则不允许删除/更新。...(与RESTRICT一致) RESTRICT 当在父表中删除/更新对应记录时,首先检查该记录是否有对应外键,如果有则不允许删除/更新。...SET DEFAULT 父表有变更时,子表将外键列设置为一个默认的值(innodb不支持) alter table 表名 add constraint 外键名称 references 主表名(...主表字段名) on update cascade on delete cascade -- 添加外键约束并指定外键的删除和更新行为 alter table emp add constraint...-- 添加外键约束并指定外键的删除和更新行为 alter table emp add constraint fk_emp_dept_id foreign key (dept_id) references

39010

SQL 基础(二)数据表的创建、约束、修改、查看、删除

数据表删除 Management Studio 删除表 SQL 指令删除表 数据类型 数据类型 含义 CHARACTER(n) 字符/字符串。...数据完整性 保证数据库中数据的正确性、有效性、相容性,完整性机制主要有: 约束 Constraint 默认 Default 规则 Rule 触发器 Trigger 存储过程 Stotred Procedure...,其他约束需要通过“删除后重新添加“的方式完成修改 -- ALTER ALTER TABLE S ALTER COLUMN SN nvarchar(12) DROP 仅用于删除完整性约束定义 -- DROP...ALTER TABLE s3 DROP CONSTRAINT s_prim 数据表查看 右键 表 ,属性 查看表信息 数据表删除 Management Studio 删除表 表存在依赖对象时,不可删除...SQL 指令删除表 仅可删除匹配用户建立的表,用户权限要对应 -- 删除基本表 DROP TABLE s

96620
领券