1. 存储过程

CREATE PROCEDURE [dbo].[bbs_move_createtopic]
@fid smallint,
@iconid smallint,
@curtid INT OUTPUT
AS
BEGIN
INSERT INTO [topics] ......
SET @topicid=SCOPE_IDENTITY()
END
declare @curtid int
exec [createtopic] @fid=@new_fid,@iconid=0,
@curtid=@curr_topicid OUTPUT

2. 游标

    DECLARE
@name NVARCHAR(100),
@id DECIMAL,
@idcard NVARCHAR(100)=NULL --声明游标
DECLARE cur_correctIdCard CURSOR
FOR
SELECT
ID, NAME, [USER_ID]
FROM dbo.old_bbstitle
WHERE (USER_ID IS NULL OR LTRIM(NAME)='')
OR (NAME IS NULL OR LTRIM(NAME)='')
--打开游标
OPEN cur_correctIdCard
--开始FETCH
FETCH NEXT FROM cur_correctIdCard INTO @id,@name,@idcard --0 FETCH 语句成功
--1 FETCH 语句失败或此行不在结果集中
--2 被提取的行不存在
WHILE(@@FETCH_STATUS=0)
BEGIN
... ... FETCH NEXT FROM cur_correctIdCard INTO @id,@name,@idcard
SET @idcard=NULL
END CLOSE cur_correctIdCard
DEALLOCATE cur_correctIdCard

3. 复制表的数据

SELECT * INTO users_bak FROM users

4. group by … having …

DELETE
FROM dbo.old_clubuser WHERE CLUBUSER_ID
IN(
SELECT MIN(CLUBUSER_ID) FROM dbo.old_clubuser WHERE CLUBUSER_NAME IS NOT NULL AND CLUBUSER_NICKNAME IS NOT NULL
GROUP BY CLUBUSER_NAME,CLUBUSER_NICKNAME
HAVING COUNT(CLUBUSER_NAME)>1
)

5. 事务

BEGIN TRANSACTION trans_correctIdCard
BEGIN TRY
DECLARE
@name NVARCHAR(100),
@id DECIMAL,
@idcard NVARCHAR(100)=NULL COMMIT TRANSACTION trans_correctIdCard
PRINT 'SUCCESS'
END TRY
BEGIN CATCH ROLLBACK TRANSACTION trans_correctIdCard PRINT '出错:'+CAST(@@error AS NVARCHAR(MAX))
PRINT '已进行回滚' END CATCH

5. 先判断表是否存在再创建表

--判断表是否存在,存在则先删除
IF object_id(N'dbo.T_Student',N'U') IS NOT NULL
DROP TABLE dbo.T_Student
GO --创建表
CREATE TABLE [dbo].[T_Student](
[Id] [int] IDENTITY(1,1) NOT NULL,
[Name] [nvarchar](max) NULL,
[Age] [int] NOT NULL,
[NickName] [nvarchar](max) NULL,
[City] [nvarchar](max) NULL,
CONSTRAINT [PK_dbo.T_Student] PRIMARY KEY CLUSTERED ([Id] ASC)
)

6. 获取SQL Server表结构

SELECT (case when a.colorder=1 then d.name else null end) 表名,
a.colorder 字段序号,a.name 字段名,
(case when COLUMNPROPERTY( a.id,a.name,'IsIdentity')=1 then '√'else '' end) 标识,
(case when (SELECT count(*) FROM sysobjects
WHERE (name in (SELECT name FROM sysindexes
WHERE (id = a.id) AND (indid in
(SELECT indid FROM sysindexkeys
WHERE (id = a.id) AND (colid in
(SELECT colid FROM syscolumns WHERE (id = a.id) AND (name = a.name)))))))
AND (xtype = 'PK'))>0 then '√' else '' end) 主键,b.name 类型,a.length 占用字节数,
COLUMNPROPERTY(a.id,a.name,'PRECISION') as 长度,
isnull(COLUMNPROPERTY(a.id,a.name,'Scale'),0) as 小数位数,(case when a.isnullable=1 then '√'else '' end) 允许空,
isnull(e.text,'') 默认值,isnull(g.[value], ' ') AS [说明]
FROM syscolumns a
left join systypes b on a.xtype=b.xusertype
inner join sysobjects d on a.id=d.id and d.xtype='U' and d.name<>'dtproperties'
left join syscomments e on a.cdefault=e.id
left join sys.extended_properties g on a.id=g.major_id AND a.colid=g.minor_id
left join sys.extended_properties f on d.id=f.class and f.minor_id=0
where b.name is not null
--WHERE d.name='要查询的表' --如果只查询指定表,加上此条件
order by a.id,a.colorder

