单表查询

最简单的查询语句

select * from dept

select * from emp;
– 显示部分列
select empno,ename,sal ,comm,deptno from emp
– 显示部分行 where
select empno,ename,sal ,comm,deptno from emp where sal<2500

– 别名
select empno 编号,ename 姓名,sal 工资 ,comm 补助,deptno 部门编号 from emp where sal<2500
– as可以省略 alias 别名
select empno as 编号,ename as 姓名,sal as 工资 ,comm as 补助,deptno as 部门编号 from emp where sal<2500

select empno ‘编 号’,ename “姓 名”,sal SALARY ,comm 补助,deptno 部门编号 from emp where sal<2500

– 算术运算
select empno,ename,sal ,comm,sal1.1, deptno from emp where sal<2500
– update emp set sal = sal
1.1
select empno,ename,sal ,comm,sal*1.1, sal+comm ,deptno from emp where sal<2500 – ???

– 去重 distinct
select job from emp
select distinct job from emp
select job,deptno from emp

– 自动对后面所有列去重
select distinct job,deptno from emp

– 排序 order by
select * from emp – Oracle 并不一定按照主键排序 MySQL中按照主键排序
select * from emp order by empno – 指定按照主键排序
select * from emp order by empno asc – asc 升序排列 可以省略 默认升序
select * from emp order by sal desc – desc 降序排列 de-asc
select * from emp order by sal desc ,hiredate – 日期的大小是数值,不是早晚

– desc emp

where子句

– 最简单的条件? 关系运算符
select * from emp
select * from emp where deptno = 10
select * from emp where deptno < 10
select * from emp where deptno <= 10
select * from emp where deptno <> 10
select * from emp where deptno != 10
select * from emp where job = ‘CLERK’
select * from emp where job = ‘clerk’
select * from emp where binary job = ‘clerk’ – binary 区分大小写
select * from emp where hiredate < ‘1981-12-25’

– 逻辑运算符 and
select * from emp where sal >1500 and sal <3000
select * from emp where sal >1500 and sal <3000 order by sal
select * from emp where sal >=1500 and sal <=3000

select * from emp where sal between 1500 and 3000 – [1500,3000]

select * from emp where job = ‘CLERK’ and deptno = 20
select * from emp where job = ‘CLERK’ && deptno = 20
– 逻辑运算符 or
select * from emp where deptno = 10 or deptno = 20
select * from emp where deptno = 10 || deptno = 20

select * from emp where deptno in (10,20)
select * from emp where job in (‘CLERK’,‘MANAGER’,‘ANALYST’) order by job
select * from emp where job = ‘CLERK’ or deptno = 20

– 模糊匹配 % _
– % 代表任意多个字符 0,1,2 …
select * from emp where ename like ‘%A%’; – like
– _ 任意一个字符
select * from emp where ename like ‘__A%’
select * from emp where ename not like ‘__A%’

– null
select * from emp where comm is null

select * from emp where comm is not null

– 小括号 ()
select * from emp where job=‘SALESMAN’ or job=‘CLERK’ and sal>=1280 – 优先级别 先and 再or
select * from emp where (job=‘SALESMAN’ or job=‘CLERK’) and sal>=1280 – 改变运算顺序
select * from emp where job=‘SALESMAN’ or (job=‘CLERK’ and sal>=1280) – 提高可读性

单行函数

– 使用函数
select empno, ename,lower(ename),upper(ename),sal from emp

select max(sal),min(sal),count(sal),sum(sal),avg(sal) from emp

– 函数作用:提高select查询数据的能力
– 函数不会修改数据库表的数据

– 函数的分类
– 单行函数 lower(ename),upper(ename)
– 多行函数 max(sal),min(sal),count(sal),sum(sal),avg(sal)
– 区别1:是对单行还是多行进行操作,而不是指结果有几行
– 区别2:除了多行函数(max(sal),min(sal),count(sal),sum(sal),avg(sal)),都是单行函数

