SqlServer中的查询语句(一)

2014-11-24 08:31:16 ? 作者: ? 浏览: 8

SqlServer中查询语句
表的存在性判断代码
IF OBJECT_ID('tempdb..#temp') is NOT NULL
DROP TABLE #temp;
--查询是否存在有#temp临时表,如存在,将其删除
IF EXISTS(SELECT 1 FROM sys.sysobjects WHERE name = 'temp')
DROP TABLE temp;
--查询是否存在有表temp,如果有,则将其删除
系统自带存储过程代码
EXEC sys.sp_who @loginame = 'sa'
--查看'sa'用户登陆的 数据库的用户和进程 
EXEC sys.sp_depends @objname = 'dbo.Audit_Stat' -- nvarchar(776)
--查看该表相关的依赖信息
EXEC sys.sp_help @objname = 'dbo.Audit_Stat' -- nvarchar(776)
--查看该对象的所有信息
EXEC sys.sp_helpindex @objname = 'dbo.Audit_Stat' -- nvarchar(776)
--查看该对象所对应的索引信息
EXEC sys.sp_helptext @objname = 'dbo.qry_Audit'
--查看该存储过程对应的信息
EXEC sys.sp_password @old = NULL, -- sysname
@new = NULL, -- sysname
@loginame = NULL -- sysname
--修改数据的密码信息
Set应用代码
SET IDENTITY_INSERT tableName OFF|ON
--允许将显示值插入到标识符字段
SET NOCOUNT OFF|ON
--允许返回影响行数
SET ROWCOUNT OFF|ON
--在返回指定的行数之后停止处理查询。
@@fetch_status代码
@@FETCH_STATUS
--返回被 FETCH 语句执行的最后游标的状态,
--而不是任何当前被连接打开的游标的状态。
--0表示FETCH 语句成功
--可以用于循环取游标中数据
@@error代码
PRINT @@ERROR
--无错时,返回为0
--有错时,返回该错误代码
@@identity代码
SELECT * INTO #temp FROM dbo.Audit_Stat WHERE AuditItem = '020' ;
PRINT @@IDENTITY;
DROP TABLE #temp;
--@@IDENTITY;保存 系统中最后修改的标识符
Cursor的使用代码
DECLARE
@Item VARCHAR(10)
SET @Item = '020';
SELECT AuditItem, Date, Obj, ObjType, Count INTO #temp FROM dbo.Audit_Stat WHERE AuditItem = @Item;
--在创建时,对该游标时时进行赋值
--DECLARE temp_cursor CURSOR FOR SELECT * FROM #temp;
DECLARE @temp_cursor CURSOR;
--创建时不指定游标的范围时是全局的
--SET @temp_cursor = CURSOR FOR SELECT * FROM #temp;
--创建时FORWARD_ONLY,游标移动时只能FETCH NEXT
--SET @temp_cursor = CURSOR LOCAL FORWARD_ONLY FOR SELECT * FROM #temp;
--创建时SCROLL,游标可以任意移动
SET @temp_cursor = CURSOR LOCAL SCROLL FOR SELECT * FROM #temp;
SET @temp_cursor = CURSOR LOCAL FOR SELECT * FROM #temp;
OPEN @temp_cursor;
DECLARE @itemCode VARCHAR(10);
DECLARE @theDate common.DT_Date;
DECLARE @obj VARCHAR(10);
DECLARE @objType VARCHAR(10);
DECLARE @theCount INT ;
FETCH NEXT FROM @temp_cursor INTO @itemCode, @theDate, @obj, @objType, @theCount
UPDATE #temp SET Count = 100 WHERE CURRENT OF @temp_cursor;
SELECT * FROM #temp;
CLOSE @temp_cursor;
DEALLOCATE @temp_cursor;
DROP TABLE #temp;
Truncate删除代码
TRUNCATE TABLE #temp;
--Truncate删除比Delete快,
--但删除后不能RollBack
--Delete是物理-次一行删除
--Truncate释放所有与表关联列
Union与union all代码
SELECT TOP 2 *
FROM dbo.Audit_Stat
WHERE AuditItem = '010'
UNION ALL
SELECT TOP 2 *
FROM dbo.Audit_Stat
WHERE AuditItem = '010'
--UNION,UNION ALL
--可以将查询出的结果进行联合,但必须注意的是,
--查询的结果对应结构相同,对应的类型兼容
--UNION:对于查询的结果,如果相同,则合并
--UNION ALL: 对应查询的结果,直接联接,不合并
Having语句应用代码
SELECT AuditItem, SUM(Count) sum
FROM dbo.Audit_Stat
GROUP BY AuditItem
HAVING SUM(Count) > 1000;
--HAVING可对分组后的集合进行过滤
Group by 与 all的应用代码
SELECT AuditItem, SUM(Count) FROM dbo.Audit_Stat WHERE AuditItem = '030'
GROUP BY ALL AuditItem;
--注意Where语句的添加后,对于all更有对比性
--不加all时,仅显示AuditItem = '030'的Code和对应的和
--加上all时,显示所有的AuditItem,但
-->

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容: