澳门新萄京官方网站-www.8455.com-澳门新萄京赌场网址

澳门新萄京官方网站SQLServer数据库增加和删除改

2019-05-25 作者:数据库网络   |   浏览(125)

数码表定义

数据表(或称表)是数据库最根本的组成部分之1,数据库中以表为公司单位存款和储蓄数据,数据库只是三个框架,数据表才是其实质内容。数据库管理工科具中能够展现数据库中的全数数据表,数据表是数据库中二个要命首要的对象,是别的对象的功底。

CHECK约束增多规则

一、CHECK 约束用于限制列中的值的界定。

二、Check约束通过逻辑表明式来推断数据的立竿见影,用来界定输入一列或多列的值的限制,在列中更新数据时,所要输入的从头到尾的经过必须满意Check约束的尺码,不然将不能够准确输入。

3、假若对单个列定义 CHECK 约束,那么该列只允许特定的值。

四、如果对二个表定义 CHECK 约束,那么此约束会在特定的列中对值举办界定。

1、数据库定义

数据库(Database)是依据数据结构来公司、存款和储蓄和保管数据的库房。数据库的操作分为三种方式:一种是一向在数据库管理工科具图形化分界面举行操作;一种是使用数据库脚本进行操作,数据库脚本能够一向在数据库处理工科具中操作,也足以在dos命令窗口中操作。

DEFAULT约束增加规则

1、若在表中定义了私下认可值约束,用户在插入新的数额行时,如若该行未有一点点名数量,那么系统将暗中认可值赋给该列,假使大家不设置默许值,系统默以为NULL。

2、借使“私下认可值”字段中的项替换绑定的暗许值(以不带圆括号的花样展现),则将唤起您化解对暗许值的绑定,并将其替换为新的私下认可值。

