sql server创建表相关
2016-07-07 09:30 鲁佐富 阅读(282) 评论(0) 收藏 举报1,设置主键的sql的三种方式
a、字段名 int primary key
b、字段名 int constraint 主键名 primary key clustered(字段名)
c、创建表是,后置一句:constraint 主键名 primary key clustered【聚集索引】(字段名)
2,给两个字段创建索引的语句
constraint 主键名 primary key clustered(字段名1,字段名2)---只要两个字段的值不相同即可
一个表只能创建一个主键,一个主键可以包含多个列,主键不能为null也不能重复,主键会自动创建为聚集索引。
3,一个数据库里的主键名不能相同
查看数据库主键的sql
select * from sys.Objects where type='pk'
---为已经存在的表增加主键 alter table 表名 add constraint 主键名 primary key clustered(列名)
---删除主键的sql alter table 表名 drop constraint 主键名
4,创建唯一键
a,创建表时,字段名 数据类型 后面跟 constraint uq_唯一键名 unique nonconstered【非聚集索引】(字段名)
注意的几点:唯一键允许一行数据的值为空,唯一键默认创建非聚集索引unique最多可以有249个。
查看数据库唯一键的sql
select * from sys.Objects where type='uq'
5,check约束
例如年龄大于0的约束:创建表时 列名 数据类型 constraint check_约束名 check(sage>0)
例如性别只能是男或女:constraint check_约束名 check (sex in('男','女'))
例如手机号码:constraint check_smobile check (smobileNO like '[1][34578][0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9]')
---通配符
%表示可以匹配0个或多个字符
_表示匹配一个字符
例如是邮箱:constraint check_email check (semail like '%_[@]%_[.]%_')
[]这个包括的表示一个字符,其中有多个字符的话,只要是其中的一个字符就行
6,外键
创建外键的sql,先创建一个表的字段例如是sno
再创建另外一个表是,如果这个表的sno是第一个表的外键
sql:列名 数据类型 constraint fk_外键名 foreign key(sno)references 第一个表的(sno)
外键在主表中的数据不能重复,不管是主键还是唯一键都可以作为其它表的外键
浙公网安备 33010602011771号