– 单行函数
– 字符串函数
select ename,length(ename),substring(ename,2,3) from emp – 索引从1开始

– 数值函数
select abs(-5),ceil(5.4),floor(5.6),round(3.14) from dual – dual 伪表 虚拟表 为了练习函数

select abs(-5),ceil(5.4),floor(5.6),round(3.14) – 如果没有where条件,from dual都可以省略

select 10/3,-10%-3,mod(-10,3) from dual

– 日期与时间函数
select * from student – 1999-12-23
select curdate(),curtime()
select now(),sysdate() ,sleep(3),now(),sysdate() from dual
insert into student values (null,‘zhangsan’,‘男’,23,now(),‘Java001’,‘zh@sxt.cn’)
insert into student values (null,‘zhangsan’,‘男’,23,sysdate(),‘Java001’,‘zh2@sxt.cn’)
desc student

– 流程函数
select empno,ename,sal,if(sal>=2500,‘high’,‘low’) as grade from emp order by grade – if–else
select empno,ename,sal,comm,sal+ifnull(comm,0) from emp – if
select nullif(1,1),nullif(1,2)

多行函数

– 单行流程函数
select * from emp

– case 等值判断 switch
select empno,ename,job,
case job
when ‘CLERK’ then ‘店员’
when ‘SALESMAN’ then ‘销售’
when ‘MANAGER’ then ‘经理’
else ‘其他’
end ‘岗位’,
sal from emp

– case 区间判断 if-else if - else if—else
select empno,ename,sal ,
case
when sal<=1000 then ‘A’
when sal <=2000 then ‘B’
when sal <=3000 then ‘C’
else ‘D’
end 等级
from emp

– 其他函数
select database(),user(),version()
select password(“bjsxt”) – MySQL8中不再支持password()

– 多行函数
select * from emp
select max(sal),min(sal),count(sal),sum(sal),avg(sal) from emp
– 多行函数会自动的忽略null值
select max(comm),min(comm),count(comm),sum(comm ),avg(comm) from emp
– max() min() count() 针对所有数据类型,sum() avg() 只针对数值类型
select max(ename),min(ename),count(ename) from emp
select ename,sal from emp
select count(ename),max(sal) from emp

select * from emp
-- 统计表的记录数
select count(*) from emp
select count(*) from dept
--  只有count支持*
select count(*) from emp select 1 from dual
select 1 from emp 
-- 统计表的记录数(推荐使用)
select count(1) from emp

分组和having

– 统计各个部门的平均工资(只显示平均工资2000以上的)
select avg(sal) from emp – 1
select deptno from emp – 14
– 字段、多行函数不能共存,除非使用分组,除非这个字段出现子分组语句中
select deptno,avg(sal)
from emp

– 字段、多行函数不能共存,除非使用分组,除非这个字段出现子分组语句中
select deptno,avg(sal),count(1)
from emp
group by deptno
– where avg(sal) > 2000
having avg(sal)>2000
order by max(sal)

– select * from emp order by deptno

– 统计各个岗位的平均工资,除了MANAGER
select job,avg(sal),count(1)
from emp
where job != ‘MANAGER’
GROUP BY JOB
order by avg(sal) desc

select job,avg(sal)
from emp
group by job
having job != ‘MANAGER’
– order by avg(sal) desc
order by job

– where子句中不能出现多行函数

单表查询总结案例

– 统计各个部门的平均工资(只显示平均工资2000以上的)
select avg(sal) from emp – 1
select deptno from emp – 14
– 字段、多行函数不能共存,除非使用分组,除非这个字段出现子分组语句中
select deptno,avg(sal)
from emp

– 字段、多行函数不能共存,除非使用分组,除非这个字段出现子分组语句中
select deptno,avg(sal),count(1)
from emp
group by deptno
– where avg(sal) > 2000
having avg(sal)>2000
order by max(sal)

– select * from emp order by deptno

