设为首页 收藏本站
查看: 1256|回复: 0

[经验分享] 常用 SQL 语句使用的总结

[复制链接]

尚未签到

发表于 2017-7-14 20:52:22 | 显示全部楼层 |阅读模式
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  
from  sys.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'
DSC0000.png

  sql server 按照 in 的值的顺序进行排序:




select * from Student
where S_StuNo in ('014','003','009')
order by CHARINDEX(','+S_StuNo+',',',014,003,009,')
DSC0001.png

  设置显示或不显示受影响的行数:




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
DSC0002.png

DSC0003.png

  查询、删除指定表及指定列的默认值约束,以及删除字段(即列)。




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、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-393960-1-1.html 上篇帖子: 利用LINQ to SQL 增删改查本地数据库 下篇帖子: Sql Server2008-读写分离
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表