sql server创建表相关
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)
外键在主表中的数据不能重复,不管是主键还是唯一键都可以作为其它表的外键
sql server创建表相关的更多相关文章
- SQL Server 创建表分区
原文:SQL Server 创建表分区 先准备测试表 CREATE TABLE [dbo].[Employee] ( EmployeeNo ,) PRIMARY KEY, EmployeeName ) ...
- SQL Server创建表超出行最大限制解决方法
问题的现象在创建表A的时候,出现“信息 511,级别 16,状态 1,第 5 行 无法创建大小为 的行,该值大于允许的最大值 8060.”的信息提示.很奇怪,网上查了一下,是因为要插入表的数据类型的 ...
- SQL Server 创建表
SQL Server 创建表 我们在上一节中完成了数据库的创建,在本节,我们要往这个新的数据库中加入点数据,要想将数据添加到数据库,我们就必须在数据库中添加一个表,接下来来看看具体的操作. 我们的数据 ...
- SQL Server 创建表 添加主键 添加列常用SQL语句
--删除主键 alter table 表名 drop constraint 主键名 --添加主键 alter table 表名 add constraint 主键名 primary key(字段名1, ...
- SQL Server 创建表 添加主键 添加列常用SQL语句【转】
--删除主键alter table 表名 drop constraint 主键名--添加主键alter table 表名 add constraint 主键名 primary key(字段名1,字段名 ...
- SQL SERVER创建表
创建表 create table table_name ( column_name_1 data_type, column_name_2 data_type NOT NULL, column_name ...
- Sql Server 创建表添加说明
http://bbs.csdn.net/topics/340184487 在此感谢 提供参考 CREATE TABLE ToPayFee ( Id INT IDENTITY(1,1) PRIMA ...
- SQL server 创建表,索引,主键,外键
if object_id('student', 'U') is not null drop table student go create table student( sno varchar(20) ...
- sql server系统表和视图相关的语句
一.系统表 数据字典的详细信息请查SQL SERVER BOL,这里仅列出一部分. 1.1.sysservers 1.查看所有本地服务器及链接服务器 select * from master..sys ...
随机推荐
- Django 1.6 最佳实践: 如何设置django项目的设置(settings.py)和部署文件(requirements.txt)
Django 1.6 最佳实践: 如何设置django项目的设置(settings.py)和部署文件(requirements.txt) 作者: Desmond Chen,发布日期: 2014-05- ...
- cocos2d jsb 打包 Android APK
1.首先要会普通的cpp 打包成Android APK 下面所说的是在cocos2d-x 2.2.2 或者 2.3 版本号中.本文在Eclipse总用ndk编译cocos2d-x. 老生常谈cocos ...
- 从零开始学android开发-获取控件
mBtnNews = (Button)findViewById(R.id.btn_news);//获取控件
- [Angular2 Form] Group Inputs in Angular 2 Forms with ngModelGroup
The ngModelGroup directive allows you to group together related inputs so that you structure the obj ...
- java.net.SocketException四大异常解决方案【转】
java.net.SocketException如何才能更好的使用呢?这个就需要我们先要了解有关这个语言的相关问题.希望大家有所帮助.那么我们就来看看有关java.net.SocketExceptio ...
- 用SecureCRT来上传和下载数据
借助securtCRT,使用linux命令sz可以很方便的将服务器上的文件下载到本地,使用rz命令则是把本地文件上传到服务器. 其中,对于sz和rz的理解与记忆我用了如下的方法(很多时候容易搞混): ...
- IPC——流套接字通信
Linux进程间通信——使用流套接字 前面说到的进程间的通信,所通信的进程都是在同一台计算机上的,而使用socket进行通信的进程可以是同一台计算机的进程,也是可以是通过网络连接起来的不同计算机上的进 ...
- IFormatProvider,ICustomFormatter,IFormattable总结
IFormatProvider中 public object GetFormat(Type formatType); 该方法主要用于获取一个 ICustomFormatter接口的实例 ICustom ...
- Web安全XSS
Web安全XSS 简单的反射型XSS钓鱼演示 </form> <script> function hack(){ XSSImage=new Image; XSSImage.sr ...
- Fedora 23如何安装LAMP服务器
LAMP 是开源系统上 Web 服务器的梦幻组合.LAMP 是 Linux. Apache HTTP 服务. MySQL/MariaDB 数据库和 PHP. Perl 或 Python 的简称. 下面 ...