问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

sql 列完整性约束

发布网友 发布时间:2022-05-01 13:13

我来回答

3个回答

懂视网 时间:2022-05-01 17:34

table student1( sid char(6) primary key, sname varchar(20), age int, gender varchar(10) )

 

创建表时,定义列后指定主键

create table student2(
sid char(6),
sname varchar(20),
age int,
gender varchar(10),
primary key(sid)
);

 

创建表后,增加主键

create table student3(
sid char(6),
sname varchar(20),
age int,
gender varchar(10)
)

添加主键

alter table student3 add primary key(sid);

删除主键(只是删除主键约束,而不会删除主键列):

alter table student3 drop primary key;

 

2 主键自增长

MySQL提供了主键自动增长的功能!这样用户就不用再为是否有主键是否重复而烦恼了。当主键设置为自动增长后,在没有给出主键值时,主键的值会自动生成,而且是最大主键值+1,也就不会出现重复主键的可能了。

创建表时设置主键自增长(主键必须是整型才可以自增章)

create table stu4(
sid int primary key auto_increment,
sname varchar(20),
age int;
gender varchar(10)
)

 修改表时设置主键自增长:

alter table sut change sid sid int auto_increment;

  修改表时删除主键自增长:

alter table stu change sid sid int;
 3 非空

指定非空约束的列不能没有值,也就是说在插入记录时,对添加了非空约束的列一定要给值;在修改记录时,不能把非空列的值设置为NULL。

 指定非空约束:

create table stu5(
sid int primary key auto_increment,
sname varchar(20) not null,
age int,
gender varchar(10)
)

当为sname字段指定为非空后,在向stu表中插入记录时,必须给sname字段指定值,否则会报错:

INSERT INTO stu(sid) VALUES(1);

插入的记录中sname没有指定值,所以会报错!

 4 唯一

还可以为字段指定唯一约束!当为字段指定唯一约束后,那么字段的值必须是唯一的。这一点与主键相似!例如给stu表的sname字段指定唯一约束:

CREATE TABLE tab_ab(

         sid INT PRIMARY KEY AUTO_INCREMENT,

         sname VARCHAR(10) UNIQUE

);

 

INSERT INTO sname(sid, sname) VALUES(1001, ‘zs‘);

INSERT INTO sname(sid, sname) VALUES(1002, ‘zs‘);

  当两次插入相同的名字时,MySQL会报错!

 5 外键

主外键是构成表与表关系的唯一途径,外键是另一张表的主键。

l         创建t_user表,指定uid为主键列:

技术分享

create table user(
uid int primary key auto_increment,
name varchar(20) unique not null
)

   创建t_section表,指定sid为主键列,u_id为相对t_user表的uid列的外键:

create table section(
 sid int primary key auto_increment,
sname varchar(20) not null,
u_id int,
constraint fk_user_id foreign key(u_id) references user(uid)
)

   修改t_section表,指定u_id为相对t_user表的uid列的外键:

alter table section 
add constraint fk_user_id 
foreign key(u_id) 
references user(uid);

  修改t_section表,删除u_id的外键约束:

alter table section drop foreign key fk_user_id;

 

 

 

SQL复习四(完整性约束)

标签:自动生成   用户   create   creat   自动   src   添加   end   ges   

热心网友 时间:2022-05-01 14:42

CREATE TABLE C (
CODE varchar(6)
CONSTRAINT C_Code CHECK( PATINDEX('[A-Z][A-Z][0-9][0-9][0-9][0-9]', CODE) = 1)
);
GO

1>
2> INSERT INTO C VALUES('AA1234');
3> GO

(1 行受影响)

1>
2> INSERT INTO C VALUES('A12345');
3> GO
消息 547,级别 16,状态 1,服务器 HOME-BED592453C\SQLEXPRESS,第 2 行
INSERT 语句与 CHECK 约束"C_Code"冲突。该冲突发生于数据库"test",表"dbo.C", colum
n 'CODE'。
语句已终止。

