SQL Sever 2008 R2 数据库(3) ——数据表管理-阿里云开发者社区

开发者社区> 技术小牛人> 正文

SQL Sever 2008 R2 数据库(3) ——数据表管理

简介:
+关注继续查看

1. 创建新表

例一: 创建新表

create table northwind.dbo.例一表

(

编号 int,

姓名 nvarchar(50)

)

create table northwind.例一表

(

编号 int,

姓名 nvarchar(50)

)

use northwind

create table 例一表

(

编号 int,

姓名 nvarchar(50)

)

2. 创建标识字段

例二: 创建新表并设置标识字段

创建一个新表,表结构为"例二表(编号 int,姓名 nvarchar(50))"。其中,"编

号"为自动增长列。

create table 例二表

(

编号 int identity,

姓名 nvarchar(50)

)

3. 创建带标识种子和标识增量的标识字段

例三:创建带标识种子和标识增量的标识字段

创建一个新表,表结构为"例三表(编号 int,姓名 nvarchar(50))" 。其中,"编号"为

主键和自动增长列,增长步为2

create table 例三表

(

编号 int identity(1,2) primary key,

姓名 nvarchar(5)

)

4. 创建非Null字段

例四: 创建非空值字段

创建一个新表,表结构为"例四表(编号 int,姓名 nvarchar(50))".其中,"编号"

为主键和自动增长列,"姓名"为不能为Null列.

creat table 例四表

(

编号 int identity(1,1) primary key,

姓名 nvarchar(50) not null

)

5. 字段的默认值

例五: 设置字段的默认值

创建一个新表,表结构为"例五表(编号 int,姓名 nvarchar(50),性别 bit)".其

中,"编号"为主键和自动增长列,"姓名"为不能Null列,"性别"的默认值为"男",在

bit里用"1"表示.

create table 例五表 P213

(

编号 int identity(1,1) primary key,

姓名 nvarchar(50),not null,

性别 bit default 1

)

6. 将创建的表放在文件组中

例六: 创建新表并将其放在文件组中

创建一个新表,表结构与例五中的相同,并将新表放到"第二文件组"中.

create table 例六表 P213

(

编号 int identity(1,1) primary key,

姓名 nvarchar(50) not null,

性别 bit default 1

)

on 第二文件组

7. 使用Check约束

例七: 创建新表并使用Check约束

创建一个新表,表结构为"例七表(编号 int,姓名 nvarchar(50),性别 bit,年

纪 tinyint)". 其中,"编号"为主键和自动增长列,"姓名"为不能Null列,"性别"

的默认值为1,年纪为1到100之间.

create table 例七表

(

编号 int identity(1,1) primary key,

姓名 nvarchar(50) not null,

性别 bit default 1,

年纪 tinyint constraint ck_年纪 check(年纪>0 and 年纪<101)

)

8. 设置字段的排序规则

例八: 创建新表并设置字段的排序规则

创建一个新表,表结构与例七中表结构相同,并且按"姓名"字段排序.

create table 例八表

(

编号 int identity(1,1) primary key,

姓名 nvarchar(50) collate Chinese_PRC_CI_AS not null,

性别 bit default 1,

年纪 tinyint constraint ck_例八年纪 check(年纪>0 and 年纪<101)

)

9. 创建外键

例九: 创建两个新表并设置外键

创建两个新表,一个是部门表,表结构为"例九_部门表(部门编号 int,部门名称

nvarchar(50))".其中,"部门编号"为自动增长的主键,"部门名称"不能重复也不能

为空.另一个是员工表,表结构为"例九_员工表(员工编号 int,所属部门 int,员工

姓名 nvarchar(20))".其中,"员工编号",为自动增长的主键,"所属部门"为外键

指向"例九_部门表"的"部门编号"字段,"员工姓名"为不能为Null的字段.

create table 例九_部门表

(

部门编号 int identity(1,1) primary key,

部门名称 nvarchar(50) not null,

)

go

create table 例九_员工表

(

员工编号 int identity(1,1) primary key,

所属部门 int

constraint fk_员工表外键

foreign key

references 例九_部门表(部门编号),

员工姓名 nvarchar(20) not null

)

go

10. 设置外键的更新规则和删除规则

例十: 创建新表并设置外键规则

创建两个新表,表结构与例九中两个一样,并将外键约束的更新规则设置为"层叠",

删除规则设置为"设置空".

