常用 SQL 语句使用的总结
alter table Studentadd fee
int
not null
default 15
alter table Student
alter column S_Sex
varchar(10) null
with t as (select * from Student)
select * from t
alter table Student
add C_S_Id int null
alter table Student
add constraint C_S_Id
foreign key (C_S_Id)
references Course(C_Id)
go
select name
fromsys.foreign_key_columns f
inner join sys.objects o on f.constraint_object_id=o.object_id
where f.parent_object_id=object_id('Student')
alter table Course drop constraint FK__Course__Stu_Id__15502E78
sp_helpdb Test
sp_helpdb
sp_help Course
sp_help
ALTER DATABASE Test
SET COMPATIBILITY_LEVEL = 80||90||100
GO
SET IDENTITY_INSERT Student on
go
SET IDENTITY_INSERT Student off
go
SET NOCOUNT ON
SET QUOTED_IDENTIFIER ON
SET ANSI_NULLS ON
ALTER TABLE Student
ADD CONSTRAINT UQ_CourseID_Primary_Key
UNIQUE (C_Id)
ALTER TABLE Student
ADD CONSTRAINT DF_S_Name_Default
DEFAULT('233') FOR S_Name
ALTER TABLE Student
ADD CONSTRAINT FK_C_Id_Foreign_Key
FOREIGN KEY (C_Id)
REFERENCES Course(C_Id)
ON UPDATE CASCADE
ON DELETE CASCADE
补充一个添加和删除主键约束和查询指定表的主外键约束名的 sql 语句:
alter table Student
add constraint S_C_Id
primary key (S_Id)
select a.Name as 表名,b.Xtype as 键类型,b.Name as 键名
from sysobjects a,sysobjects b
where a.ID=b.parent_obj and a.name='Student'
and b.Xtype in('F','PK')
alter table Student
drop constraint PK__Student__A3DFF08D170CE4CD
使用 sql 系统存储过程(sp_helpconstraint)根据指定表的表名查询表中的约束。
为指定表添加主键约束,但显式设置为非聚集索引。
exec sp_helpconstraint UserInfo
alter table UserInfo drop constraint PK__UserInfo__5A2040BBA6D6767A
alter table UserInfo add constraint PK__UserInfo__5A2040BBA6D6767A primary key nonclustered (U_Id)
使用 sql 系统存储过程(sp_rename)修改指定表的表名或指定表的字段名。
exec sp_rename 'UserInfo.RoleID','P_Id'
exec sp_rename 'UserInfo_Id','UserInfo'
注意: 更改对象名的任一部分都可能会破坏脚本和存储过程。
使用 sql 系统存储过程(sp_helptext)获取自定义存储过程、视图、函数等创建的 T-SQL 文本(不可以用于表)。
EXEC sp_helptext 'SctStu'
EXEC sp_helptext 'V_DEMO_Ceshi'
EXEC sp_helptext 'Split'
sql server 按照 in 的值的顺序进行排序:
select * from Student
where S_StuNo in ('014','003','009')
order by CHARINDEX(','+S_StuNo+',',',014,003,009,')
设置显示或不显示受影响的行数:
set nocount on
set nocount off
设置等待执行时间:
select * from Student
waitfor delay '0:0:3'
select * from Course
使用 RAISERROR 自定义抛出异常:
RAISERROR(233333,16,3)
参数:
MessageId:
异常的唯一标识,且这个值会被赋值给 SQL Server 的系统变量 @@Error。自定义异常的 MessageId 建议使用 50000 以后的,因为 50000 以内的会被系统异常占用。
Severity:
异常的级别。任何用户都可以指定 0 至 18 的级别。小于 0 的级别被解释为 0,大于 25 的级别被解释为 25。
19 到 25 级别的错误,只能由 sysadmin 角色的成员用 WITH LOG 选项指定。19 到 25 级别的错误,将记录到错误日志和应用程序日志。
20 到 25 级别的错误,被认为是致命的;遇到致命的级别错误,客户端的连接将在收到消息后终止。C# 中的 catch 块中可以俘获 错误级别 11 到 19 级别的异常。
0 至 10 之间的级别不会被 catch 捕获,而 20 到 25 级别的异常,被认为是致命的,会被断开数据库连接。所以 C# cath 块可以接受到这种异常,但异常的内容不是真正的异常内容,可能是类似这样的内容:“在从服务器接收结果时发生传输级错误”。
State:
如果输入负值或大于255 的值会生成错误,产生错误则会中断数据库的连接。
使用 for xml path 把查询的数据转换为 XML 格式。
select *
from Student
where S_Id='7'
for xml path
查询、删除指定表及指定列的默认值约束,以及删除字段(即列)。
SELECT *
FROM sys.default_constraints a
LEFT JOIN sys.sysconstraints b ON a.object_id = b.constid AND a.parent_object_id=b.id
LEFT JOIN sys.columns c ON a.object_id = c.default_object_id
WHERE a.parent_object_id = OBJECT_ID('Student')
AND c.NAME='Flag'
ALTER TABLE Student DROP constraint DF__Stu__Flag__707E9C7C
ALTER TABLE Student DROP COLUMN Flag
页:
[1]