读《程序员的SQL金典》[1]--基础数据检索
前言
《程序员的SQL金典》这本书是杨中科老师的,拜读了一下,简单做了读书笔记供以后翻阅。仅供学习分享,要想细读的话推荐购买原版呀!
这次读书的时候用了新的办法把看书计划进行了量化,虽然简单,发现还是有效果的。

1. Count(*)与Count(column)区别
Count(*)统计结果集总条数;
Count(column)统计结果集中column字段不为null的总条数。
2. 低效的where 1=1
为了实现动态拼接查询条件的功能,有时我们会使用where 1=1这样看似聪明的解决方案。但实际上会造成很大的性能损失,这个条件使得数据库无法使用索引等优化查询策略,数据库会进行全表扫描。当数据量较大的时候查询速度可能会变得很慢。(在SQL Server2012等数据库中,对这种情况其实已经做了优化)
优化前:
private static void CreateWhere(QueryParam param)
{
string where = " where 1=1 " ;
if (param != null )
{
if (param.HasPicture)
{
where += " AND picture<>'' " ;
}
if (param.ClassId > )
{
where += " AND ClassID=@classid " ;
}
if (param.AuthorId > )
{
where += " AND UserId=@UserId";
}
}
}
可以改用下面的逻辑实现。
private static void CreateWhere1(QueryParam param)
{
StringBuilder where = new StringBuilder( " where 1=1 ");
bool hasWhere = false ;
if (param != null )
{
if (param.HasPicture)
{
hasWhere = AppendWhereIfNeed(where, hasWhere);
where.AppendLine( "picture<>'' ");
}
if (param.ClassId > )
{
hasWhere = AppendWhereIfNeed(where, hasWhere);
where.AppendLine( "ClassID=@classid ");
}
if (param.AuthorId > )
{
hasWhere = AppendWhereIfNeed(where, hasWhere);
where.AppendLine( "UserId=@UserId");
}
}
}
private static bool AppendWhereIfNeed( StringBuilder where, bool hasWhere)
{
if (hasWhere)
{
where.Append( " and ");
}
else
{
where.Append( " where ");
}
return true ;
}
3.Group By分组
分组查询时,所有SELECT语句中出现的列必须出现在Group By子句中(聚合函数除外。)
实例:
①错误
SELECT FAge ,FSalary FROM T_Employee GROUP BY FAge
--选择列表中的列 'T_Employee.FSalary' 无效,因为该列没有包含在聚合函数或 GROUP BY 子句中。
②正确
SELECT FAge ,Max( FSalary) FROM T_Employee GROUP BY FAge
FAge (无列名)
22 1200.00
23 5000.00
25 8300.00
28 6200.00
4.Having 语句
①聚合函数不能出现在where语句中,此时可以使用having语句代替。
SELECT FAge , COUNT(*) AS CountOfThisAge FROM T_Employee GROUP BY FAge --WHERE COUNT(*)>1--错误 HAVING COUNT (*)> 1--正确
②HAVING子句位置要在GROUP子句之后;
③HAVING子句也可以像where一样使用较复杂的过滤条件
SELECT FAge ,COUNT(*) AS CountOfThisAge FROM T_Employee GROUP BY FAge HAVING COUNT (FAge)= 1 OR COUNT(FAge )=2 SELECT FAge ,COUNT(*) AS CountOfThisAge FROM T_Employee GROUP BY FAge HAVING COUNT (FAge) IN(1 ,2)
5.ROW_NUMBER() OVER(排序规则)
ROW_NUMBER()函数可以计算数据的行号。但该函数不能放在WHERE子句中,如果想根据行号进行过滤可以使用子查询来实现。
SELECT * FROM
(
SELECT ROW_NUMBER () OVER (ORDER BY FSalary DESC) num, FName,FSalary
FROM T_Employee
) A
WHERE A .num BETWEEN 1 AND 3
6.DISTINCT
DISTINCT是针对这个结果集取消重复的,而不是针对单个列。
7.字符串计算函数
①LEN(string)可以计算字段的长度。
SELECT FName ,LEN( FName) AS NameLength
FROM T_Employee
WHERE FName IS NOT NULL
②SUBSTRING(str,start,length):
字符串截取函数。str表示原字符串,start为开始位置(从1开始计算),length为截取的长度。
SELECT FName ,SUBSTRING( FName,1 ,2) AS NameLength
FROM T_Employee
WHERE FName IS NOT NULL
执行结果:
FName NameLength
Tom To
Jerry Je
Jane Ja
8.UNION
UNION可以进行结果集的合并。如果想合并之后自动去掉重复行,可以使用UNION ALL.
读《程序员的SQL金典》[1]--基础数据检索的更多相关文章
- 读《程序员的SQL金典》[4]--SQL调优
一.SQL注入 如果程序中采用sql拼接的方式书写代码,那么很可能存在SQL注入漏洞.避免的方式有两种: 1. 对于用户输入过滤敏感字母: 2. 参数化SQL(推荐). 二.索引 ①索引分类 聚簇索引 ...
- 读《程序员的SQL金典》[2]--函数
一.数学函数 1.RAND SELECT RAND () ---0.302870228294199 取0-1之间的随机小数. 2.小数取整 CEILINT(data)舍掉小数部分并向上取整. FLOO ...
- 读《程序员的SQL金典》[3]--表连接、子查询
一.表连接-JOIN 1. 自连接实例 查询类型相同的订单信息. SELECT O1 .*,O2.* FROM T_Order O1 JOIN T_Order O2 ON O1 .FTypeId= O ...
- 【程序员的SQL金典】笔记(第6章~第11章)
第六章 索引与约束 1.索引用来提高数据的检索速度,而约束则用来保证数据的完整性. 2.创建索引 创建索引的SQL 语句是CREATE INDEX,其语法如下: CREATE INDE ...
- 程序员的sql金典
1.数据库基础概念 2.数据类型 3.通过SQL语句管理数据表 4.数据的增删改 5.Select的基本用法 6.高级数据过滤 7.数据分组 8.限制结果集行数和抑制重复数据 9.计算字段 10.不从 ...
- 【程序员的SQL金典】笔记(第1章~第5章)
第一章数据库入门 1.概念: 数据库 表 列 记录(行) 主键 索引 第二章 数据表的创建和管理 1.数据库系统中的数据类型大致可以分为五类:整数.数值.字符相关.日期时间以及二进 ...
- 好程序员web前端分享HTML基础篇
好程序员web前端分享HTML基础篇,最近遇到很多新手,都会问,如果要学web前端开发,需要学什么?难不难学啊?多久能入门之类的问题?那么今天好程序员就先来给大家分享一下web前端学习路线:HTML基 ...
- 面向.Net程序员的Sql版本管理
代码版本管理基本上程序员们都知道 TFS GIT SVN等等 但是对于数据库版本管理 java程序员或许会了解一些 但是.Net程序员收获的资料应该不多. 特别是现在云概念使用越来越广的情况下,与应用 ...
- 程序员书单_java学习基础编程篇
Java程序设计语言.(美国)阿诺德.清晰版 http://download.csdn.net/detail/shenzhq1980/9076093 JAVA2核心技术第1卷.基础知识7th.part ...
随机推荐
- FLASH CC 2015 CANVAS (四)制作响应式设计(自适应)的项目
注意 此贴 为个人边“开荒”边写,所以不保证就是最佳做法,也难免有错误(如果发现我会更新文章)! 正式教程会在后续开始更新 相信你在看了(第二节)(第三节)之后已经能够满足绝大多数的互动需求了.那么也 ...
- Eclipse 高亮显示选中的相同变量
问题描述: 在 eclipse 中使用快捷键或其他原因,不小心按错了,使得变量的高亮显示没了. 1.网友解决方法: 选择:windows-> preferences->java-> ...
- 记CVTE2014年春季招聘实习生求职历程
进度:目前已经过了网测 明天一面,好紧张,人生第一次实习面试.据说只有一分钟. 网测; 首先在http://exam.cvte.com/ 注册了账号,然后填写相关的个人信息,这里要仔细填写,因为它最后 ...
- iOS - UIToolbar
前言 NS_CLASS_AVAILABLE_IOS(2_0) __TVOS_PROHIBITED @interface UIToolbar : UIView <UIBarPositioning& ...
- 直播未来属于RTMP还是HTTP?
直播未来属于RTMP还是HTTP? HTTP 传视频比 RTMP 实现起来简单?HTTP 延迟太高? 答:直播通讯未来是属于html5的. 1,协议使用份额 如今国内90%的面向大众的直播平台都是采用 ...
- QQReg.java
import java.awt.*; import javax.swing.*; public class QQReg extends JFrame{ public static void main( ...
- C++中关于new及内存地址的思考
OJ题刷多了,每次都是直接分配内存,那么,你还记得怎么动态分配内存吗? ———————————————————————————————————— 我们知道,使用malloc/calloc等分配内存的函 ...
- 10 database tables
本章提要-----------------------------------各种数据库表的讨论, 并介绍什么情况使用哪种表情调表的物理存储特征---------------------------- ...
- Java的加密与解密
package com.wangbo.util; import java.security.Key; import java.security.Security; import javax.crypt ...
- Object Pascal 控制语句
控制语句 1.常量声明语句常量在声明时就被赋予了一个值,在程序执行过程中是不可改变的. 格式 const 常量名 :数据类型 = 值 下面的例子声明了3 个常量: const Pi = 3.14159 ...