SQLServer修改数据列

SQLServer修改数据列

应用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

 图片 1

图片 2

当表结构已存在时

首先判断表中是不是存在暗中同意约束,假设存在则先删除暗许约束再添加,假使不存在则直接助长。

语法:

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

图片 3

图片 4

总结

在支付依旧生产数据库中,数据列一经济建设好,不要私下改变,随意更改可能会引起数据库的级联操作退步和代码错误。

 

use myDBName
go

总结

① 、每一个字段只可以有3个暗中认可约束。
贰 、倘使私下认可约束设置的值大于字段所允许的长度,则截取到字段允许长度。
叁 、不能够参预到含有IDENTITY属性可能TIMESTAMP的字段上。
肆 、即使字段的数据类型为用户自定义类型,而且已有默许值绑定在此数据类型上,则区别意又一次行使私下认可值。

 

运用T-SQL脚本添加DEFAULT约束

修改列数据类型

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

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

图片 5

图片 6

— 删除数据库
— drop database myDBName;

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

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

图片 7

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

图片 8

③ 、点击保存(大概ctrl+s)-》关闭表设计器-》刷新表-》重新打开表设计器查看。

图片 9

始建表时加上暗中同意约束

首先判断表是还是不是选在,倘若存在则先删除表再添加,借使不设有则直接助长。

语法:

–成立新表时添加默许约束
–数据库证明
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

图片 10

图片 11

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

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

图片 12

② 、在新开拓的窗口视图中-》点击要修改的行-》可以修改列名、列类型、是还是不是可空、属性等-》修改完毕点击保存按钮(只怕ctrl+s)。

图片 13

  — 方法二(删除原主键) 
  if exists(select * from sysobjects where xtype=’PK’ 
            and parent_obj=object_id(N’uinfor’) )  
  begin  
  –使用动态语句能够保险不管主键名是怎么定义都足以健康删除  
    declare @s nvarchar(4000)  
     select @s=N’alter table uinfor drop constraint’+quotename(name)  
            from sysobjects 
            where xtype=’PK’ and parent_obj=object_id(N’uinfor’)  
    exec(@s)  
  end  

行使SSMS数据库管理工科具添加DEFAULT约束

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

图片 14

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

图片 15

③ 、点击保存按钮(或许ctrl+s)-》刷新表-》再度打开表查看结果。

图片 16

选拔T-SQL脚本修改列

–注意:该权限一般由sa用户授予。
–常用的权力:insert、delete、update、select。
grant insert,delete,update,select on 表名 to 数据库用户;

DEFAULT约束添加规则

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

② 、借使“暗中同意值”字段中的项替换绑定的默许值(以不带圆括号的样式显得),则将唤起您清除对暗许值的绑定,并将其替换为新的暗中同意值。

三 、若要输入文本字符串,请用单引号 (‘)
将值括起来;不要选拔双引号
(“),因为双引号已封存用于带引号的标识符。

肆 、若要输入数值暗许值,请输入数值并且毫不用引号将值括起来。

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

修改列名

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

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

图片 17

图片 18

图片 19图片 20用SQL创设数据库用户

DEFAULT约束优缺点

优点:

一 、使用私下认可值能够减掉代码量,新增多少时可以不用写新增暗许值列,执行新增操作时时暗中认可填充。

② 、较便宜开始展览总括和剖析,以及便于程序逻辑操作。

缺点:

一 、使用不为NULL的默许值,占用了越来越多的存款和储蓄空间。

 

若果私下认可值存在

语法:

–先是步判断暗中同意值否存在,要是存在就删除,假诺不存在则不删除
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;

图片 21

–3. 添加字段  
  alter table uinfor
  add u_note varchar(1) NULL;  

修改列是或不是可空

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

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

图片 22

图片 23

use master
go — 批处理的收尾

修改数据列

在开发和生育进程中,列名的拼写错误只怕列名的变动是内需操作数据表的,超过一半情状下都以不供给修改的.

以下三种状态下大家并不可能直接修改数据列:

一 、用于索引的列。 
二 、用于 CHECK、FOREIGN KEY、UNIQUE 或 PEnclaveIMAEscortY KEY 约束的列。 
三 、与暗中认可值(由 DEFAULT 关键字定义)相关联的列,或绑定到暗中同意对象的列。 
四 、绑定到规则的列。 

措施二:添加 SQL Server 身份验证

修改列私下认可值

比方暗许值不存在

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

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

图片 24

图片 25

–============== 添加 Windows 身份验证 ==============

–示例二
exec sp_grantDBaccess ‘xugang’;
–当省略‘数据库用户’时,即:’登录账户’与’数据库用户’相同。

/* 注意:
dbo用户是叁个相比特殊的数据库用户,不能够删除,且一向出以后数据库中。
貌似的话,某些用户创设的数据库,一般意况下,拥有者即dbo用户。
*/

肆 、用SQL创制登录账户

图片 26图片 27用SQL创设文件夹

 

 

–移除’数据库用户’的权力 (设置为null)
revoke insert on stuInfo from xg;
–revoke all on stuInfo from xg;

/* sp_grantlogin:内置的系统存款和储蓄进程 */
exec sp_grantlogin ‘Windows域名\域账户’

–1.剔除原主键
  — 方法一(删除原主键) 
  alter table uinfor    
  drop constraint PK_uinfor; 

— 删除外键约束
alter table stuMarks
drop constraint FK_stuNo;

— 方式二:存款和储蓄进程
exec sp_revokedbaccess ‘xugang’;          –SQL用户
exec sp_revokedbaccess ‘NEWER-XG\xugang’; –Windows用户
–后续版本的 Microsoft SQL Server 将去除该成效。

 二 、用SQL创立数据库

create user aa for login [xugang];
go

— 添加外键约束:FK_字段名
alter table stu马科斯 –子表上树立
add constraint FK_stuNo
    foreign key(stuNo) references stuInfo(stuNo);

发表评论

电子邮件地址不会被公开。 必填项已用*标注

网站地图xml地图