使用SSMS数据库管理工科具修改DEFAULT约束

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

图片 1

2、在表设计器窗口-》选中要修改的数量列-》在列属性中找到暗中同意值绑定-》举办修改。

图片 2

3、点击保存(只怕ctrl+s)-》关闭表设计器-》刷新表-》重新张开表设计器查看。

图片 3

DEFAULT约束加多准则

1、若在表中定义了暗中同意值约束,用户在插入新的多寡行时,如若该行未有一点点名数量,那么系统将暗中同意值赋给该列,要是大家不设置暗中同意值,系统默认为NULL。

2、假若“暗许值”字段中的项替换绑定的默许值(以不带圆括号的款式呈现),则将唤起您拨冗对暗中认可值的绑定,并将其替换为新的暗中认可值。

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

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

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

修改数据列

在付出和生产进程中,列名的拼写错误或许列名的改换是内需操作数据表的,大相当多景况下都以不供给修改的.

以下三种状态下大家并不可能一贯退换数据列:

1、用于索引的列。 
2、用于 CHECK、FOREIGN KEY、UNIQUE 或 PENVISIONIMA智跑Y KEY 约束的列。 
3、与私下认可值(由 DEFAULT 关键字定义)相关联的列,或绑定到暗中认可对象的列。 
4、绑定到法规的列。 

 

PLacrosseIMAQashqaiY KEY约束加多准则

1、在表中常有一列或多列的组成,其值能独一标记表中的每一行,那样的一列或多列成为表的主键(PrimaryKey)。

2、贰个表只可以有二个主键,何况主键约束中的列无法为空值。

3、独有主键列本事被视作别的表的外键所开创。

4、一般情形下二个表中只好有贰个主键。

行使T-SQL脚本修改DEFAULT约束

DEFAULT约束修改法则必须首先删除现存的DEFAULT约束,然后利用新定义再一次创制,手艺选择Transact-SQL修改DEFAULT约束。

语法:

–使用数据库
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=’default1′)
alter table test1 drop constraint
default1;
go
–加多暗许值约束
alter table test1 add constraint default2
default 18 for age;
go

 图片 4

图片 5

应用SSMS数据库管理工科具加多DEFAULT约束

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

图片 6

2、在表设计窗口中-》选用数据列-》在列属性窗口中找到暗中同意值或绑定-》输入暗中认可值(注意暗中认可值的数据类型和输入格式)。

图片 7

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

图片 8

使用SSMS数据库管理工科具修改列

1、连接数据库,展开要修改的数据库,选用数据表-》右键点击-》选取设计。

图片 9

2、在新开发的窗口视图中-》点击要修改的行-》能够修改列名、列类型、是不是可空、属性等-》修改完毕点击保存开关(或许ctrl+s)。

图片 10

1、用SQL创立文件夹

选取SSMS数据库管理工科具增多主键约束

总结

1、每一种字段只可以有贰个私下认可约束。
2、借使默许约束设置的值大于字段所允许的长度,则截取到字段允许长度。
3、没办法加入到含有IDENTITY属性大概TIMESTAMP的字段上。
4、如若字段的数据类型为用户自定义类型,并且已有暗许值绑定在此数据类型上,则分歧意再度使用默许值。

 

应用T-SQL脚本增多DEFAULT约束

接纳T-SQL脚本修改列

图片 11图片 12用SQL成立文件夹

选取SSMS数据库管理工科具增加一列作为二个主键约束

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

图片 13

2、在新窗口中,选拔一行,右键点击-》采纳设置主键-》点击保存开关(或许ctrl+s)。

图片 14

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

图片 15

 

当表结构已存在时

第一判定表中是或不是留存暗中同意约束,假使存在则先删除暗许约束再增多,要是不真实则一向抬高。

语法:

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

图片 16

图片 17

修改列名

语法:exec sp_rename 
表明.旧列名,新列名; 

示例:exec sp_rename
‘[test1].height6′,’height7’; 

图片 18

图片 19

— 1、展现高端选项
sp_configure ‘show advanced options’,1;
reconfigure; –退换当前布局
go

行使SSMS数据库管理工科具添扩展列作为贰个主键约束

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

图片 20

2、在新窗口中-》按下ctrl键,选用多行-》右键点击-》选取设置主键-》点击保存(大概ctrl+s)。

图片 21

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

图片 22

创造表时加上默许约束

率先判定表是还是不是选在,若是存在则先删除表再增加,假若荒诞不经则直接助长。

语法:

–创设新表时增多私下认可约束
–数据库表明
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

图片 23

图片 24

修改列数据类型

语法:alter table 数据库名.dbo.表名 alter
column 列名 类型 [约束];  