3、若要输入文本字符串,请用单引号 (') 将值括起来;不要选拔双引号 ("),因为双引号已保存用于带引号的标记符。

四、若要输入数值暗中认可值,请输入数值并且永不用引号将值括起来。

5、若要输入对象/函数,请输入对象/函数的名号并且不要用引号将名称括起来。

P汉兰达IMA本田CR-VY KEY约束增加规则

壹、在表中常有壹列或多列的咬合,其值能唯一标志表中的每壹行,那样的1列或多列成为表的主键(PrimaryKey)。

二、多个表只可以有二个主键,而且主键约束中的列不能为空值。

叁、唯有主键列技能被当作任何表的外键所创设。

四、一般景色下三个表中只好有二个主键。

创办数据表

主意1:展开数据库管理工具-》登入-》选拔数据库-》选取表-》右键点击,选用新建表-》在右臂视图中输入列名、数据类型、是或不是可空、在列属性中设置须要的质量-》点击保存(或ctrl s)-》保存成功,刷新就可以展现

澳门新萄京官方网站 1

澳门新萄京官方网站 2

措施二:使用T-SQL脚本新建表

 1 --数据库声明
 2 use testss
 3 --建表语法声明
 4 create table test1
 5 (
 6 --字段声明
 7 id int identity(1,1) not null,
 8 name nvarchar(50) null,
 9 sex nvarchar(50) null,
10 age nvarchar(50) null,
11 classid int,
12 primary key clustered(id asc) with(ignore_dup_key=off) on [primary]    --主键索引声明
13 )on [primary]
14 
15 --字段注释声明
16 exec sys.sp_addextendedproperty @name=N'MS_Description', @value=N'id主键' , @level0type=N'SCHEMA',
17 @level0name=N'dbo', @level1type=N'TABLE',@level1name=N'test1', @level2type=N'COLUMN',@level2name=N'id';
18 
19 exec sys.sp_addextendedproperty @name=N'MS_Description', @value=N'姓名' , @level0type=N'SCHEMA',
20 @level0name=N'dbo', @level1type=N'TABLE',@level1name=N'test1', @level2type=N'COLUMN',@level2name=N'name';
21 
22 exec sys.sp_addextendedproperty @name=N'MS_Description', @value=N'性别' , @level0type=N'SCHEMA',
23 @level0name=N'dbo', @level1type=N'TABLE',@level1name=N'test1', @level2type=N'COLUMN',@level2name=N'sex';
24 
25 exec sys.sp_addextendedproperty @name=N'MS_Description', @value=N'年龄' , @level0type=N'SCHEMA',
26 @level0name=N'dbo', @level1type=N'TABLE',@level1name=N'test1', @level2type=N'COLUMN',@level2name=N'age';
27 
28 exec sys.sp_addextendedproperty @name=N'MS_Description', @value=N'班级id' , @level0type=N'SCHEMA',
29 @level0name=N'dbo', @level1type=N'TABLE',@level1name=N'test1', @level2type=N'COLUMN',@level2name=N'classid';
30 
31 go

 示例结果如下:澳门新萄京官方网站 3

行使SSMS数据库管理工具增加CHECK约束

1、连接数据库,采取数据库,选择数据表-》右键点击(或然直接点击约束,右键点击,选取丰硕约束,前边步骤一样)-》选拔设计。

澳门新萄京官方网站 4

2、采取要足够约束的数据列-》右键点击-》选用CHECK约束。

澳门新萄京官方网站 5

三、在CHECK约束弹出框中式点心击增多。

澳门新萄京官方网站 6

四、在CHECK约束弹出框中-》输入CHECK约束表明式-》输入CHECK约束名-》输入CHECK约束描述-》别的能够选用默许。

澳门新萄京官方网站 7

伍、点击关闭-》点击保存开关(或许ctrl s)-》刷新表查看结果。

澳门新萄京官方网站 8

二、数据库创设

办法一:数据库图形化管理工具创造数据库步骤:右键点击数据库-》点击新建数据库-》输入数据库名称,可自定义数据库全数者(设置什么样人能够动用数据库)、逻辑名称、开首大小(数据库早先化大小)、自增进大小(数据库新扩充加少的时候以每趟多大存款和储蓄量增加)、路径(数据库数据文件路线,关系到以往的数据库备份,迁移,还原等操作)、文件名(数据库的文件名称)、日志等品质,左上角的挑选和平常能够选拔系统暗中认可的-》点击分明就可以创设数据库

澳门新萄京官方网站 9

澳门新萄京官方网站 10

措施贰:数据库脚本创制数据库步骤:编写脚本-》在数据库管理工科具中实行脚本-》刷新数据库就可以展现;

 

 1 --创建数据库
 2 create database testss
 3 on 
 4 (
 5     name='testss',
 6     filename='D:SqlTestblogtestss.mdf',
 7     size=10240kb,
 8     maxsize=102400kb,
 9     filegrowth=1024kb
10 )
11 log on
12 (
13     name='testlog',
14     filename='D:SqlTestblogtestlog.ldf',
15     size=10240kb,
16     maxsize=102400kb,
17     filegrowth=1024kb
18 )
19 go

 

 

创办理并了结果示举个例子下:

澳门新萄京官方网站 11

接纳SSMS数据库处理工科具增添DEFAULT约束

1、连接数据库,选取数据表-》右键点击-》选取设计。

澳门新萄京官方网站 12

二、在表设计窗口中-》选取数据列-》在列属性窗口中找到默许值或绑定-》输入默许值(注意默许值的数据类型和输入格式)。

澳门新萄京官方网站 13

三、点击保存开关(恐怕ctrl s)-》刷新表-》再次展开表查看结果。

澳门新萄京官方网站 14

动用SSMS数据库管理工科具增加主键约束

删去数据表

艺术1:张开数据库管理工科具-》登陆-》选择数据库-》选拔表-》右键点击,选择删除-》点击弹出框中的分明删除-》刷新数据库

澳门新萄京官方网站 15澳门新萄京官方网站 16

措施二:使用T-SQL脚本删除:drop table test二;

澳门新萄京官方网站 17

应用T-SQL脚本加多CHECK约束

3、数据库删除

措施一:直接在数据库管理工科具中右键-》选取删除

澳门新萄京官方网站 18

 

方法贰:在数据库管理工科具中多少脚本:drop database 数据库名

选拔T-SQL脚本加多DEFAULT约束

行使SSMS数据库管理工科具加多1列作为三个主键约束

一、连接数据库,选取数据表-》右键点击,采纳设计。

澳门新萄京官方网站 19

贰、在新窗口中,选取一行,右键点击-》选取设置主键-》点击保存按键(只怕ctrl s)。

澳门新萄京官方网站 20

三、刷新表查看示例结果。

澳门新萄京官方网站 21

 

修改数据表

措施一:张开数据库管理工科具-》登入-》选拔数据库-》选拔表-》右键点击,采取重命名-》重新输入表名-》按enter键明确-》刷新可查看新表名

 澳门新萄京官方网站 22

主意二:使用T-SQL脚本修改表名:exec sp_rename 'test1','test2';

澳门新萄京官方网站 23

当表结构存在时

增加CHECK约束时首先校验约束是或不是已存在,借使存在应该是先删除再增多,若是不设有则直接助长。

语法:

-- 增添贰个暗许约束
use 数据库名;
go

if exists(select * from sysobjects where name=约束名)
alter table 表名 drop constraint 约束名;
go

alter table 表名 add constraint 约束名 check(约束规则),constraint 约束名 check(约束规则);
go

示例:

-- 增添叁个默许约束
use testss;
go

if exists(select * from sysobjects where name='check1')
alter table test1 drop constraint check1;
go

alter table test1 add constraint check1 check(height>=170 and height<=175);
go

 澳门新萄京官方网站 24

澳门新萄京官方网站 25

四、数据库修改

艺术一:选中数据库-》右键-》接纳重命名-》输入数据库新名称

澳门新萄京官方网站 26

主意二:在数据库管理工科具中输入脚本修改:exec sp_renamedb 'testss','test1'或者alter database test1 modify name=test2 

澳门新萄京官方网站 27

当表结构已存在时

先是决断表中是还是不是存在暗中认可约束,假如存在则先删除默许约束再增添,假设不设有则直接助长。

语法:

use 数据库
go
--判定默许约束是不是留存,若是存在则先删除,若是不存在则直接助长
if exists(select * from sysobjects where name=约束名)
alter table 表名 drop constraint 约束名;
go
--给钦命列加多暗许约束
alter table 表名 add constraint 约束名 default(约束值) for 列名;
go

示例:

use [testss]
go
--决断暗中认可约束是还是不是留存,假使存在则先删除,假若不存在则直接抬高
if exists(select * from sysobjects where name='defalut_height')
alter table [testss].[dbo].[test1] drop constraint defalut_height;
go
--给内定列增加暗许约束
alter table [testss].[dbo].[test1] add constraint defalut_height default(160) for height;
go

澳门新萄京官方网站 28

澳门新萄京官方网站 29

使用SSMS数据库管理工科具添增多列作为三个主键约束

一、连接数据库,接纳数据表-》右键点击-》选用设计。

澳门新萄京官方网站 30

二、在新窗口中-》按下ctrl键,选取多行-》右键点击-》选用安装主键-》点击保存(或许ctrl s)。

澳门新萄京官方网站 31

三、刷新表查看示例结果。

澳门新萄京官方网站 32

查看数据表

--查询数据库下有所的表
--xtype='U'查询用户表
select name from sysobjects where xtype='U'
-- xtype='S'查询系统表
select name from sysobjects where xtype='S'

--查看test一表的有所音信
exec sp_help test1;

--查询test一表中具备的列
select * from syscolumns where id=Object_Id('test1')

--查看test一表中有所列数据
select * from test1;

当表结构不存在时

要是表结构不存在,能够平昔抬高约束,能够同时丰盛多个也许多少个约束。

语法:

--如若表结构不设有的时候加多check约束
use 数据库名;
go
--如若已存在表则删除
if exists(select * from sysobjects where name=表名 and xtype='U')
drop table 表名;
go
--创建表
create table 表名
(
--字段注明
列名 int identity(1,1) not null,
列名 nvarchar(50) null,
列名 nvarchar(50) null constraint 约束名 check(约束规则),
澳门新萄京官方网站,列名 nvarchar(50) null,
列名 int,
列名 int constraint 约束名 check(约束规则)
primary key clustered(列名 asc) with(ignore_dup_key=off) on [primary], --主键索引表明
)on [primary]

--字段注释证明
exec sys.sp_addextendedproperty @name=N'MS_Description', @value=N'列描述' , @level0type=N'SCHEMA',
@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'表名', @level2type=N'COLUMN',@level2name=N'列名';

exec sys.sp_addextendedproperty @name=N'MS_Description', @value=N'列描述' , @level0type=N'SCHEMA',
@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'表名', @level2type=N'COLUMN',@level2name=N'列名';

exec sys.sp_addextendedproperty @name=N'MS_Description', @value=N'列描述' , @level0type=N'SCHEMA',
@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'表名', @level2type=N'COLUMN',@level2name=N'列名';

exec sys.sp_addextendedproperty @name=N'MS_Description', @value=N'列描述' , @level0type=N'SCHEMA',
@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'表名', @level2type=N'COLUMN',@level2name=N'列名';

exec sys.sp_addextendedproperty @name=N'MS_Description', @value=N'列描述' , @level0type=N'SCHEMA',
@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'表名', @level2type=N'COLUMN',@level2name=N'列名';

go

示例:

--假设表结构不存在时增添check约束
use testss;
go
--假若已存在表则删除
if exists(select * from sysobjects where name='test1' and xtype='U')
drop table test1;
go
--创建表
create table test1
(
--字段注解
id int identity(1,1) not null,
name nvarchar(50) null,
sex nvarchar(50) null constraint check1 check(sex='男' or sex='女'),
age nvarchar(50) null,
classid int,
height int constraint check2 check(height>=110 and height<=120)
primary key clustered(id asc) with(ignore_dup_key=off) on [primary], --主键索引注明
)on [primary]

--字段注释注明
exec sys.sp_addextendedproperty @name=N'MS_Description', @value=N'id主键' , @level0type=N'SCHEMA',
@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'test1', @level2type=N'COLUMN',@level2name=N'id';

exec sys.sp_addextendedproperty @name=N'MS_Description', @value=N'姓名' , @level0type=N'SCHEMA',
@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'test1', @level2type=N'COLUMN',@level2name=N'name';

exec sys.sp_addextendedproperty @name=N'MS_Description', @value=N'性别' , @level0type=N'SCHEMA',
@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'test1', @level2type=N'COLUMN',@level2name=N'sex';

exec sys.sp_addextendedproperty @name=N'MS_Description', @value=N'年龄' , @level0type=N'SCHEMA',
@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'test1', @level2type=N'COLUMN',@level2name=N'age';

exec sys.sp_addextendedproperty @name=N'MS_Description', @value=N'班级id' , @level0type=N'SCHEMA',
@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'test1', @level2type=N'COLUMN',@level2name=N'classid';

go

 澳门新萄京官方网站 33

澳门新萄京官方网站 34

澳门新萄京官方网站 35

伍、查数据库查看

方式1:在数据库管理工科具中选中数据库-》右键属性-》查看数据库相关安顿消息

澳门新萄京官方网站 36

澳门新萄京官方网站 37

措施二:在数据库管理工科具中输入数据库脚本查看,一下罗列两种常用的数据库查看信息

--使用目录视图查看数据库消息
--使用sys.database_files查看有关数据库文件的音信
select * from sys.database_files;
--使用sys.filegroups查看有关数据库组的音讯
select * from sys.filegroups;
--使用sys.master_files 查看数据库文件的主干音信和情景音信
select * from sys.master_files;
--使用sys.databases 数据库和文件目录视图查看有关数据库的基本新闻
select * from sys.databases where name='testss';

澳门新萄京官方网站 38

 

--使用函数查看数据状态
use testss
select databasepropertyex('test二','Status') as 'test数据库状态'

澳门新萄京官方网站 39

制造表时丰裕暗中同意约束

先是判定表是或不是选在,要是存在则先删除表再增加,假如不设有则平昔抬高。

语法:

--创造新表时增添默许约束
--数据库注解
use 数据库名
go
--要是表已存在则先删除表再成立,假诺表不设有则直接创立
if exists(select * from sysobjects where name=表名 and type ='U')
drop table 表名;
go
--建表语法注解
create table 表名
(
--字段申明
列名 列类型 identity(1,1) not null,
列名 列类型) null,
列名 列类型 null,
列名 列类型 null,
列名 列类型,
列名 列类型 constraint 约束名 default 默认值,
primary key clustered(列名 asc) with(ignore_dup_key=off) on [primary] --主键索引注解
)on [primary]

