麒麟v10 上部署 TiDB v5.1.2 生产环境优化实践
871
2023-05-09
巧用SQL语句,小技巧解决大问题!
朋友们,我们在写SQL脚本的时候,可能一些看起来不起眼的小问题、却让我们非常头疼。比如我们要写一个备份数据库的脚本,如果我们对服务器的硬盘分区和使用情况很了解,备份当然没有问题,但如果我们不知道服务器硬盘如何分区、每个分区还有多少空间可用的情况下,您写的备份语句可能就不好执行了。
下面,我就日常我们可能会碰到的一些“大问题”,通过简单的SQL脚本进行实现。
查看硬盘分区与可用空间
这个通过调用master数据库下面的存储过程xp_fixeddrives很容易实现。
EXEC master..xp_fixeddrives
获取数据库服务器的磁盘分区和可用空间
按照姓氏笔画排序
这问题看起来很简单,做起来可能会让您毫无头绪,通过调用MSSQL的字符集信息很容易实现。
Select * From 表名 Order By 字段 Collate Chinese_PRC_Stroke_ci_as
按照姓氏笔画排序
比较两个表是否相等
这个看似简单的问题,通常的写法可能要些一大坨SQL进行各种对比,下面的方法就很简单。
if (select checksum_agg(binary_checksum(*)) from 表1) =(select checksum_agg(binary_checksum(*)) from 表2) print '相等' else print '不相等'
比较两个表是否相等
分页及获取某个区间的数据记录
如果获取前多少条,大家都知道通过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
巧用ROW_NUMBER截取记录
如果您不希望排序,只需要截取默认顺序的记录,可以这样写:
select * from ( select ROW_NUMBER() over(order by (select 0)) as FRowID,* from 表名 ) as v where v.FRowID between 序列1 and 序列2
巧用ROW_NUMBER截取记录
有关分组的,这里就不再赘述了。
查看与某一个表相关的视图、存储过程、函数
查看引用表的所有视图、存储过程和函数
还有很多的小技巧,以后我们慢慢发掘吧。
【编辑推荐】
数据库主要特点是保护数据的安全性和可靠性以及正确性和有效性数据库大师成长日记:***和MySQL常用SQL区别数据库大师成长日记:您最需要了解的NoSQL非关系型数据库数据库大师成长日记:巧用SQL语句查看***的结构信息数据库大师成长日记:如何在***查询中实现高效分页
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。