数据库大师成长日记:巧用SQL语句,小技巧解决大问题!

栏目: 数据库 · 发布时间: 7年前

内容简介:朋友们,我们在写SQL脚本的时候,可能下面,我就日常我们可能会碰到的一些“大问题”,通过简单的SQL脚本进行实现。

朋友们,我们在写 SQL 脚本的时候,可能 一些看起来不起眼的小问题、却让我们非常头疼 。比如我们要写一个备份数据库的脚本,如果我们对服务器的硬盘分区和使用情况很了解,备份当然没有问题,但如果我们不知道服务器硬盘如何分区、每个分区还有多少空间可用的情况下,您写的备份语句可能就不好执行了。

数据库大师成长日记:巧用SQL语句,小技巧解决大问题!

下面,我就日常我们可能会碰到的一些“大问题”,通过简单的SQL脚本进行实现。

查看硬盘分区与可用空间

这个通过调用master数据库下面的存储过程 xp_fixeddrives 很容易实现。

EXEC master..xp_fixeddrives

数据库大师成长日记:巧用SQL语句,小技巧解决大问题!

获取数据库服务器的磁盘分区和可用空间

按照姓氏笔画排序

这问题看起来很简单,做起来可能会让您毫无头绪,通过调用MSSQL的字符集信息很容易实现。

Select *  From 表名  Order  By 字段  Collate Chinese_PRC_Stroke_ci_as  

数据库大师成长日记:巧用SQL语句,小技巧解决大问题!

按照姓氏笔画排序

比较两个表是否相等

这个看似简单的问题,通常的写法可能要些一大坨SQL进行各种对比,下面的方法就很简单。

if (select checksum_agg(binary_checksum(*))  from 表1)  =( select checksum_agg(binary_checksum(*))  from 表2)  
 print '相等'  
else  
 print '不相等'  

数据库大师成长日记:巧用SQL语句,小技巧解决大问题!

比较两个表是否相等

分页及获取某个区间的数据记录

如果获取前多少条,大家都知道通过top n,如果数据本来有1000条,您想按照某种 排序 后,获取其中的第10到11条该如何处理呢?SQL中提供了一个很好用的ROW_NUMBER()函数,返回的就是行标,灵活运用您就会惊喜不断。其语法格式如下:

ROW_NUMBER() OVER ([ partition_by_clause ] order_by_clause)  

其中:

  • partition_by_clause:将FROM子句生成的结果集划入应用了ROW_NUMBER()函数的分区。可以理解为 分组
  • order_by_clause:确定将ROW_NUMBER值分配给分区中的行的顺序。其实就是 排序

了解了这个,我们就可以写了:

select v.*  from (  
select ROW_NUMBER() over( order  by 排序字段)  as FRowID,*  from 表名  
) as v   
where v.FRowID  between 序列1  and 序列2 

数据库大师成长日记:巧用SQL语句,小技巧解决大问题!

巧用ROW_NUMBER截取记录

如果您不希望排序,只需要截取默认顺序的记录,可以这样写:

select *  from (  
select ROW_NUMBER() over( order  by ( select 0))  as FRowID,*  from 表名  
) as v  
where v.FRowID  between 序列1  and 序列2  

数据库大师成长日记:巧用SQL语句,小技巧解决大问题!

巧用ROW_NUMBER截取记录

有关分组的,这里就不再赘述了。

查看与某一个表相关的视图、存储过程、函数

这也是一个看起来简单做起来头疼的问题。其实活用sysobjects和syscomments即可。

select a.*  from sysobjects a, syscomments b  where a.id = b.id  and b.text  like '%表名%'  

数据库大师成长日记:巧用SQL语句,小技巧解决大问题!

查看引用表的所有视图、存储过程和函数

还有很多的小技巧,以后我们慢慢发掘吧。


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

程序开发心理学

程序开发心理学

(美)杰拉尔德·温伯格 / 邓俊辉 / 清华大学出版社 / 2004-1-1 / 39.00元

本书开创"以人为本"研究方法的先驱,在长达25年的岁月中一直保持活力,至今仍在继续。1997年,本书作者温伯格因其在软件领域的杰出贡献,被美国计算机博物馆的计算机名人堂选为首批5位成员之一。 在计算机界,还没有任何一本计算机方面的书,在初次出版之后,能够在长达25年的岁月中一直保持活力--而且这种活力到今天仍在继续。《程序开发心理学》是开创"以人为本"研究方法的先驱,它以其对程序员们在智力、......一起来看看 《程序开发心理学》 这本书的介绍吧!

MD5 加密
MD5 加密

MD5 加密工具

RGB CMYK 转换工具
RGB CMYK 转换工具

RGB CMYK 互转工具

HEX CMYK 转换工具
HEX CMYK 转换工具

HEX CMYK 互转工具