查询语法如下:

select...

from...

where...

group by...

(having)...

order by...;

顺序是from (从指定表中) where (具体条件) group by (分组依据) having (附加条件) select (查询) order by (结果排序)

单行处理函数主要包括:lower, upper, substr, length, trim, str_to_date, date_format, format, round, rand(), ifnull, concat

分组函数主要包括:sum, max, min, avg, count

例子:

来源于动力节点的例子,数据库文件是bjpowernode.sql,在官网就能下载到。

// 连接MySQL(首先确保MySQL服务已经运行,可以使用>net start MySQL来打开MySQL服务,也可以直接在服务中开启)
>mysql -u root(角色) -pXXXX (密码)  // 连接MySQL
>mysql -h (ip address) -P (port) -u root -pXXXX // 连接到远程MySQL
 
// 创建名为testdemo的数据库
mysql> create database testdemo;
 
// 查看MySQL的版本
mysql> select version();
 
// 进入名为testdemo的数据库
mysql> use testdemo;
 
// 将指定地址的SQL脚本文件导入到testdemo数据库,注意地址路径中不应包含中文
mysql> source C:\Users\Larissa\Desktop\bjpowernode.sql;
 
// 显示testdemo数据库中的表
mysql> show tables;
 
// 描述名为dept的表
mysql> desc dept;
 
// 从名为dept的表中查询全部数据
mysql> select * from dept;
 
// 从名为dept的表中查询deptno字段的数据
mysql> select deptno from dept;
 
// 从dept表中查询字段名为deptno的数据,并将deptno命名为Number,可以使用as或空格
mysql> select deptno as Number from dept;
mysql> select deptno Number from dept;
 
// 一条SQL语句可以查询多个字段,从dept表中查询字段名为deptno和dname的数据,并分别命名为Number和Name
mysql> select deptno as Number, dname as Name from dept;
 
// 从emp表中查询sal字段,并将sal数据乘以1.1,结果命名为newsal。查询可以进行数学运算
mysql> select sal*1.1 as newsal from emp;
 
// 条件查询,从emp表中查询sal大于2000的job和sal数据,并按照sal升序排列
mysal> select job,sal from emp where sal>2000 order by sal;
 
// 从emp表中查询sal小于3000的job,sal数据,并按照sal降序排列
mysql> select job,sal from emp where sal<3000 order by sal desc;
 
// 从emp表中查询sal大于3000同时job为MANAGER的ename,sal数据
mysql> select ename,sal from emp where sal>3000 and job='MANAGER';
 
// 从emp表中查询job为MANAGER或者为SALESMAN的ename,sal数据。注意in表示集合而不是区间
mysql> select ename, sal from emp where job='MANAGER' or job='SALESMAN';
mysql> select ename, sal from emp where job in ('MANAGER','SALESMAN');
// 注意这里如果使用not in的话,后面的集合中不应该包含null。
 
// 从emp表中查询sal大于1500同时job为MANAGER或者SALESMAN的ename,job,sal数据。注意and优先级高于or,不确定时请果断使用括号。
mysql> select ename,job,sal from emp where sal>1500 and (job='MANAGER' or job='SALMESMAN');
 
// 从emp表中查询comm是空的ename,sal,comm数据。注意null要用is,is not,而不能用=或者!=
mysql> select ename,sal,comm from emp where comm is null;
mysql> select ename,sal,comm from emp where comm is not null;
 
// 模糊查询,从emp表中查询ename最后一位是k的ename数据。%匹配任意多个字符
mysql> select ename from emp where ename like '%k';
 
// 从emp表中查询ename第二个字符为m的ename数据,_匹配一个字符。
mysql> select ename from emp where ename like '_m%';
 
// 从emp表中查询ename,sal数据并按照sal升序和ename升序排序,这意味着当两个sal相同时,将按照ename排序。
mysql> select ename,sal from emp order by sal asc, ename asc;
 
// 从emp表中查询sal在1250至3000之间的ename,sal数据并且按sal降序排列
mysql> select ename, sal from emp where sal between 1250 and 3000 order by sal desc;
 
// 使用处理函数对查询结果进行处理,从emp中查找ename,并将结果小写。
mysql> select lower(ename) from emp;
 
// 从emp表中查询ename,并截取从1(第一位不是0)开始,长度为2的字符串,然后转小写
mysql> select lower(substr(ename,1,2)) from emp;
 
// 从emp表中查名字首字母为s的员工名字
mysql> select ename from emp where substr(ename,1,1)='s';
 
// 从emp表中找到名字长度大于5个字符的员工名字
mysql> select ename from emp where length(ename)>5;
 
// 随机生成100以内的随机数
mysql> select round(rand()*100) from dept;
 
// 从emp表中查询ename,并计算加上comm的年薪。这里重点是使用ifnull可以将null转换为指定的值,这里是0
mysql> select ename,(sal+ifnull(comm,0))*12 as yearsal from emp;
 
// case when then when then else end的用法
mysql> select ename,job,sal as oldsal,
    -> (case job when 'MANAGER' then sal*1.1 when 'SALESMAN' then sal*1.5 else sal end) as newsal
    -> from emp;
 
// 分组函数的用法,注意,一定要先分组才能用分组函数,这意味着where后面不能用分组函数
mysql> select max(sal),sum(sal),avg(sal),count(ename) from emp;
mysql> select deptno,job,max(sal) from emp group by deptno,job;
 
// 过滤条件尽量用where实现
mysql> select deptno,max(sal) from emp where sal>3000 group by deptno;
 
// 实在无法用where实现的,用group by + having
mysql> select deptno,avg(sal) from emp where job!='MANAGER' group by job
    -> having avg(sal)>1500
    -> order by avg(sal) desc;
 