--字段注释注明
exec sys.sp_addextendedproperty @name=N'MS_Description', @value=N'列说明' , @level0type=N'SCHEMA',
@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'表名', @level2type=N'COLUMN',@level2name=N'列名';

exec sys.sp_addextendedproperty @name=N'MS_Description', @value=N'列说明' , @level0type=N'SCHEMA',
@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'表名', @level2type=N'COLUMN',@level2name=N'列名';

exec sys.sp_addextendedproperty @name=N'MS_Description', @value=N'列说明' , @level0type=N'SCHEMA',
@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'表名', @level2type=N'COLUMN',@level2name=N'列名';

exec sys.sp_addextendedproperty @name=N'MS_Description', @value=N'列说明' , @level0type=N'SCHEMA',
@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'表名', @level2type=N'COLUMN',@level2name=N'列名';

exec sys.sp_addextendedproperty @name=N'MS_Description', @value=N'列说明' , @level0type=N'SCHEMA',
@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'表名', @level2type=N'COLUMN',@level2name=N'列名';

go

示例:

--创造新表时增添暗许约束
--数据库表明
use testss
go
--假诺表已存在则先删除表再次创下设,假使表不设有则一向开立
if exists(select * from sysobjects where name='test1' and type ='U')
drop table test1;
go
--建表语法注脚
create table test1
(
--字段注脚
id int identity(1,1) not null,
name nvarchar(50) null,
sex nvarchar(50) null,
age nvarchar(50) null,
classid int,
height int constraint default_he default 166,
primary key clustered(id asc) with(ignore_dup_key=off) on [primary] --主键索引证明
)on [primary]

