2011年计算机三级数据库SQL语句大全(4)

文章作者 100test 发表时间 2011:08:01 10:45:08
来源 100Test.Com百考试题网


  数据开发-经典

  1.按姓氏笔画排序:

  Select * From TableName Order By CustomerName Collate Chinese_PRC_Stroke_ci_as //从少到多

  2.数据库加密:

  0select encrypt(原始密码)

  0select pwdencrypt(原始密码)

  0select pwdcompare(原始密码,加密后密码) = 1--相同.否则不相同 encrypt(原始密码)

  0select pwdencrypt(原始密码)

  0select pwdcompare(原始密码,加密后密码) = 1--相同.否则不相同

  3.取回表中字段:

  declare @list varchar(1000),

  @sql nvarchar(1000)

  0select @list=@list , b.name from sysobjects a,syscolumns b where a.id=b.id and a.name=表A

  set @sql=0select right(@list,len(@list)-1) from 表A

  exec (@sql)

  4.查看硬盘分区:

  EXEC master..xp_fixeddrives

  5.比较A,B表是否相等:

  if (0select checksum_agg(binary_checksum(*)) from A)

  =

  (0select checksum_agg(binary_checksum(*)) from B)

  print 相等

  else

  print 不相等

  6.杀掉所有的事件探察器进程:

  DECLARE hcforeach CURSOR GLOBAL FOR SELECT kill RTRIM(spid) FROM master.dbo.sysprocesses

  WHERE program_name IN(SQL profiler,NSQL 事件探查器)

  EXEC sp_msforeach_worker ?

  7.记录搜索:

  开头到N条记录

  Select Top N * From 表

  -------------------------------

  N到M条记录(要有主索引ID)

  Select Top M-N * From 表 Where ID in (Select Top M ID From 表) Order by ID Desc

  ----------------------------------

  N到结尾记录

  Select Top N * From 表 Order by ID Desc

  案例

  例如1:一张表有一万多条记录,表的第一个字段 RecID 是自增长字段, 写一个SQL语句, 找出表的第31到第40个记录。

  0select top 10 recid from A where recid not in(0select top 30 recid from A)

  分析:如果这样写会产生某些问题,如果recid在表中存在逻辑索引。

  0select top 10 recid from A where……是从索引中查找,而后面的0select top 30 recid from A则在数据表中查找,这样由于索引中的顺序有可能和数据表中的不一致,这样就导致查询到的不是本来的欲得到的数据。

  解决方案

  1, 用order by 0select top 30 recid from A order by ricid 如果该字段不是自增长,就会出现问题

  2, 在那个子查询中也加条件:0select top 30 recid from A where recid


相关文章


2011年计算机三级数据库SQL语句大全(3)
2011年计算机三级数据库SQL语句大全(2)
2011年计算机三级数据库SQL语句大全(1)
2011年计算机三级数据库SQL语句大全汇总
2011年计算机三级数据库SQL语句大全(4)
2011年计算机一级B模拟试题及答案汇总
2011年计算机三级网络技术全真模拟试题(2)
2011年计算机三级网络技术全真模拟试题(1)
2011年计算机三级数据库技术SQL语句辅导:技巧篇
澳大利亚华人论坛
考好网
日本华人论坛
华人移民留学论坛
英国华人论坛