// 使用distinct关键字去除查询结果中的重复
mysql> select distinct job from emp;
mysql> select distinct job, deptno from emp;

MySQL常用查询命令(单表查询)的更多相关文章

  1. MySQL数据库篇之单表查询

    主要内容: 一.单表查询的语法 二.关键字的执行优先级 三.简单查询 四.where约束 五.分组查询 group by 六.having过滤 七.查询排序 order by 八.限制查询的记录数 l ...

  2. MySQL之单表查询 一 单表查询的语法 二 关键字的执行优先级(重点) 三 简单查询 四 WHERE约束 五 分组查询:GROUP BY 六 HAVING过滤 七 查询排序:ORDER BY 八 限制查询的记录数:LIMIT 九 使用正则表达式查询

    MySQL之单表查询 阅读目录 一 单表查询的语法 二 关键字的执行优先级(重点) 三 简单查询 四 WHERE约束 五 分组查询:GROUP BY 六 HAVING过滤 七 查询排序:ORDER B ...

  3. SQL基本查询_单表查询(实验二)

    SQL基本查询_单表查询(实验二) 查询目标表结构及数据 emp empno ename job hiedate sal comn deptno 1007 马明 内勤 1992-6-12 4000 2 ...

  4. SQL基础--查询之一--单表查询

    SQL基础--查询之一--单表查询

  5. mysql四-1:单表查询

    一.单表查询的语法 SELECT 字段1,字段2... FROM 表名 WHERE 条件 GROUP BY field HAVING 筛选 ORDER BY field LIMIT 限制条数 二.关键 ...

  6. mysql——查询语句——单表查询——(概念)

    一.基本查询语句 select的基本语法格式如下: select 属性列表 from 表名和视图列表 [ where 条件表达式1 ] [ group by 属性名1 [ having 条件表达式2 ...

  7. MySQL数据查询之单表查询

    单表查询 简单查询 - 创建表 DROP TABLE IF EXISTS `person`; CREATE TABLE `person` ( `id` ) NOT NULL AUTO_INCREMEN ...

  8. MySql(六)单表查询

    十.单表查询 一.单表查询的语法 SELECT 字段1,字段2... FROM 表名 WHERE 条件 GROUP BY field HAVING 筛选 ORDER BY field LIMIT 限制 ...

  9. (七)MySQL数据操作DQL:单表查询1

    (1)单表查询 1)环境准备 mysql> CREATE TABLE company.employee5( id int primary key AUTO_INCREMENT not null, ...

  10. MySQL简单查询和单表查询

    MySQL记录操作 概览 MySQL数据操作: DML 在MySQL管理软件中,可以通过SQL语句中的DML语言来实现数据的操作,包括 使用INSERT实现数据的插入 UPDATE实现数据的更新 使用 ...

随机推荐

  1. 从容器镜像的选择-alpine 说起

    在 容器崛起之前,Alpine 还是个无名之辈,可能是因为大家并不是很关心操作系统本身的大小,毕竟大家只关心业务数据和文档,程序.库文件和系统本身的大小通常可以忽略不计. 容器技术席卷整个软件产业之后 ...

  2. IoC容器-Bean管理(bean作用域)

    IoC操作Bean管理(bean作用域) 1,在Spring里面,设置创建bean实例是单实例还是多实例 2,在Spring里面,默认情况下,bean是单实例对象 3,如何设置单实例还是多实例 (1) ...

  3. IoC容器-Bean管理XML方式(注入集合类型属性)

    Ico操作Bean管理(xml注入集合属性) 1,注入数组类型属性 2,注入List集合类型属性 3,注入Map集合类型属性 (1)创建类,定义数组.list.map.set类型属性,生成对应set方 ...

  4. Avoiding the Backup of Online Redo Logs

    Although it may seem that you should back up online redo logs along with the datafiles and control f ...

  5. 带你十天轻松搞定 Go 微服务系列(六)

    序言 我们通过一个系列文章跟大家详细展示一个 go-zero 微服务示例,整个系列分十篇文章,目录结构如下: 环境搭建 服务拆分 用户服务 产品服务 订单服务 支付服务(本文) RPC 服务 Auth ...

  6. python02day

    回顾 1.编译型和解释型 编译型:一次性编译成二进制,再执行 执行效率高,但不能跨平台,开发效率低 代表语言:C 解释型:逐行解释成二进制,再执行 可以跨平台,开发效率高,但执行效率低 代表语言:py ...

  7. Hbase 项目

     需求分析 1) 微博内容的浏览,数据库表设计 2) 用户社交体现:关注用户,取关用户 3) 拉取关注的人的微博内容 表结构 代码实现 1) 创建命名空间以及表名的定义 2) 创建微博内容表 3) 创 ...

  8. JVM内存模型(五)

    一.JVM内存模型 1.1.与运行时数据区     前面讲过了运行时数据区那接下来我们聊下内存模型,JVM的内存模型指的是方法区和堆:在很多情况下网上讲解会把内存模型和运行时数据区认为是一个东西,这是 ...

  9. ApacheCN Linux 译文集(二) 20211206 更新

    CentOS7 Linux 服务器秘籍 零.前言 一.安装 CentOS 二.配置系统 三.管理系统 四.用 YUM 管理包 五.管理文件系统 六.提供安全性 七.构建网络 八.使用文件传输协议 九. ...

  10. 一步一步搭建基于ffmpeg和sdl2的流媒体播放器

    一.  背景: 一步一步从资料收集.技术选型.代码编写.性能优化,动手搭建一款支持rtsp.rtmp等常用流媒体格式的视频播放器,ffmpeg用于流媒体解码,sdl2用于视频画面渲染和声音播放. 二. ...