king71 发表于 2017-7-14 20:52:22

常用 SQL 语句使用的总结

alter table Student      
add 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]
查看完整版本: 常用 SQL 语句使用的总结