巧用SQL语句,小技巧解决大问题!

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

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

[[253484]]

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

查看硬盘分区与可用空间

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

EXEC master..xp_fixeddrives

 

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

按照姓氏笔画排序

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

  1. Select * From 表名 Order By 字段 Collate Chinese_PRC_Stroke_ci_as  

按照姓氏笔画排序

比较两个表是否相等

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

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

比较两个表是否相等

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

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

  1. ROW_NUMBER() OVER ([ partition_by_clause ] order_by_clause)  

其中:

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

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

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

 

巧用ROW_NUMBER截取记录

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

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

巧用ROW_NUMBER截取记录

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

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

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

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

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

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

【编辑推荐】

  1. 数据库主要特点是保护数据的安全性和可靠性以及正确性和有效性
  2. 数据库大师成长日记:SQL Server和MySQL常用SQL区别
  3. 数据库大师成长日记:您最需要了解的NoSQL非关系型数据库
  4. 数据库大师成长日记:巧用SQL语句查看SQL Server的结构信息
  5. 数据库大师成长日记:如何在SQL Server查询中实现高效分页
责任编辑:庞桂玉 来源: 快资讯
相关推荐

2011-04-28 15:35:38

打印驱动

2021-10-20 10:29:18

笔记本散热技巧

2011-05-06 10:29:07

内存笔记本

2010-09-26 10:35:47

sql替换语句

2013-09-04 11:15:14

用友用友U8+

2011-07-11 09:54:16

DAC登录触发器

2010-09-25 16:17:25

SQL语句

2018-12-25 14:40:04

SQL ServerSQL语句数据库

2021-01-05 08:12:42

SQL日期Spt

2010-09-07 14:45:34

sql语句

2010-10-21 15:57:37

SQL Server无

2017-07-20 07:30:16

大数据数据互联网

2023-09-25 13:15:50

SQL数据库

2022-07-04 08:51:43

条件语句JavaScript

2010-09-17 10:08:18

SQL中case wh

2009-06-18 11:12:42

Hibernate S优化

2010-11-02 08:58:59

Cassandra

2011-07-26 15:11:51

安全模式

2018-05-21 20:58:44

人工智能云服务企业

2021-06-27 17:07:02

Snapchat QU网络协议网络
点赞
收藏

51CTO技术栈公众号