10. MySQL基础-02条件查询、排序查询
2. 条件查询
- 语法
select 查询列表 from 表名 where 筛选条件;
分类
按条件表达式筛选
简单的条件运算符:> < = != <> >= <=
按逻辑表达式筛选
逻辑运算符: &&,||,!; and,or ,not
模糊查询:like,between and, in
一般和通配符配合使用;
通配符:
% 任意多个字符包括0个字符
_ 任意单个字符
like:
查询姓名中包含a的信息
select * from student where name like ‘%a%’;
查询员工名第三个为字符为h,第五个字符也是 h的姓名与年龄
select name,age from student where name like ‘ __h_h’
查询姓名第二个字为_的信息
select name from student where name like ‘_$ _%’ DSCAPE $
DSCAPE转移字段(上例中$可以改为任何字符)
between and
使用between and 可以提高语句简介度
包含临界值
两个临界值不能交换顺序
select * from student where age>=10 and age<=12 相当于 select * from student where age between 10 and 12
in
使用in 可以提高语句简介度
in列表的值必须类型一致
select name,class from student where class=‘一班’ or class=‘二班’ or class=‘三班’;
相当于 select name,class from student where class in(‘一班’,‘二班’,‘三班’);
if null
<>,=不能去判断null的值
is null 和is not null可以判断null的值
select name,awards(奖项) from student where is null; 没有奖项
select name,awards from student where is not null; 有奖项
安全等于<=>
既可以判断是否为空又可以判断普通值
select name,awards(奖项) from student where <=> null; 没有奖项
可读性比较差,不建议使用
3. 排序查询
- 语法:
- SELECT 查询列表 FROM 表 【筛选条件】 order by 【asc|desc】
- 特点:
- asc代表的是升序,desc代表的是降序,如果不写,默认是升序
- 案例1(查询学生信息,要求英语成绩从低到高):
- SELECT * FROM student ORDER BY english(英语成绩) desc;
- 案例2(查询学生信息,年龄大于18,按入学时间升序)【筛选条件排序】
- SELECT * FROM student WHERE age>18 ORDER BY inschool(入学时间) asc;
- 案例3【按表达式排序】
- SELECT * ,(English+ifnull(fujia,0)) as 总成绩 FROM student ORDER BY (English+ifnull(fujia,0));
- 案例4【按别名名称排序】
- SELECT * ,(English+ifnull(fujia,0)) as 总成绩 FROM student ORDER BY 总成绩;
- 案例5【按姓名长度显示学生姓名和成绩】
- SELECT length(name) as 字节长度,name FROM sutdent ORDER BY length(name) DESC;
- 案例6(查询学生信息,先按语文成绩降序,再按年龄升序)【按多个字段排序
- SELECT * FROM student ORDER BY Chinese desc,age asc;
10. MySQL基础-02条件查询、排序查询的更多相关文章
- 【2017-03-10】Tsql语句基础、条件,高级查询
一.语句基础 1.创建数据库:create database 数据库名(不能汉字,不能数字.符号开头) 2.删除数据库:drop database 数据库名 3.选用数据库:use 数据库名 4.创建 ...
- 数据库MySQL--条件查询/排序查询
一.条件查询 条件查询:满足条件的字段被筛选出来 语法:select 查询列表字段 from 表名 where 筛选条件: 条件查询的条件分类: 1.按条件表达式筛选:条件运算符:>, < ...
- MYSQL基础02(查询)
查询是很大的一块,所以这里我只会写mysql的特点,就我目前使用的情况,MYSQL对标准SQL是比较支持,如果是新手的话,建议去w3school 学习标准SQL. 1.DUAL DUAL是一个虚拟表, ...
- mysql基础之日志管理(查询日志、慢查询日志、错误日志、二进制日志、中继日志、事务日志)
日志文件记录了MySQL数据库的各种类型的活动,MySQL数据库中常见的日志文件有 查询日志,慢查询日志,错误日志,二进制日志,中继日志 ,事务日志. 修改配置或者想要使配置永久生效需将内容写入配置文 ...
- mysql基础(3)-高级查询
聚合函数 count 返回查询结果的条数 max 返回查询结果的最大值 min 返回查询结果的最小值 sum 返回查询结果的和 avg 返回查询结果的平均值 统计分数大于等于90的人数: mysq ...
- MySql(五)select排序查询
举个栗子/**查询员工信息,要求工资按照从高到低进行排序(默认升序)**/SELECT * FROM employees ORDER BY salary ASC;/**方法2:**/SELECT * ...
- 【MySQL基础打卡(一)】查询语句项目作业
文章目录 1.查找email表中重复的电子邮箱 1.1 创建email数据表 1.2 找出重复Email 2.查找大国家 2.1 创建数据表 2.2 查找大国家 对于安装MySQL比较恐惧,所以想在虚 ...
- mysql5.5根据条件进行排序查询 TP5
用到了 order by if 和 count 使用的是TP5.0 $sql = Db::name('teacher') ->alias('t') ->join('user u', 'u. ...
- 学习日常笔记<day15>mysql基础
1.数据库入门 1.1数据库软件 数据库:俗称数据的仓库,方便管理数据的软件(或程序) 1.2市面上数据库软件 Oracle,甲骨文公司的产品. 当前最流行应用最广泛的数据库软件.和java语言兼容非 ...
随机推荐
- Java反射详解篇--一篇入魂
1.反射概述 Java程序在运行时操作类中的属性和方法的机制,称为反射机制. 一个关键点:运行时 一般我们在开发程序时,都知道自己具体用了什么类,直接创建使用即可.但当你写一些通用的功能时没办法在编写 ...
- uoj266[清华集训2016]Alice和Bob又在玩游戏(SG函数)
uoj266[清华集训2016]Alice和Bob又在玩游戏(SG函数) uoj 题解时间 考虑如何求出每棵树(子树)的 $ SG $ . 众所周知一个状态的 $ SG $ 是其后继的 $ mex $ ...
- vue&uniapp环境搭建以及项目创建(webstorm)
以下是针对webstorm用户上手uniapp框架的学习 vue环境搭建以及配置(脚手架搭建) 首先要明确三样东西 npm:node.js的包管理器 webpack:主要用途是通过CommonJS 的 ...
- 22.1.7 master公式及O(NLogN)的排序
22.1.7 master公式及O(NLogN)的排序 1 master 公式 (1) 写公式 T(N) = a * T(N/b) + O(N^d); master公式用来求递归行为的时间复杂度,式中 ...
- 从零开始,开发一个 Web Office 套件(14):复制、粘贴、剪切、全选
这是一个系列博客,最终目的是要做一个基于 HTML Canvas 的.类似于微软 Office 的 Web Office 套件(包括:文档.表格.幻灯片--等等). 博客园:<从零开始, 开发一 ...
- Kafka学习(二)
作者:程序员cxuan链接:https://www.zhihu.com/question/53331259/answer/1262483551来源:知乎著作权归作者所有.商业转载请联系作者获得授权,非 ...
- 两个对象值相同(x.equals(y) == true),但却可有不同的hash code,这句话对不对?
对. 因为equals()方法可以用开发者重写,hashCode()方法也可以由开发者来重写,因此它们是否相等并没有必然的关系. 如果对象要保存在HashSet或HashMap中,它们的equals( ...
- 序列化接口的id有什么用?
反序列化Java对象时必须提供该对象的class文件,现在的问题是随着项目的升级,系统的class文件也会升级,Java如何保证两个class文件的兼容性? Java序列化机制允许为序列化类提供一个p ...
- mac idea
sout :按Tab或Enter都可以出现
- java线程池源码分析
我们在关闭线程池的时候会使用shutdown()和shutdownNow(),那么问题来了: 这两个方法又什么区别呢? 他们背后的原理是什么呢? 线程池中线程超过了coresize后会怎么操作呢? 为 ...