示例:alter table [testss].dbo.[test1]
alter column height7 int null;  

图片 25

图片 26

— 2、启用 xp_cmdshell:
sp_configure ‘xp_cmdshell’,1; — 1代表“用户ID”
reconfigure
go

应用T-SQL脚本增加主键约束

DEFAULT约束优缺点

优点:

1、使用暗中认可值能够收缩代码量,新增加多少时方可不用写新添暗许值列,试行新扩张操作时时暗中认可填充。

2、较有利开始展览总结和剖判,以及方便程序逻辑操作。

缺点:

1、使用不为NULL的暗中同意值,占用了越来越多的仓库储存空间。

 

修改列是还是不是可空

语法:alter table 数据库名.dbo.表名 alter
column 列名 类型 约束;  

示例:alter table [testss].dbo.[test1]
alter column height7 int not null;

图片 27

图片 28

— 附:用SQL创立文件夹(手动):
       –> SQL Server 外围应用配置器
       –> 作用的外部应用配置器 
       –> 启用xp_cmdshell

行使T-SQL脚本加多一列作为二个主键约束

当表中约束存在时,不能直接助长主键约束,因为一张表只允许存在二个主键约束,假使必要加上主键约束必要先删除已存在的主键约束再加多主键约束。当表中官样文章主键约束时,可直接助长主键约束。

语法:

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);

图片 29

图片 30

修改列暗中认可值

假定默许值不设有

语法:alter table 数据库名.dbo.表名 add
constraint 约束名 default 默许值 for 列名;

示例:alter table [testss].dbo.[test1]
add constraint df_h default 1 for height7;

图片 31

图片 32

— 然后您就能够使用xp_cmdshell了。

利用T-SQL脚本增多多列作为一个主键约束

当表中约束存在时,不得以一贯抬高主键约束,因为一张表只允许存在贰个主键约束,假诺急需丰富主键约束需求先删除已存在的主键约束再增多主键约束。当表中空头支票主键约束时,可一向抬高主键约束。

语法:

–添扩张列主键约束

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].[dbo].[test1]
add constraint idcon2 primary key(id asc,name desc);

图片 33

假诺暗中认可值存在

语法:

–首先步判别默许值否存在,假设存在就删除,假若不设有则不删除
if exists (select * from
sys.check_constraints where object_id = object_id(默许值约束名) and
parent_object_id = object_id(表名))
alter table 表名 drop constraint
暗中认可值约束名

–次之步增添暗中认可值

alter table 表名 add constraint  约束名
default 默认值 for 列名;

示例:

–第一步判别约束是还是不是留存,要是存在就删除,要是不设有则不删除
if exists (select * from
sys.check_constraints where object_id = object_id(‘df_h’) AND
parent_object_id = object_id(‘[testss].dbo.[test1]’))
alter table [testss].dbo.[test1] drop
constraint df_h

–次之步增加默许值

alter table [testss].dbo.[test1] add
constraint df_h default 2 for height7;

图片 34

— 在C盘建立myDatabase文件夹
xp_cmdshell ‘mkdir c:\myDatabase’; 
go — 或 xp_cmdshell ‘md c:\myDatabase’ 

P福特ExplorerIMAENVISIONY KEY约束优劣点

优点:

1、简单、效率高。 

2、保障数据完整性。

3、不会有空值。

4、不允许存在重复值。

缺点:

1、主键自增一般采取int型,有数量条数的界定。

2、在数据库进行数量统偶尔会比较劳累。 

 

总结

在付出还是生产数据库中,数据列一经建好,不要随便更换,随便更改也许会唤起数据库的级联操作战败和代码错误。

 

 

 2、用SQL创设数据库

图片 35图片 36用SQL制造数据库

use master
go — 批管理的竣事

–在[master]中查询[myDBName]是不是留存
if exists(select * from sysdatabases where name=’myDBName’)
   drop database myDBName

create database myDBName –创制数据库
on primary
(
  name=’myDBName’,
  filename=’C:\myDatabase\myDBName.mdf’,
  size=3mb,
  maxsize=100mb, — unlimited:无界定的
  filegrowth=2mb 
)
, — 注意:逗号不能够丢!
(
  name=’myDBName_1′,
  filename=’C:\myDatabase\myDBName_1.ndf’,
  size=3mb,
  maxsize=unlimited,
  filegrowth= 10%
)
log on
(
  NAME = N’myDBName_log’, 
  FILENAME = N’C:\myDatabase\myDBName_log.ldf’ , 
  SIZE = 1024kb, 
  MAXSIZE = 1gb, 
  FILEGROWTH = 1mb
)

collate Chinese_PRC_CI_AS –定义排序准则
go

— 删除数据库
— drop database myDBName;

 

 

相关文章