--字段注释注解
exec sys.sp_addextendedproperty @name=N'MS_Description', @value=N'id主键' , @level0type=N'SCHEMA',
@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'test1', @level2type=N'COLUMN',@level2name=N'id';

exec sys.sp_addextendedproperty @name=N'MS_Description', @value=N'姓名' , @level0type=N'SCHEMA',
@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'test1', @level2type=N'COLUMN',@level2name=N'name';

exec sys.sp_addextendedproperty @name=N'MS_Description', @value=N'性别' , @level0type=N'SCHEMA',
@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'test1', @level2type=N'COLUMN',@level2name=N'sex';

exec sys.sp_addextendedproperty @name=N'MS_Description', @value=N'年龄' , @level0type=N'SCHEMA',
@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'test1', @level2type=N'COLUMN',@level2name=N'age';

exec sys.sp_addextendedproperty @name=N'MS_Description', @value=N'班级id' , @level0type=N'SCHEMA',
@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'test1', @level2type=N'COLUMN',@level2name=N'classid';

go

澳门新萄京官方网站 40

澳门新萄京官方网站 41

选择T-SQL脚本增添主键约束

CHECK约束优缺点

优点:

一、保险列数据标准和限制,能够约束数据完整性

二、有Check约束的列能够提要求查询优化器新闻之所以晋级品质

