SQL开发技巧(二)
本系列文章旨在收集在开发过程中遇到的一些常用的SQL语句,然后整理归档,本系列文章基于SQLServer系列,且版本为SQLServer2005及以上……
文章系列目录
- SQL开发技巧(一)
- SQL开发技巧(二)
本文内容简介
这篇文章主要介绍以下内容:
- 快速查询表的总记录数
- 非递归查询树形结构表的所有子节点
- 清除查询缓存
- 编程中构建Where语句的小技巧
- 如何进行跨服务器的数据库查询
快速查询表的总记录数
什么,你还在用select count(*) from xxx?难道没有园友告诉你用select count(col),select count(0)或者select count(1)性能会更好吗?
等等,你难道就只告诉我这个吗,我早知道了,就算是用了select count(0)查询1000w的记录还是慢呐,你不会接着告诉我去升级服务器吧?
当然不是,我要告诉你的是下面的这个语句:
SELECT rows FROM sysindexes WHERE id= OBJECT_ID('rpt2014' ) AND indid< 2
无论查询多少记录数的表,都能立即返回总记录数。为什么它能够这么快,这原理其实跟Length属性和Count()方法一样的,自己体会啦。此外,要注意这个条件:indid< 2。indid为1就是最后提交之后的总记录数,其他值可能表示索引的记录或者其他,具体就自己search了吧。
非递归查询树形结构表的所有子节点
首先,普及一个概念,怎么设计表结构为树形结构的:要设计一个树形结构的表,必须包含两个必要字段:
Id,ParentId
那么树形结构的表要查询子节点是非常容易的:select * from table where ParentId=xxx。但是,如何查询所有的子节点呢(包括子节点的子节点,递归查询)?
原来我采用的方法:
- 把所有记录查询出来,在程序中做递归查询
- 采用存储,在数据库中做递归查询
- 修改表结构,增加字段
ParentIdPath。比如有节点3,父节点为2,而2的父节点为1。那节点3的ParentIdPath就是:2,1.这样查询所有的子节点就可以用like操作了:select * from table where ParentIdPath like '2,%'
上面的方法都不太优美:我不希望在程序中查询、不希望增加额外的存储过程(我也随时随地能用)、不希望增加字段,那么到底该怎么办,需要问下蓝翔吗?
要解决这个问题,需要使用SQLServer中的with关键字,相应创建一个临时表保存每次查询的记录:
WITH Tree AS (
SELECT * FROM dbo .MgrObjType WHERE Id='00000000-A001-0000-0000-000000000000'
UNION ALL
SELECT MgrObjType.* FROM dbo .MgrObjType, Tree WHERE Tree.Id= dbo.MgrObjType .ParentId
)
SELECT * FROM Tree
结果如下:

清除查询缓存
为什么要清除缓存,有一定开发经验的程序员都知道,把一条耗时的语句在SQLServer中查询,第一次可能很慢,第二次就很快了。这样非常影响测试的效率,甚至有些程序员竟然认为第二次查询跟第一次查询不一样,这是一种不可靠的测试,没法重现问题,把责任归咎于SQLServer,巨硬那是真真正正的躺枪。
其实,上述问题的产生,主要是因为SQLServer每次查询,都会把结果缓存下来,遇到相同的SQL语句或者类似的,会从已有的缓存中查询,缓存中不存在的,才实际访问数据库。到底内存缓存多少,你可以设置:

没错,就是它了。有经验的同学还会发现,如果你不设置,可能会耗光你的内存。记得有次我在一台128G内存的电脑上使用,没有限制,内存直接利用到了70多G,搞得运维的同学如临大敌,好像我们的软件有什么天大的问题似的!
这个语句是这么写的:
DBCC FREEPROCCACHE
DBCC DROPCLEANBUFFERS
编程中构建Where语句的小技巧
这真是一个小技巧,我记得我最先学编程的时候,判断条件是这么判断的:
var sql=new StringBuilder();
if(age.HasValue||nickName.HasValue){
sql.AppendFormat(" where ");
}
if(age.HasValue){
sql.AppendFormat("Age={0}",age.Value);
}
if(nickName.HasValue)……
如果条件多了的话,写得那是更加的痛苦
其实上面的条件完全可以这么写:
var sql=new StringBuilder(" where 1=1");
if(age.HasValue){
sql.AppendFormat("Age={0}",age.Value);
}
if(nickName.HasValue)……
多了一个1=1,少了多少的条件判断。为什么会酱紫?拜托自己动一下脑筋好不,什么都要我说出来,你给我发薪水啊!
如何进行跨服务器的数据库查询
要查询另外一个数据库的表,好的,不就是DatabaseName.dbo.Table吗,这个简单
神马,这个数据库在另外一个服务器,尼玛啊,这是什么需求,你tmd为什么要访问另外一个数据库啊。能在代码中实现吗?不行!!!???
好吧,那我们怎么实现,请看:
SELECT * FROM
OPENDATASOURCE('SQLOLEDB' , 'Data Source=172.18.24.245;User ID=sa;Password=aaa*'). CenterObj_xx.dbo .TableLog AS A
你真的没看错,只需增加这么一句OPENDATASOURCE('SQLOLEDB' , 'Data Source=172.18.24.245;User ID=sa;Password=aaa*')即可。这句就是帮你访问远程数据库的。
往期内容回顾
- 使用Row_Number分页
- 事务
- 根据条件刷选记录的技巧
SQL开发技巧(二)的更多相关文章
- SQL开发技巧(二) 【转】感觉他写的很好
本文转自: http://www.cnblogs.com/marvin/p/DevelopSQLSkill_2.html 本系列文章旨在收集在开发过程中遇到的一些常用的SQL语句,然后整理归档,本系列 ...
- Sql开发技巧
原文:Sql开发技巧 简介 本文主要介绍下述几个技巧: 使用Row_Number分页 事务 根据条件刷选记录的技巧 分页 主要是使用了Row_Number()这个函数.一般如下: declare @P ...
- Mysql - 开发技巧(二)
本文中的涉及到的表在https://github.com/YangBaohust/my_sql中 本文衔接Mysql - 巧用join来优化sql(https://www.cnblogs.com/dd ...
- sql开发技巧总结-2
---恢复内容开始--- 1.如何进行行列转换 需求: 列转换成行 select a.`user_name`,sum(b.kills) from user1 a join user_kills b o ...
- sql开发技巧总结-1
1.数据库分类 关系型 非关系型 2.sql语句分类 sql: ddl数据库定义语言 tpl事物处理语言 dcl数据控制语言 dml数据操作语言(insert delete update sele ...
- CSS开发技巧(二):表格合并边框后的单元格宽度计算
前言: 分离边框模型和合并边框模型是表格的两种模型,它通过以下属性确定: border-collapse:separate(默认值) | collapse | inherit 当采用分离边框模型时,表 ...
- discuz二次开发技巧
discuz二次开发技巧 二次开发大多时候知识设置和处理,如果能够获知模板文件获得的变量数组将大大提高我们的开发效率 获取页面已经定义的变量 <--{eval printf_r(get_defi ...
- SQL开发中容易忽视的一些小地方(二)
原文:SQL开发中容易忽视的一些小地方(二) 目的:继上一篇:SQL开发中容易忽视的一些小地方(一) 总结SQL中的null用法后,本文我将说说表联接查询. 为了说明问题,我创建了两个表,分别是学生信 ...
- AngularJS进阶(二十九)AngularJS项目开发技巧之localStorage存储
AngularJS项目开发技巧之localStorage存储 注: localStorage深度学习 绪 项目开发完毕,测试阶段发现后台管理端二维码生成有问题,问题在于localStora ...
随机推荐
- 先说IEnumerable,我们每天用的foreach你真的懂它吗?
我们先思考几个问题: 为什么在foreach中不能修改item的值? 要实现foreach需要满足什么条件? 为什么Linq to Object中要返回IEnumerable? 接下来,先开始我们的正 ...
- VM(虚拟机安装win7 提示 :units specified don't exist, SHSUCDX can't install)解决方法
改成IDE的模式
- Recurrent Neural Network系列1--RNN(循环神经网络)概述
作者:zhbzz2007 出处:http://www.cnblogs.com/zhbzz2007 欢迎转载,也请保留这段声明.谢谢! 本文翻译自 RECURRENT NEURAL NETWORKS T ...
- ABP文档 - 目录
ABP框架 概览 介绍 多层结构 模块系统 启动配置 多租户 集成OWIN 共同结构 依赖注入 会话 缓存 日志 设置管理 时间 领域层 实体 值对象(新) 仓储 领域服务 工作单元 领域事件(Eve ...
- [译]ZOOKEEPER RECIPES-Leader Election
选主 使用ZooKeeper选主的一个简单方法是,在创建znode时使用Sequence和Ephemeral标志.主要思想是,使用一个znode,比如"/election",每个客 ...
- OpenCASCADE Expression Interpreter by Flex & Bison
OpenCASCADE Expression Interpreter by Flex & Bison eryar@163.com Abstract. OpenCASCADE provide d ...
- [.NET] 打造一个很简单的文档转换器 - 使用组件 Spire.Office
打造一个很简单的文档转换器 - 使用组件 Spire.Office [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/6024827.html 序 之前,& ...
- 【知识必备】一文让你搞懂design设计的CoordinatorLayout和AppbarLayout联动,让Design设计更简单~
一.写在前面 其实博主在之前已经对design包的各个控件都做了博文说明,无奈个人觉得理解不够深入,所以有了这篇更加深入的介绍,希望各位看官拍砖~ 二.从是什么开始 1.首先我们得知道Coordina ...
- 游走 bzoj 3143
游走(2s 128MB)walk [问题描述] [输入格式] [输出格式] [样例输入] 3 3 2 3 1 2 1 3 [样例输出] 3.333 [样例说明] 题解: 主要算法:贪心:高斯消元: 题 ...
- BPM配置故事之案例4-子表
公司渐渐对采购管理重视起来了,新招聘了采购主管老李,老李对现有的申请表很不满意,要求将申请物资和申请原因改成物资明细表 物资明细表 小明只好继续致电大毛-- 大毛:把申请物资和申请原因删掉,新增一个数 ...