mysql进阶三四五六
排序查询
一、语法
select 查询表
from 表
where 筛选条件
order by 排序列表[asc / desc]
特点:
1、asc:升序
desc:降序
2、排序列表之中支持单字段,多字段、函数、表达式、别名
3、order by的位置一般放在查询语句的最后(除limit之外)
常见函数:
功能:提高重用性
隐藏了实现细节
调用函数语法:
select 函数名(实参列表);
二、单行函数
1、字符函数
concat:连接
substr:截取字符串
upper/lower:大写、小写
repalce:替换
length:获取字节长度
trim:去前后空格
lpad/rpad:左右填充
instr:获取字串第一次出现的索引
2、数学函数
ceil:向上取整
round:四舍五入
mod:取整
floor:向下取整
truncat:阶段
rand:获取随机数
3、日期函数
date:
now:
year:
month:
day:
date_format:
curdate:
str_to_date:
curtime:
hour:
minute:
second:
datediff:两个时间相差天数
monthname:
4、其他函数
wersion:数据库服务器版本
database:当前打开数据库
password:返回该字符的密码形式
md5:返回该字符的md5加密形式
5、流程控制函数
if(条件表达式,表达式1,表达式2):如果条件表达式成立,返回1,否则返回2
case情况1
case 变量或表达式或字段
when 常量1 then 值1
when。。。。
else。。。
end
case 情况2
case
when 条件1 then 值1
when。。。。
else。。。
end
三、分组函数
1、分类
max:最大值
min:最小值
avg:平均值
sum:求和
count:计数
2、特点
1、语法
select max(字段)from 表名
2、支持的类型
sum和avg一般用于处理数值型
max、min、cuount可以处理任何数据类型
以上分组函数都忽略null
都可以和distinct使用,实现去重统计
count函数
conut(字段):统计该字段非空值的个数
count(*):统计结果集的行数
和分组函数一同查询的字符,要求group by后的字段
分组查询
语法:
select 分组函数,分组后的字段,
from 表
【where 筛选条件】
group by 分组的字段
【having 分组后的筛选】
【order by 排序列表】
特点
使用关键字 筛选的表 位置
分组前的筛选 where 原始表 group by的前面
分组后的筛选 having 分组后的结果 group by的后面
连接查询
含义:当查询中涉及到了多个表的字段,需要使用多表连接
语法
select 字段1,字段2
from 表1,表2;
笛卡尔乘积:当查询多个表时,没有添加有效的连接条件,导致多个表所有行实现全连接
分类:
按年代分类:
sql92:
等值、
语法:
select 查询列表
from 表1 别名,表二,别名
where 表1.key=表2.key
【and 筛选条件】
【group by 分组字段】
【having 分组后的筛选 】
【order by 排序自组但】
特点:
起别名
多表顺序可调换
n表连接至少需要n-1个链接条件
等值链接时多表的交集部分
非等值
select 查询列表
from 表1 别名,表二,别名
where 非等值的链接条件
【and 筛选条件】
【group by 分组字段】
【having 分组后的筛选 】
【order by 排序自组但】
、自连接
select 查询列表
from 表1 别名,表1,别名
where 表1.key=表1.key
【and 筛选条件】
【group by 分组字段】
【having 分组后的筛选 】
【order by 排序自组但】
也支持一部分外连接,但不稳定
sql99【推荐使用】:
内链接
等值,非等值,自连接
外连接
左外、右外、全外(不支持)
交叉连接
mysql进阶三四五六的更多相关文章
- mysql进阶(二十六)MySQL 索引类型(初学者必看)
mysql进阶(二十六)MySQL 索引类型(初学者必看) 索引是快速搜索的关键.MySQL 索引的建立对于 MySQL 的高效运行是很重要的.下面介绍几种常见的 MySQL 索引类型. 在数 ...
- Java进阶(三十六)深入理解Java的接口和抽象类
Java进阶(三十六)深入理解Java的接口和抽象类 前言 对于面向对象编程来说,抽象是它的一大特征之一.在Java中,可以通过两种形式来体现OOP的抽象:接口和抽象类.这两者有太多相似的地方,又有太 ...
- mysql进阶(三)游标简易教程
mysql游标简易教程 从mysql V5.5开始,进行了一次大的改变,就是将InnoDB作为默认的存储引擎.InnoDB支持事务,而且拥有相关的RDBMS特性:ACID事务支持,数据完整性(支持外键 ...
- 网站开发进阶(三十六)String.getBytes()方法中的中文编码问题
String.getBytes()方法中的中文编码问题 String的getBytes()方法是得到一个系统默认的编码格式的字节数组. getBytes("utf-8")得到一个U ...
- MYSQL进阶学习笔记六:MySQL视图的创建,理解及管理!(视频序号:进阶_14,15)
知识点七:MySQL视图的创建(14) 视图的定义: 什么是视图: 视图数由查询结果形成的一张虚拟的表. 什么时候要用到视图? 如果某个查询结果出现的非常频繁,也就是,要经常拿这个查询结果来做子查询. ...
- AngularJS进阶(三十六)AngularJS项目开发技巧之利用Service&Promise&Resolve解决图片预加载问题(后记)
AngularJS项目开发技巧之利用Service&Promise&Resolve解决图片预加载问题(后记) 前言 在"AngularJS项目开发技巧之图片预加载" ...
- mysql进阶(十六)常见问题汇总
mysql进阶(十六)常见问题汇总 MySQL视图学习: http://www.itokit.com/2011/0908/67848.html 执行删除操作时,出现如下错误提示: 出现以上问题的原因是 ...
- {MySQL数据库初识}一 数据库概述 二 MySQL介绍 三 MySQL的下载安装、简单应用及目录介绍 四 root用户密码设置及忘记密码的解决方案 五 修改字符集编码 六 初识sql语句
MySQL数据库初识 MySQL数据库 本节目录 一 数据库概述 二 MySQL介绍 三 MySQL的下载安装.简单应用及目录介绍 四 root用户密码设置及忘记密码的解决方案 五 修改字符集编码 六 ...
- 04 mysql 基础三 (进阶)
mysql 基础三 阶段一 mysql 单表查询 1.查询所有记录 select * from department; select * from student; select * from ...
随机推荐
- $.ajax防止多次点击重复提交的方法
第一种:使用$.ajaxPrefilter( [dataTypes], handler(options, originalOptions, jqXHR) ) 方法:$.ajaxPrefilter()方 ...
- 淘宝H5移动端解决方案
详细:http://www.w3cplus.com/mobile/lib-flexible-for-html5-layout.html ; (function(win, lib) { var doc ...
- Cocos2d-x v3.1 核心类Director,Scene,Layer和Sprite(六)
Cocos2d-x v3.1 核心类Director,Scene,Layer和Sprite(六) Scene就像一个舞台一样在上面会摆放各种的元素,有的是固定的比如说布景,道具都是固定不动的,但有的元 ...
- Cocos2d-x v3.1 坐标系统(五)
Cocos2d-x v3.1 坐标系统(五) 为了能够更好的布局以及了解对象所在的位置,我们必须对Cocos2d-x中的坐标有详细的了解,本篇文章主要就是了解Cocos中用到的坐标系统.学过数学的人都 ...
- PRD、MRD、BRD的含义
一.PRD的含义 英文简称,PRD(Product Requirement Document),PRD文档中文意思是:产品需求文档. PRD文档是产品项目由“概念化”阶段进入到“图纸化”阶段的最主要的 ...
- Centos install ICU, INTL for php
1. Install ICU from source wget http://download.icu-project.org/files/icu4c/56.1/icu4c-56_1-src.tgz ...
- 有些其他程序设置为从 Outlook 下载并删除邮件。为防止发生此意外情况,我们将这些邮件放入一个特殊的 POP 文件夹中
最近使用FOXMAIL接收MSN邮件时,发现有一些邮件收取不到,进到WEB页面,页面下方提示“你的邮件位于 POP 文件夹中!有些其他程序设置为从 Outlook 下载并删除邮件.为防止发生此意外情况 ...
- 深入理解计算机系统_3e 第二章家庭作业 CS:APP3e chapter 2 homework
初始完成日期:2017.9.26 许可:除2.55对应代码外(如需使用请联系 randy.bryant@cs.cmu.edu),任何人可以自由的使用,修改,分发本文档的代码. 本机环境: (有一些需要 ...
- Hadoop完全分布式集群环境搭建
1. 在Apache官网下载Hadoop 下载地址:http://hadoop.apache.org/releases.html 选择对应版本的二进制文件进行下载 2.解压配置 以hadoop-2.6 ...
- AJAX进行分页
新建数据集:PagingDataSet.xsd SELECT * from ( select id, areaID, area, father,Row_Number() over (order by ...