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

我们在写SQL脚本的时候,可能一些看起来不起眼的小问题、却让我们非常头疼。比如我们要写一个备份数据库的脚本,如果我们对服务器的硬盘分区和使用情况很了解,备份当然没有问题,但如果我们不知道服务器硬盘如何分区、每个分区还有多少空间可用的情况下,您写的备份语句可能就不好执行了。 2018-12-26 09:25:30 SQL ServerSQL语句数据库 如何在SQL Server查询中实现高效分页 经常写SQL查询脚本的朋友,很可能会遭遇分页查询的问题。在MSSQL2000及以前的版本中,分页的写法大多采用纯Top嵌套方式,写法比较复杂、而且效率并不理想。今天我们就谈谈ROW_NUMBER和offset的语法和在分页中的应用。 2018-12-25 16:30:15 SQL Server高效分页数据库 巧用SQL语句查看SQL Server的结构信息 常用SQLServer的朋友们,绝大部分情况下,我们写SQL脚本主要用来处理我们自己的数据,比如读取、插入数据等。但在有些情况下,我们可能要查看我们定义的一些元素,比如我们定义的表都有哪些、表结构如何、存储过程的源码等等。这时候,我们学习的常规的SQL脚本可能就无法处理了。 2018-12-25 14:40:04 SQL ServerSQL语句数据库 您最需要了解的NoSQL非关系型数据库 朋友们,我们平时使用的数据库,大多都是关系型数据库,包括MySQL、PostgreSQL、SQLServer等。关系型数据库的特点是数据的存储通过二维表格实现,将数据存储在相互独立的表格中。 2018-12-24 18:35:11 NoSQLRedisMongoDB SQL Server和MySQL常用SQL区别 SQLServer和MySQL都是大家常用的数据库,她们基本兼容SQL-92标准,但语法风格还是有一些不同,下面列举一部分两者常用SQL片段的差异,权当抛砖引云,其实两者之间的细微差异多着呢。

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

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

[[253484]]

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

查看硬盘分区与可用空间

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

EXEC master..xp_fixeddrives

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

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

按照姓氏笔画排序

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

  1. Select*From表名OrderBy字段CollateChinese_PRC_Stroke_ci_as

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

按照姓氏笔画排序

比较两个表是否相等

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

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

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

比较两个表是否相等

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

如果获取前多少条,大家都知道通过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. selectv.*from(
  2. selectROW_NUMBER()over(orderby排序字段)asFRowID,*from表名
  3. )asv
  4. wherev.FRowIDbetween序列1and序列2

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

巧用ROW_NUMBER截取记录

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

  1. select*from(
  2. selectROW_NUMBER()over(orderby(select0))asFRowID,*from表名
  3. )asv
  4. wherev.FRowIDbetween序列1and序列2

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

巧用ROW_NUMBER截取记录

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

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

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

  1. selecta.*fromsysobjectsa,syscommentsbwherea.id=b.idandb.textlike'%表名%'

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

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

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

【编辑推荐】

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

©本文为清一色官方代发,观点仅代表作者本人,与清一色无关。清一色对文中陈述、观点判断保持中立,不对所包含内容的准确性、可靠性或完整性提供任何明示或暗示的保证。本文不作为投资理财建议,请读者仅作参考,并请自行承担全部责任。文中部分文字/图片/视频/音频等来源于网络,如侵犯到著作权人的权利,请与我们联系(微信/QQ:1074760229)。转载请注明出处:清一色财经

(0)
打赏 微信扫码打赏 微信扫码打赏 支付宝扫码打赏 支付宝扫码打赏
清一色的头像清一色管理团队
上一篇 2023年5月6日 11:13
下一篇 2023年5月6日 11:13

相关推荐

发表评论

登录后才能评论

联系我们

在线咨询:1643011589-QQbutton

手机:13798586780

QQ/微信:1074760229

QQ群:551893940

工作时间:工作日9:00-18:00,节假日休息

关注微信