(出处:http://www.cnblogs.com/ynbt/archive/2012/07/16/2593389.html)

7. 查询数据库中的所有数据库名

SELECT Name FROM Master..SysDatabases ORDER BY Name

8. 查询某个数据库中所有的表名

SELECT Name FROM SysObjects Where XType='U' ORDER BY Name

9. 批量清空一个库的表(1)

SELECT 'TRUNCATE TABLE ' + Name FROM SysObjects Where XType='U' ORDER BY Name

10. 批量清空一个库的表(2)

    USE [库名]
DECLARE
@tableName NVARCHAR(100) --声明游标
DECLARE CUR_ALLTABLES CURSOR
FOR
SELECT Name FROM SysObjects Where XType='U' ORDER BY Name --打开游标
OPEN CUR_ALLTABLES
--开始FETCH
FETCH NEXT FROM CUR_ALLTABLES INTO @tableName DECLARE @SQL VARCHAR(MAX) = '' --0 FETCH 语句成功
--1 FETCH 语句失败或此行不在结果集中
--2 被提取的行不存在
WHILE(@@FETCH_STATUS=0)
BEGIN SET @SQL = 'TRUNCATE TABLE ' + @tableName
PRINT @SQL FETCH NEXT FROM CUR_ALLTABLES INTO @tableName
END CLOSE CUR_ALLTABLES
DEALLOCATE CUR_ALLTABLES

11. 行列转换的例子

WITH CTE AS (
select 1 as 序号 ,'2010-2-3' as 日期,'是' as 状
union all
select 2 as 序号 ,'2010-2-3' as 日期,'否' as 状
union all
select 3 as 序号 ,'2010-2-4' as 日期,'是' as 状
union all
select 4 as 序号 ,'2010-2-4' as 日期,'否' as 状
union all
select 5 as 序号 ,'2010-2-3' as 日期,'是' as 状
union all
select 6 as 序号 ,'2010-2-3' as 日期,'是' as 状
union all
select 7 as 序号 ,'2010-2-4' as 日期,'是' as 状
)
SELECT 日期, SUM(是) 是, SUM(否) 否 FROM (
SELECT 日期,
CASE WHEN 状='是' THEN 1 ELSE 0 END AS 是,
CASE WHEN 状='是' THEN 0 ELSE 1 END AS 否 FROM CTE
)A GROUP BY 日期

12. 获取一个存储过程的内容

DECLARE @Content NVARCHAR(max)
SELECT @Content=text
FROM syscomments
WHERE id = ( SELECT id FROM sysobjects WHERE name = 'StoredProcedureName')
PRINT @Content

13. 使用OFFSET/FETCH NEXT获取分页数据[SQL Server 2012]
注:OFFSET是从0开始的

DECLARE @Count int = 10
SELECT * FROM TableName(NOLOCK) WHERE Status&2=2
ORDER BY CreateTime DESC
OFFSET 0 ROW FETCH NEXT @Count rows only

14. top

DECLARE @COUNT INT = 10;
SELECT TOP(@COUNT) FROM T_Name

15. Create View

IF object_id(N'dbo.v_users',N'V') IS NOT NULL
DROP VIEW dbo.v_users
GO CREATE VIEW dbo.v_users
AS
SELECT *
FROM [dbo].[users]

16. 查看SP

sp_helptext spname

17. 获取执行统计信息

DBCC DROPCLEANBUFFERS 清除缓冲区
DBCC FREEPROCCACHE 删除计划高速缓存中的元素 SET STATISTICS TIME ON
SET STATISTICS IO ON SELECT 1 FROM Persons SET STATISTICS TIME OFF
SET STATISTICS IO OFF

相关: http://www.cnblogs.com/xqhppt/p/4041799.html

18. 修改字段

alter table Persons alter column Name nvarchar(12) not null

To Be Continued ...

常用sql语句整理[SQL Server]的更多相关文章

  1. 常用sql语句整理:mysql

    ## 常用sql语句整理:mysql1. 增- 增加一张表```CREATE TABLE `table_name`(  ...  )ENGINE=InnoDB DEFAULT CHARSET=utf8 ...

  2. Oracle数据库常用的Sql语句整理

    Oracle数据库常用的Sql语句整理 查看当前用户的缺省表空间 : select username,default_tablespace from user_users; 2.查看用户下所有的表 : ...

  3. 一个项目涉及到的50个Sql语句(整理版)

    /* 标题:一个项目涉及到的50个Sql语句(整理版) 说明:以下五十个语句都按照测试数据进行过测试,最好每次只单独运行一个语句. */ --1.学生表Student(S,Sname,Sage,Sse ...

  4. mysql copy表或表数据常用的语句整理汇总

    mysql copy表或表数据常用的语句整理汇总. 假如我们有以下这样一个表: id username password ----------------------------------- 1 a ...

  5. 如果一条SQL语句太长,我们可以通过回车键来创建一个新行来编写SQL语句,SQL语句的命令结束符为分号(;)。

    1.如果一条SQL语句太长,我们可以通过回车键来创建一个新行来编写SQL语句,SQL语句的命令结束符为分号(;). 2.select查询的多个字段之间要用逗号“,”分割,如果查询涉及多个表,那多个表之 ...

  6. 基于简单sql语句的sql解析原理及在大数据中的应用

    基于简单sql语句的sql解析原理及在大数据中的应用 李万鸿 老百姓呼吁打土豪分田地.共同富裕,总有一天会实现. 全面了解你所不知道的外星人和宇宙真想:http://pan.baidu.com/s/1 ...

  7. 第15讲:嵌入式SQL语句(动态SQL)

    一.动态SQL概述 1. 静态SQL vs 动态SQL ①动态SQL是相对静态SQL而言的 ②静态SQL特点:SQL语句在程序中已经按要求写好,只需要把一些参数通过变量传递给SQL语句即可 specN ...

  8. mybatis日志,打印sql语句,输出sql

    mybatis日志,打印sql语句,输出sql<?xml version="1.0" encoding="UTF-8" ?><!DOCTYPE ...

  9. 常用的一些SQL语句整理,也许有你想要的。

    本篇文章是对一些常用的sql语句进行了总结与分析,需要的朋友参考下,也许会有你需要的. 1.SQL行列转换 问题:假设有张学生成绩表(tb)如下:姓名 课程 分数张三 语文 74张三 数学 83张三 ...

随机推荐

  1. 眼保Guide

    1.睡前不要玩手机,特别是关灯玩手机!否则第二天早上你就会感到眼睛模糊了.长久下去就会形成近视或者近视加深. 2.早上起床半小时内不要戴眼镜,不要看手机.电脑等一切电子屏幕,甚至不要看书.这段时间是眼 ...

  2. 高性能JavaScript DOM编程

    我们知道,DOM是用于操作XML和HTML文档的应用程序接口,用脚本进行DOM操作的代价很昂贵.有个贴切的比喻,把DOM和JavaScript(这里指ECMScript)各自想象为一个岛屿,它们之间用 ...

  3. 【分布式协调器】Paxos的工程实现-cocklebur选举

    其实整个项目中一个最主要的看点就是选举算法,而这部分也是逻辑最复杂最难理解的部分.不同的实现在不同的场景下的策略也不尽相同,而且场景非常之多.接下来我们一起来看一下Cocklebur的实现思路. 一个 ...

  4. redis性能测试tcp socket and unix domain

    UNIX Domain Socket IPC socket API原本是为网络通讯设计的,但后来在socket的框架上发展出一种IPC机制,就是UNIX Domain Socket.虽然网络socke ...

  5. 深入理解计算机系统(2.8)---浮点数的舍入,Java中的舍入例子以及浮点数运算(重要)

    前言 上一章我们简单介绍了IEEE浮点标准,本次我们主要讲解一下浮点运算舍入的问题,以及简单的介绍浮点数的运算. 之前我们已经提到过,有很多小数是二进制浮点数无法准确表示的,因此就难免会遇到舍入的问题 ...

  6. 用程序集编写clr表值函数:把正则表达式引入数据库中

    正则表达式非常好,但在数据库中就是没有,但可以通过程序集方式扩展 先编写一个dll,标量函数很好写,表值函数麻烦一点 下面是C#代码 using System; using System.Data; ...

  7. 求height数组

    procedure getheight; var i,po1,po2:longint; begin to len do begin ; po1:=i;po2:=sa[rank[i]-]; while ...

  8. 利用ZTree链接数据库实现 [权限管理]

    最近想研究权限管理,看群里有人发了ZTrees模板,我看了下,觉得笔easyUI操作起来更灵活些,于是就开始研究了. 刚开始从网上找了找了个Demo,当然这个并没有实现权限啥的,但实现了前台调用Aja ...

  9. 软件工程(FZU2015)学生博客列表(最终版)

    FZU:福州大学软件工程 张老师的博客:http://www.cnblogs.com/easteast/ 经过前两周选课,最后正式选上课程的所有学生博客如下: 序号 学号后3位 博客 1 629 li ...

  10. 0921MySQL 报错 ERROR 1290 (HY000): running with the --secure-file-priv

    http://blog.itpub.net/26506993/viewspace-2121850/ mysql> show variables like '%secure%';+-------- ...