缺点:

一、插入或然修改时数据不合乎约束规则,不可能修改成功。

陆、数据库优缺点

可取:易用性、适合布满式组织的可伸缩性、用于决策协助的数据仓库作用、与广大别的服务器软件紧凑关联的集成性、杰出的性能和价格的比例等。

缺点:一开放性。只可以运维在微软的windows平台,未有丝毫的开放性可言。

      2可伸缩性,并行性。并行奉行和水保模型并不成熟,很难管理日益扩大的用户数和数据卷,伸缩性有限。
      叁品质牢固。SQLServer当用户连接多时品质会变的很差,并且远远不够牢固。
      四使用风险。SQLServer完全重写的代码,经历了许久的测试,不断延迟,繁多成效需时间来验证。并不要命男才女貌开始的一段时期产品。使用要求冒一定危机。
      5客户端接济及使用情势。只扶助C/S方式。

DEFAULT约束优缺点

优点:

一、使用暗中认可值能够减少代码量,新添多少时得以不用写新扩大私下认可值列,推行新添操作时时私下认可填充。

二、较有利于开始展览计算和分析,以及福利程序逻辑操作。

缺点:

1、使用不为NULL的暗中认可值,占用了更加的多的积累空间。

 

选拔T-SQL脚本增添一列作为二个主键约束

当表中约束存在时,无法一贯抬高主键约束,因为一张表只允许存在1个主键约束,假设需求丰硕主键约束须求先删除已存在的主键约束再增多主键约束。当表中不存在主键约束时,可平昔抬高主键约束。

语法:

if exists(select * from sysobjects where name=约束名)
alter table 数据库名.[dbo].表名 drop constraint 约束名;
alter table 数据库名.[dbo].表名 add constraint 约束名 primary key(列名 [asc|desc]);

示例:

--若是封锁存在则删除约束,假设封锁不存在则不删除
if exists(select * from sysobjects where name='idcon2')
alter table [testss].[dbo].[test1] drop constraint idcon2;
--增添封锁
alter table [testss].[dbo].[test1] add constraint idcon2 primary key(id asc);

澳门新萄京官方网站 42

澳门新萄京官方网站 43

选用T-SQL脚本添增添列作为3个主键约束

当表中约束存在时,不可能向来抬高主键约束,因为一张表只允许存在多个主键约束,假诺须求加多主键约束要求先删除已存在的主键约束再增加主键约束。当表中不存在主键约束时,可径直抬高主键约束。

语法:

--加多多列主键约束

if exists(select * from sysobjects where name=约束名)
alter table 数据库名.[dbo].表名 drop constraint 约束名;
alter table 数据库名.[dbo].表名 add constraint 约束名 primary key(列名 [asc|desc],列名 [asc|desc],......);

示例:

--添增加列主键约束
if exists(select * from sysobjects where name='idcon2')
alter table [testss].[dbo].[test1] drop constraint idcon2;
--增加封锁
alter table [testss].[澳门新萄京官方网站SQLServer数据库增加和删除改查,SQLServer数据表用法。dbo].[test1] add constraint idcon2 primary key(id asc,name desc);

澳门新萄京官方网站 44

PRIMACR-VY KEY约束优缺点

优点:

1、简单、效率高。 

二、保障数据完整性。

三、不会有空值。

四、不允许存在重新值。

缺点:

一、主键自增一般选取int型,有数量条数的限制。

二、在数据库进行数量统一时会相比较麻烦。 

 

本文由澳门新萄京官方网站发布于数据库网络,转载请注明出处:澳门新萄京官方网站SQLServer数据库增加和删除改

关键词: