SQL的编写顺序和执行顺序,以及空值处理,别名处理,转义字符处理
SQL即结构化查询语言。也就是用来从数据库中操作数据的。数据总的来说就是增删改查CRUD。
一,sql的分类,大致有四类:
1)DDL : 数据定义语言 create alter drop truncate
2)DML : 数据操纵语言 insert update delete
3)DCL : 数据控制语言 安全 授权 grant revoke
4)DQL : 数据查询语言 select 子句
二,查询语句的结构
select [列名] [*] from 表名 [where 条件] [group by 分组条件] [having 过滤分组条件] [order by 排序 asc|desc]
三,sql的书写顺序
SQL的书写顺序:select ...from ..where...group by having...order by ....
四,sql的执行顺序
sql的执行顺序:from ...where... group by... having... select.... order by...
先是从那张表以什么条件查询出来,其次是以什么条件分组,最后将查询出来的数据进行排序输出。
五,sql中的聚合函数
求和函数:sum() 求平均:avg() 最大值:max() 最小值:min() 统计: count()
聚合函数在使用的时候是不会将空值纳入计算的,也就是说聚合函数是会避开空值的。count()用于统计不为空的记录。
需要注意的是:
1.在select子句中出现了聚合函数,就不要出现其他的普通列,除非是group by分组的列。
2.where 后面不能加聚合函数,where 是对from的结果进行筛选,需要使用where子查询。
3.使用统计count()时不要使用*号,最好使用主键或者常量。
六,关于sql中的模糊查询
sql中支持通配符,模糊查询主要有%,_,利用这两个通配符来进行模糊查询。%表示匹配一个或多个甚至0个字符,_表示匹配一个字符。
例如 select * from emp where name like 'j%';表示查询出姓名以j开头的所有员工信息。
七,关于别名的问题
使用as 关键字, 可以省略,别名中不能有特殊字符或者关键字, 如果有就加双引号。
八,关于在查询中遇到特殊字符
在查询中遇到特殊字符需要使用转义字符 escape,
例如 查询名字中包含%的员工信息,select * from emp where ename like '%\%%' escape '\';
九,关于排序时null值的处理
排序为null的问题可以使用nulls first | last来指定null值得显示位置,是之前显示还是最后显示。
select * from emp order by comm desc nulls last | first;
当null参与运算时,任何与null进行运算都是null。例如select 1+null;结果为空。所以在数据库中药尽量避免空值。在设计时需要考虑好。
十,多表查询
多表查询主要有内连接,外连接。内连接 inner join on也就是两个表之间的交集,可以直接使用where代替。
外连接又分为左外连接和右外连接。
左外连接:left outer(可省略) join...on
例如:select A.name,B.name from A left join B on A.id=B.id;左外连接的特点是,不管右表中有没有数据与左表中存在关联,它都将查询出左表的全部数据。靠近左边的就是左表。
右外连接:right outer join... on特点和左连接相反。
SQL的编写顺序和执行顺序,以及空值处理,别名处理,转义字符处理的更多相关文章
- SQL Select语句完整的执行顺序(转)
SQL Select语句完整的执行顺序: 1.from子句组装来自不同数据源的数据: 2.where子句基于指定的条件对记录行进行筛选: 3.group by子句将数据划分为多个分组: 4.使用聚集函 ...
- SQL 中的语法顺序与执行顺序(转)
很多程序员都很抵触SQL.其实SQL是一整为数不多的声明性语言,只是它的运行方式完全不同于我们所熟知的命令行语言.面向对象的程序语言.甚至是函数语言. 今天大家共同学习下SQL的语法顺序与执行顺序.( ...
- 170607、SQL Select语句完整的执行顺序
SQL Select语句完整的执行顺序: 1.from子句组装来自不同数据源的数据: 2.where子句基于指定的条件对记录行进行筛选: 3.group by子句将数据划分为多个分组: 4.使用聚集函 ...
- sql查询原理和Select执行顺序
一 sql语句的执行步骤 1)语法分析,分析语句的语法是否符合规范,衡量语句中各表达式的意义. 2) 语义分析,检查语句中涉及的所有数据库对象是否存在,且用户有相应的权限. 3)视图转换,将涉及视图的 ...
- 009 面试题 SQL语句各部分的执行顺序
SQL语句各部分的执行顺序 select distinct...from t1 (left/right) join t2 on t1.xx=t2.xx where t1.xx=? and t2.xx= ...
- Oracle-SQL语句的语法顺序和执行顺序
SQL语句的语法顺序和执行顺序了,我们常见的SQL语法顺序如下: SELECT DISTINCT <Top Num> <select list>FROM [left_table ...
- mysql语句的书写顺序和执行顺序
mysql语句的书写顺序和执行顺序有很大差异. 书写顺序,mysql的一般书写顺写为: select <要返回的数据列> from <表名> <join, left jo ...
- SQL查询中关键词的执行顺序
写在前面:最近的工作主要是写SQL脚本,在编写过程中对SQL的执行和解析过程特别混乱不清,造成了想优化却无从下手.为此专门在网上找博文学习,并做了如下总结. 1.查询中常用到的关键词有: SELECT ...
- SQL server T-sql语句查询执行顺序
前言 数据库的查询执行,毋庸置疑是程序员必备的技能之一,然而数据库查询执行的过程绚烂多彩,却是很少被人了解,今天我们来深入了解下sql查询的来龙去脉,为查询的性能优化打个基础 这篇博客,摒弃查询优化性 ...
随机推荐
- 大哥带的JavaScript伪协议
将javascript代码添加到客户端的方法是把它放置在伪协议说明符javascript:后的URL中.这个特殊的协议类型声明了URL的主体是任意的javascript代码,它由javascript的 ...
- 基于Xposed hook 实时监测微信消息
本文以微信版本6.7.3为例进行分析有hook, 大部分做微信机器人的话,首先要实时抓取微信的消息,在这里展示三种方式对微信的消息进行hook: 1.基于UI层拉取加载进行监听 2.基于微信dao层调 ...
- LeetCode 15. 三数之和(3Sum)
题目描述 给定一个包含 n 个整数的数组 nums,判断 nums 中是否存在三个元素 a,b,c ,使得 a + b + c = 0 ?找出所有满足条件且不重复的三元组. 注意:答案中不可以包含重复 ...
- 七、smarty--缓存的控制
1.建议缓存 $smarty->cacheing = true; //设置为2是给每一个模板设置缓存 $smarty->setCacheDir(“”); 2.处理缓存的生命周期 $smar ...
- 《统计学习方法(李航)》讲义 第03章 k近邻法
k 近邻法(k-nearest neighbor,k-NN) 是一种基本分类与回归方法.本书只讨论分类问题中的k近邻法.k近邻法的输入为实例的特征向量,对应于特征空间的点;输出为实例的类别,可以取多类 ...
- 深度学习基础——Epoch、Iteration、Batchsize
原文地址:https://www.cnblogs.com/Johnny-z6951/p/11201081.html 梯度下降是一个在机器学习中用于寻找较佳结果(曲线的最小值)的迭代优化算法.梯度的含义 ...
- Spring MVC三种返回方式
spring mvc处理方法支持如下的返回方式:ModelAndView, Model, ModelMap, Map,View, String, void. 下面一一进行说明: 1.ModelAndV ...
- IP冲突如何把冲突的IP挤下去
把冲突IP挤下去的方法: ①进入网络和共享中心>本地连接>禁用. ②进入网络和共享中心>更改适配器设置>双击被禁用的连接,自动重新连接即可.
- Struts2-Ajax整合之Jquery版本
<纯JavaScript版本 http://www.cnblogs.com/hzb462606/p/8934787.html > 大部门跟JavaScript版本一致,就是<sc ...
- Jmeter之乱码 (一)
Jmeter历史版本下载: http://archive.apache.org/dist/jmeter/binaries/ Jmeter3.0接口测试脚本POST请求主体中的中文无法正确显示,现象如下 ...