create table 例十_部门表

(

部门编号 int identity(1,1) primary key,

部门名称 nvarchar(50) not null

)

go

create table 例十_员工表

(

员工编号 int identity(1,1) primary key,

所属部门 int

constraint fk_例十_员工表外键

foreign key

references 例十_部门表(部门编号)

on update cascade

on delete set null,

员工姓名 nvarchar(20) not null

)

go

11. 创建Unique约束

例十一: 创建新表并同时创建Unique约束

创建一个新表,表结构与"例九_部门表"结构一样,并将"部门名称"设置为Unique约束

create table 例十一_部门表

(

部门编号 int identity(1,1) primary key,

部门名称 nvarchar(50) not null unique

)

12. 创建计算列

例十二: 创建新表并创建可计算的列

创建一个新表,表结构为"例十二表(编号 int,单价 money,数量 int,合计 money)"

其中,"编号"为主键和自动增长列,"单价"不能为空,"数量"不能空,且大于零,"合计"

为"单价"乘以"数量".

create table 例十二表

(

编号 int identity(1,1) primary key ,

单价 money not null ,

数量 int not null

constraint ck_例十二表 check (数量>0),

合计 as 单价*数量

)

13. 设置数据表的约束

数据表约束同时针对多个字段约束.下面我们来看看数据表约束与字段约束的不同之处

例十三: 创建新表并设置数据表的约束

创建一个新表,表结构为"例十三_用户注册表(编号 int,用户名nvarchar(50),密码

varchar(16),电话 varchar(50),地址nvarchar(200))", 其中,"编号"为主键和自动增长列,"用户名"和

"密码"不能为空,"电话"和"地址"至少有一个不为空.

create table 例十三_用户注册表

(

编号 int identity(1,1) primary key



本文转自 beyondhedefang 51CTO博客,原文链接:http://blog.51cto.com/beyondhdf/1154004 ,如需转载请自行联系原作者

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
SQL Serever学习13——数据库编程语言
编程基础 注释 注释命名来对一些语句进行说明,便于日后维护或者其他用户理解,注释不会执行。 单行注释 SELECT GETDATE() --查询当前日期 多行注释 /* 注释有助于 理解操作的内容 查询当前日期 */ SELECT GETDATE() 变量 在T-SQL执行命令时,可...
976 0
mysql 5.7 修改数据库表
修改数据表 修改数据表是修改数据库中已经存在的数据表的结构。MySQL使用alter table 语句修改表。常用的修改表操作有:修改名,修改字段数据类型或字段名,增加和删除字段,修改字段的排列位置,更改表的存储引擎,删除表的外键约束。
1081 0
Mysql数据库表分区深入详解
0、mysql数据库分区的由来? 1)传统不分区数据库痛点
17 0
Linux基础命令---mysqladmin数据库管理工具
mysqladmin mysqladmin是mysql数据库的管理工具,可以控制、查看、修改数据库服务器的配置和状态。 此命令的适用范围:RedHat、RHEL、Ubuntu、CentOS、Fedora。
919 0
怎样在Sql server2008客户端管理器修改多于200行的数据
版权声明:欢迎评论和转载,转载请注明来源。 https://blog.csdn.net/zy332719794/article/details/8778356 在修改数据时,当数据记录的行数大于200行时,对表内容进行修改操作,当我用鼠标右键点击表时,出现: 然而,并没有我想要的编辑200行后的数据。
523 0
SQL Serever学习17——数据库的分析和设计
数据库的分析和设计 设计数据库确定一个合适的数据模型,满足3个要求: 符合用户需求,包含用户所需的所有数据 能被数据库管理系统实现,如sqlserver,oracle,db2 具有比较高质量,容易理解,使用方便,便于维护,效率高 设计步骤分为6步: 需求分析,与用户沟通,达成统一意见 概念结构...
1009 0
数据管理 DMS :SQLServer 2008的性能优化服务发布
数据库性能诊断和优化是提高数据库性能和稳定性的关键技术之一。快速的发现异常、定位根因并且进行止损,是每个用户的需求。 数据管理DMS 增强了对SQL Server 2008 R2 性能优化服务的支持,希望可以帮助用户更快速的定位问题和解决问题。
2185 0
5723
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
《2021云上架构与运维峰会演讲合集》
立即下载
《零基础CSS入门教程》
立即下载
《零基础HTML入门教程》
立即下载