– 统计各个岗位的平均工资,除了MANAGER
select job,avg(sal),count(1)
from emp
where job != ‘MANAGER’
GROUP BY JOB
order by avg(sal) desc

select job,avg(sal)
from emp
group by job
having job != ‘MANAGER’
– order by avg(sal) desc
order by job

– where子句中不能出现多行函数

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/325156.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

ssl1072-砝码称重【dp练习】

Description 设有1g、2g、3g、5g、10g、20g的砝码各若干枚&#xff08;其总重<1000&#xff09;&#xff0c; 要求&#xff1a; 输入方式&#xff1a;a1 a2 a3 a4 a5 a6 &#xff08;表示1g砝码有a1个&#xff0c;2g砝码有a2个&#xff0c;…&#xff0c;20g砝码有a6个&…

java中遍历树形菜单,你可能不知道还有这样的方法

版权声明&#xff1a;本文为CSDN博主「穆雄雄」的原创文章&#xff0c;遵循CC 4.0 BY-SA版权协议&#xff0c;转载请附上原文出处链接及本声明。原文链接&#xff1a;https://blog.csdn.net/qq_34137397/article/details/72654955穆雄雄开发工具&#xff1a;MyEclipse 10.5后台…

Docker-Compose 一键部署Ningx+.Net Core+Redis集群

在看该文章前&#xff0c;你需要对Docker有所了解。 1、创建WebApp应用程序 我使用的是.Net Core 1.0.1版本&#xff0c;创建一个MVC应用程序&#xff0c;并添加对Redis的引用。因为这些很基础&#xff0c;也很简单&#xff0c;这里就不详细说明了&#xff0c;特别提一下有关多…

JavaFX官方教程(十四)之转换,动画和视觉效果教程的源代码

翻译自 转换&#xff0c;动画和视觉效果教程的源代码 下表列出了本文档中的演示应用程序及其关联的源代码文件。 教程源代码NetBeans项目文件 转换概述 Xylophone.java transformations.zip 动画基础知识 animations.zip 树动画示例 tree_animation.zip 创建视觉效…

ssl2294-打包【dp练习】

Description 你现在拿到了许多的礼物&#xff0c;你要把这些礼物放进袋子里。你只有一个最多装下V 体积物品的袋子&#xff0c;你不能全部放进去。你也拿不动那么重的东西。你估计你能拿的最大重量为 G。现在你了解了每一个物品的完美值、重量和体积&#xff0c;你当然想让袋子…

《走遍中国》珍藏版(三)

Console.WriteLine("上一本书已经看完&#xff0c;从今天开始看下一本"); System.out.println("《走遍中国》珍藏版"); System.out.println("这本书是关于地理的"); System.out.println("地理往往是和历史进行紧密联系的");长廊的油漆…

Catalog Service - 解析微软微服务架构eShopOnContainers(三)

上一篇我们说了Identity Service&#xff0c;因为其基于IdentityServer4开发的&#xff0c;所以知识点不是很多&#xff0c;今天我们来看下Catalog Service&#xff0c;今后的讲解都会把不同的、重点的拿出来讲&#xff0c;希望大家明白。 源码分析 我们先看下它的目录结构&a…

JavaFX官方教程(十五)之A Xylophone.java

翻译自 Xylophone.java 一个 Xylophone.java 有关说明&#xff0c;请参阅转换类型和示例。 法律条款和版权声明 / **版权所有&#xff08;c&#xff09;2010,2014&#xff0c;Oracle和/或其附属公司。* 版权所有。使用须遵守许可条款。**此文件可通过以下许可证获得并获得许…

索引,事务,视图

索引 此时是要获取所有的数据&#xff0c;是否有索引作用不大 select * from emp – 因为数据库以及自动的给主键列empno创建了索引&#xff0c;查询条件中出现empno&#xff0c;自动使用索引进行查询 – 是否使用索引&#xff0c;语句没有区别 select * from emp where empno…

配置环境变量 path

原理 根据windows系统在查找可执行程序的原理&#xff0c;可以将java工具所在路径定义到path 环境变量中&#xff0c;让系统帮我们去找运行执行的程序。 配置方法 我的电脑–属性–高级系统设置–环境变量 编辑 path 环境变量&#xff0c;在变量值开始处加上java工具所在目录…

ssl2863-石子合并【dp练习】

Description 在一个操场上一排地摆放着N堆石子。现要将石子有次序地合并成一堆。规定每次只能选相邻的2堆石子合并成新的一堆&#xff0c;并将新的一堆石子数记为该次合并的得分。请设计一个程序&#xff0c;计算出将N堆石子合并成一堆的最小得分。 Input 每组数据第1行为一个…

《走遍中国》珍藏版(四)

Console.WriteLine("上一本书已经看完&#xff0c;从今天开始看下一本"); System.out.println("《走遍中国》珍藏版"); System.out.println("这本书是关于地理的"); System.out.println("地理往往是和历史进行紧密联系的");游走其中&a…

前端框架选型

前面的话 有一个流传较广的笑话&#xff0c;一个人在stackoverflow中提了一个问题&#xff0c;如何使用javascript实现一个数字与另外一个数字相加。最高票回答是你应该使用jQuery插件&#xff0c;jQuery插件可以做任何事情。 历史总是在重演&#xff0c;以前是jQuery&#xff…

JavaFX UI控件教程(一)之简述

翻译自 JavaFX UI控件概述 关于本教程 本教程介绍JavaFX API中提供的内置JavaFX UI控件。 该文件包含以下章节&#xff1a; JavaFX UI控件 标签 按钮 单选按钮 切换按钮 复选框 选择框 文本域 密码框 滚动条 滚动面板 列表视图 表视图 树视图 组合框 分隔器…

断言、触发器、存储过程

断言 assertion 设置每一门课程最多有60人选修 create assertion a check (60 > all ( select count(*) from sc group by cno) ); drop assertion a; 触发器 trigger 删除触发器 drop tigger a on student 存储过程 定义一个没有返回值的存储过程 create procedure my…

《走遍中国》珍藏版(五)

Console.WriteLine("上一本书已经看完&#xff0c;从今天开始看下一本"); System.out.println("《走遍中国》珍藏版"); System.out.println("这本书是关于地理的"); System.out.println("地理往往是和历史进行紧密联系的");陕西&#…

ssl1007 and ssl -最大乘积 and 加法最大【区间dp练习】

Description   今年是国际数学联盟确定的“2000——世界数学年”&#xff0c;又恰逢我国著名数学家华罗庚先生诞辰90周年。在华罗庚先生的家乡江苏金坛&#xff0c;组织了一场别开生面的数学智力竞赛的活动&#xff0c;你的一个好朋友XZ也有幸得以参加。活动中&#xff0c;主…

一个java源文件中可以声明多少个class与编译后会生成多少个字节码文件

在一个java源文件中可以声明多个class。 但是&#xff0c;只能最多有一个类声明为public的。 而且要求声明为public的类的类名必须与源文件名相同。 编译的过程 编译以后&#xff0c;会生成一个或多个字节码文件。字节码文件的文件名与java源文件中的类名相同。 运行 只能运…

用户管理

用户管理 查询用户 use mysql select * from user use mydb select * from mysql.user – 创建用户 create user ‘zhangsan’ identified by ‘zhangsan’ – create user ‘用户名’‘主机名’ identified by ‘密码’ create user ‘lisi’‘localhost’ identified by ‘…

JavaFX UI控件教程(二)之JavaFX UI控件

翻译自 JavaFX UI控件 本章概述了通过API提供的JavaFX UI控件。 JavaFX UI控件是使用场景图中的节点构建的。因此&#xff0c;控件可以使用JavaFX平台的视觉丰富功能。由于JavaFX API完全用Java实现&#xff0c;因此您可以轻松地将JavaFX UI控件集成到现有的Java应用程序中…