1>
2> INSERT INTO C VALUES('AAA123');
3> GO
消息 547,级别 16,状态 1,服务器 HOME-BED592453C\SQLEXPRESS,第 2 行
INSERT 语句与 CHECK 约束"C_Code"冲突。该冲突发生于数据库"test",表"dbo.C", colum
n 'CODE'。
语句已终止。追问我是这样的

create table bill.仓库
(仓库号 char(6) primary key,

跟着怎么弄啊???

追答create table [仓库]
(
仓库号 char(6) primary key
CONSTRAINT 约束的名字 CHECK( PATINDEX('[A-Z][A-Z][0-9][0-9][0-9][0-9]', 仓库号) = 1),
其它字段 varchar(10)
)
go

1>
2>
3> INSERT INTO [仓库] VALUES('AA1234', '其它1');
4> go

(1 行受影响)
1>
2> INSERT INTO [仓库] VALUES('A12345', '其它2');
3> go
消息 547,级别 16,状态 1,服务器 HOME-BED592453C\SQLEXPRESS,第 2 行
INSERT 语句与 CHECK 约束"约束的名字"冲突。该冲突发生于数据库"test",表"dbo.仓库"
, column '仓库号'。
语句已终止。
1>
2> INSERT INTO [仓库] VALUES('AAA123', '其它3');
3> go
消息 547,级别 16,状态 1,服务器 HOME-BED592453C\SQLEXPRESS,第 2 行
INSERT 语句与 CHECK 约束"约束的名字"冲突。该冲突发生于数据库"test",表"dbo.仓库"
, column '仓库号'。
语句已终止。

热心网友 时间:2022-05-01 16:00

名 drop constraint 约束名
另外,虚机团上产品团购,超级便宜
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
找专业防水队做完还漏水怎么维权 法院会受理房屋漏水造成的纠纷吗? 巴西龟最长活多久,家养!!! 养胃的药最好的是什么啊 婴儿积食发烧不愿吃药怎么办 板门穴位在哪个部位 手机设置放偷看的方法? 凝结水回收器生产厂家? 个人账户养老金预测公式:现有5万元,缴费20年,能领多少钱? 临沂比较有名的男装品牌 问一个关于电话交换机的记录问题 如何在FreeSWITCH外联模式下使用esl接口时,设置无应答超时时间 IMS的功能实体 怎么删除c盘 里无用的文件 VOIP网络电话如何用话机设置固定IP? 如何卸载C盘里的QQ? 在ims系统中,hss和cscf之间的接口采用的是什么协议 如何删除在C盘中的QQ文件 怎样把残留的QQ文件删除干净? 什么是sangoma sbc qq装在d盘了c盘的qq文件怎样彻底删除它 怎么删了又回来了怎么办 什么是NAT穿越 从c盘删除不了qq文件 别人用我的支付宝为他开了亲密付该怎么办? 怎样拒绝别人为我弄的支付宝亲密付 联想笔记本 cpu温度总是70—80° 联想小新15温度过高? 联想笔记本电脑应存放在多少度温度下 联想笔记本 CPU正常温度是多少 联想笔记本CPU温度多少才算正常!不能超过多少 TXT文档的空格能一下消掉吗? 怎么样批量删除TXT表格里面的空格 写字楼装修要讲究目标,写字楼装修攻略是什么? 如何装饰中小型的写字楼? 写字楼怎么装修设计? 写字楼装修设计的注意事项有哪些 写字楼装修设计如何做到“光鲜亮丽”? SQL Server提供的数据完整性约束有哪些? powerpoint 母版视图分为幻灯片母版视图、标题母版视图和什么视图? 精算师的具体工作是什么??? 跑步会不会让小腿变粗?? 跑步会不会让小腿变粗啊? 精算师属于工程师吗 跑步会让小腿变粗吗 精算师这个职业具体是干什么的 跑步会不会让小腿变粗 跑步会不会让小腿变粗? 跑步能让小腿变粗吗 跑步会不会小腿变粗 跑步会不会使小腿变粗?