数据库基础知识——DQL语言(一)

文章目录

      • 1.基础查询
      • 2.条件查询
      • 3.排序查询
      • 4.常见函数
        • 4.1 单行函数
          • 4.1.1 字符函数
          • 4.1.2 数学函数
          • 4.1.3 日期函数
          • 4.1.4 流程控制函数
          • 4.1.5 其他函数
        • 4.2 分组函数/统计函数/聚合函数
      • 5.分组查询

1.基础查询

语法:
SELECT 要查询的东西
【FROM 表名】;
#查询employees表中所有字段
select * from employees;#查询employees表中的first_name字段
select first_name from employees;#查询employees表中的多个字段
select first_name,salary FROM employees;#查询常量值
select 100+123;
select "zhaoxr"#查询表达式
select 100*98;#查询函数
select version();#起别名
select 98*98 as result;
select last_name as "姓",first_name as "名" from employees;
select last_name "姓",first_name "名" from employees;#去重
select distinct department_id from employees;# +的作用
select 100+99;
select "123"+99;
select "zhaoxr"+"linux";
select null+16;# concat函数
select concat(last_name," ",first_name) "姓名" from employees;
类似于Java中 :System.out.println(要打印的东西);
特点:
① 通过select查询完的结果 ,是一个虚拟的表格,不是真实存在
② 要查询的东西 可以是常量值、可以是表达式、可以是字段、可以是函数

2.条件查询

条件查询:根据条件过滤原始表的数据,查询到想要的数据
语法:
select 要查询的字段|表达式|常量值|函数
from 表
where 条件 ;分类:
一、条件表达式示例:salary>10000条件运算符:> < >= <= = != <>二、逻辑表达式
示例:salary>10000 && salary<20000逻辑运算符:and(&&):两个条件如果同时成立,结果为true,否则为falseor(||):两个条件只要有一个成立,结果为true,否则为falsenot(!):如果条件成立,则not后为false,否则为true三、模糊查询
like
between and
in
is null | is not null通配符:
%:任意多个字符,包含0个字符
_:单个字符
\:转义字符,"\_"代表字符_示例:last_name like 'a%'
# 查询工资大于等于12000的员工ID,姓名和薪水
select employee_id,CONCAT(last_name," ",first_name) as "姓名",salary 
from employees
where salary>=12000;# 查询部分编号不等于90的员工姓名和部门编号
select CONCAT(last_name," ",first_name) as "姓名",department_id
from employees
where department_id!=90;#查询工资在10000到20000之间的员工ID,姓名和工资
select employee_id,concat(last_name," ",first_name) as "姓名",salary
from employees
where salary>=10000 and salary<=20000;#查询员工姓中含有a的员工信息
select *
from employees
where last_name like "%a%";#查询员工姓第三个字母是l,第五个是e的员工信息
select *
from employees
where last_name like "__l_e%"; #查询员工姓的第二个字符是_的员工信息
select *
from employees
where last_name like "_\_%";#查询员工ID在100到200之间的员工信息,包含100和200
select *
from employees
where employee_id between 100 and 200;#查询工种编号是IT_PROG,PU_CLERK,ST_CLERK的员工信息
select *
from employees
where job_id in("IT_PROG","PU_CLERK","ST_CLERK");#查询奖金率为null的员工信息
select *
from employees
where commission_pct is null;

3.排序查询

语法:
select要查询的东西
from表
where 条件order by 排序的字段|表达式|函数|别名 【asc|desc】
#查询员工信息,工资由低到高排列
select *
from employees
order by salary asc;#查询员工信息,部门编号大于等于90,并且按照入职先后排列
select *
from employees
where department_id>=90
order by hiredate asc;#查询员工信息和年薪,并按照年薪从低到高排列
select *,salary*12*(1+ifnull(commission_pct,0)) as "年薪"
from employees
order by salary*12*(1+ifnull(commission_pct,0)) asc;#查询员工的姓名和工资,按照姓名的长度从小到大排列
select CONCAT(last_name," ",first_name) as "姓名",length(concat(last_name," ",first_name)) as "姓名长度",salary
from employees
order by length(concat(last_name," ",first_name)) asc;#查询员工信息,先按工资从低到高排名,再按员工编号从低到高排序
select *
from employees
order by salary asc,employee_id asc;

4.常见函数

4.1 单行函数

4.1.1 字符函数
	concat拼接substr截取子串upper转换成大写lower转换成小写trim去前后指定的空格和字符ltrim去左边空格rtrim去右边空格replace替换lpad左填充rpad右填充instr返回子串第一次出现的索引length 获取字节个数
#length函数|查询员工的姓,以及姓的长度
select last_name,length(last_name)
from employees;#concat函数|查询员工的姓名
select concat(last_name," ",first_name) as "姓名"
from employees;#upper函数和lower函数|查询员工的姓名,姓大写,名小写
select concat(upper(last_name)," ",lower(first_name)) as "姓名"
from employees;#substr截取函数|注意:截取函数从1开始
#返回"i love china"中的"china"
select substr("i love china",8);#返回"我爱你中国"中"中国"
select substr("我爱你中国",4);#返回"i love china"中的"love"
select substr("i love china",3,4);#instr返回子串第一次出现的索引|返回"i love china"中的'c'在第几个位置
select instr("i love china","c");#trim去空格|删除"  love   "左右的空格
select trim("   love   ");#trim去除指定的字符|删除"aaaaaloveaaaa"左右的'a'
select trim('a' from "aaaaaaaloveaaaaa");#lpad填充|使用'0'填充字符"我爱你",总字符数10个,填充结果为"0000000我爱你"
select lpad("我爱你",10,'0');#replace替换|将"我爱china",替换为"我爱中国"
select replace("我爱china","china","中国");
4.1.2 数学函数
	round 四舍五入rand 随机数floor向下取整ceil向上取整mod取余truncate截断
#数学函数
#round四舍五入|2.55四舍五入保留整数部分
select round(2.55);#ceil向上取整,返回>=该数的最小整数|取整2.0001,2.0000
select ceil(2.0001),ceil(2.0000);#floor向下取整,返回<=该数的最大整数|取整-2.0001,2.0000
select floor(-2.0001),floor(2.0000);#truncate截断,保留小数几位|1.99999保留两位小数
select truncate(1.99999,2);#mod取余|10/3的余数
select mod(10,3);
4.1.3 日期函数
	now当前系统日期+时间curdate当前系统日期curtime当前系统时间str_to_date 将字符转换成日期date_format将日期转换成字符

在这里插入图片描述

#时间函数
#查询当前时间
select now();#获取指定的年月日,获取当前年份,月份,日
select year(now()) as "年",month(now()) as "月",day(now()) as "日";#获取员工姓名和入职年份
select concat(last_name," ",first_name) as "姓名",year(hiredate) as "入职年份"
from employees;#str_to_date将日期格式的字符转换为规定的日期格式,规定的日期格式"2021-04-29"
select str_to_date("2021年4月29日","%Y年%m月%d日"),str_to_date("04/29/2021","%m/%d/%Y");#date_format将日期转换为自己想要的日期字符|查询员工的姓名和入职时间,入职时间显示为"2021年4月29日"的格式
select concat(last_name," ",first_name) as "姓名",date_format(hiredate,"%Y年%m月%d日") as "日期"
from employees;
4.1.4 流程控制函数
	if 处理双分支if(判断条件,真就执行此处,假就执行此处)case 要判断的字段或者表达式when 常量1 then 要显示的值1或者语句1when 常量2 then 要显示的值2或者语句2。。。。。else 要显示的值n或者语句nendcase when 条件1 then 要显示的值1或者语句1when 条件2 then 要显示的值2或者语句2。。。。。else 要显示的值n或者语句nend
#流程控制函数
#if函数|查询员工的姓,奖金率,如果有奖金,返回有奖金,没有奖金返回没奖金
select last_name,commission_pct,if(commission_pct is null,"没奖金","有奖金") as "奖金"
from employees;#case|查询员工的姓名,工资,部门ID#如果部门=90,salary*1.1;如果部门=100,salary*1.2;如果部门=110,salary*1.3;其它salary不变;并显示
select concat(last_name," ",first_name),department_id,salary as "原始工资",case department_idwhen 90 then salary*1.1when 100 then salary*1.2when 110 then salary*1.3else salaryend as "当前工资"
from employees;#case|查询员工的姓名,工资#如果工资小于10000,显示低工资;#如果工资大于等于10000,小于20000,显示中等工资;#如果工资大于等于20000,显示高工资
select concat(last_name," ",first_name),salary,case when salary<10000 then "低工资"when salary>=10000 and salary<20000 then "中等工资"when salary>20000 then "高工资"end as "工资区间"
from employees;
4.1.5 其他函数
	version版本database当前库user当前连接用户
#其它函数
#version查看版本号
select version();#database查看当前数据库
select database();#user查看当前用户
select user();

4.2 分组函数/统计函数/聚合函数

	sum 求和max 最大值min 最小值avg 平均值count 计数
#分组函数
#简单使用
select sum(salary) as "总工资",max(salary) as "最高工资",min(salary) as "最低工资",avg(salary) as "平均工资",count(salary) as "工资个数"
from employees;#查询有多少中工资
select count(distinct salary)
from employees;#查询employees表有多少行
select count(*) as "行数",count(1) as "行数"
from employees;
	特点:1、以上五个分组函数都忽略null值,除了count(*)2、sum和avg一般用于处理数值型max、min、count可以处理任何数据类型3、都可以搭配distinct使用,用于统计去重后的结果4、count的参数可以支持:字段、*、常量值,一般放1建议使用 count(*)

5.分组查询

语法:
select 查询的字段,分组函数
from 表
group by 分组的字段特点:
1、可以按单个字段分组
2、和分组函数一同查询的字段最好是分组后的字段
3、分组筛选针对的表	位置			关键字
分组前筛选:	原始表		group by的前面		where
分组后筛选:	分组后的结果集	group by的后面		having4、可以按多个字段分组,字段之间用逗号隔开
5、可以支持排序
6、having后可以支持别名
#查询每个部门的平均工资
select avg(salary),department_id
from employees
group by department_id;#查询每个工种的最高工资
select max(salary),job_id
from employees
group by job_id;#查询工资大于10000的每个工种的最高工资
select max(salary),job_id
from employees
where salary>10000
group by job_id;#查询哪个部门员工的个数大于2
select count(*),department_id
from employees
group by department_id
HAVING count(*)>2;#按员工的姓名长度分组,查询每一组员工的个数,筛选员工个数大于5的有哪些
select count(*),length(last_name) as "len_name"
from employees
group by length(last_name)
having count(*)>5;#查询每个部门每个工种的平均工资
select avg(salary),department_id,job_id
from employees
group by department_id,job_id;#查询每个部门每个工种的平均工资,并按照降序排列
select avg(salary),department_id,job_id
from employees
group by department_id,job_id
order by avg(salary) desc;

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

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

相关文章

Linux安装MariaDB(Mysql)和简单配置

安装MariaDB 安装命令yum -y install mariadb mariadb-server安装完成MariaDB&#xff0c;首先启动MariaDBsystemctl start mariadb设置开机启动systemctl enable mariadbMariaDB的相关简单配置mysql_secure_installation首先是设置密码&#xff0c;会提示先输入密码Enter curr…

数据库基础知识——DQL语言(二)

文章目录1.多表连接查询1.1 sql92语法1.1.1 等值连接1.1.2 sql92:非等值连接1.1.3 sql92:自连接1.2 sql99语法1.2.1 等值连接1.2.2 非等值连接1.2.3 内连接1.2.4 左右连接&#xff08;外连接&#xff09;2.子查询2.1 where或者having后面3.分页查询4.联合查询1.多表连接查询 笛…

周志华教授发表首届国际学习与推理联合大会IJCLR开场Keynote:探索从纯学习到学习+推理的AI...

周志华&#xff0c;毕业于南京大学&#xff0c;欧洲科学院外籍院士&#xff0c;国家杰出青年基金获得者&#xff0c;现任南京大学人工智能学院院长、南京大学计算机软件新技术国家重点实验室常务副主任、机器学习与数据挖掘研究所 (LAMDA)所长、人工智能教研室主任。2021年8月1…

第八章 指针实验

C程序实验报告 实验项目&#xff1a; 1、指针基础及指针运算 2、数据交换 3、字符串反转及字符串连接 4、数组元素奇偶排列 姓名&#xff1a;曹时仙 实验地点&#xff1a;教学楼514教室 实验时间&#xff1a;2019.6.12 一、实验目的与要求 1、掌握指针的概念和定义方法 2、掌…

大脑的学习方式如何,机器学习与生物学习的联系将提供「答案」

来源&#xff1a;ScienceAI编辑&#xff1a;凯霞准确指出神经活动如何随着学习而变化&#xff0c;不是黑白分明的。有人认为大脑中的学习或生物学习可以从优化的角度来考虑&#xff0c;这就是在计算机或机器人等人工网络中学习的方式。由卡内基梅隆大学和匹兹堡大学的研究人员共…

数据库基础知识——DML语言

文章目录1.插入2.修改3.删除1.插入 语法&#xff1a; insert into 表名(字段名&#xff0c;...) values(值1&#xff0c;...);特点&#xff1a; 1、字段类型和值类型一致或兼容&#xff0c;而且一一对应 2、可以为空的字段&#xff0c;可以不用插入值&#xff0c;或用null填…

Go语言交叉编译工具gox

基本介绍 交叉编译是为了在不同平台编译出其他平台的程序&#xff0c;比如在Linux编译出Windows程序&#xff0c;在Windows能编译出Linux程序&#xff0c;32位系统下编译出64位程序&#xff0c;今天介绍的gox就是其中一款交叉编译工具。 配置环境 首先配置好Go语言的环境变量&a…

登顶Nature | DeepMind用AI首次实现数学领域重大进展,助力科学家证实两大猜想

来源&#xff1a;AI科技评论作者&#xff1a;杏花、莓酊编辑&#xff1a;琰琰数论是人类知识最古老的一个分支&#xff0c;然而它最深奥的秘密与其最平凡的真理是密切相连的。数学原理极易从事实中归纳出来&#xff0c;但证明却隐藏的极深。可以说数学&#xff0c;是一切科学的…

C++学习——类的多态

文章目录1.重载多态1.1 函数重载1.2 运算符重载2.强制多态3.类型参数化多态4.包含多态类的多态 多态是指同样的消息被不同类型的对象接收时导致不同的行为。 所谓消息是指对类成员函数的调用&#xff0c;不同的行为是指不同的实现&#xff0c;也就是调用了不同的函数。 在C中&a…

细胞如何获得秩序?除了形成细胞器,还可以发生相分离

来源&#xff1a;集智俱乐部作者&#xff1a;Viviane Callier译者&#xff1a;王百臻 审校&#xff1a;梁金 编辑&#xff1a;邓一雪 导语小小的细胞实际上是一个无比复杂的宇宙。DNA在细胞核中运筹帷幄&#xff0c;指导各种细胞器密切合作&#xff0c;产生功能各异的蛋白质。…

JS设置cookie、读取cookie、删除cookie

cookie是网站设计者放置在客户端的小文本文件&#xff0c;一般后台语言使用的比较多&#xff0c;可以实现用户个性化的一些需求。 javascript使用 document.cookie 来操作cookie同一个域名下的页面,共有一个cookie不同的浏览器分别管理自己的cookie,互不影响1.设置cookie // 设…

数据库基础知识——DDL语言

1.库的管理&#xff1a; 一、创建库 create database 库名#创建一个books库 create database books二、删除库 drop database 库名 三、修改库 rename database 旧库名 to 新库名2.表的管理&#xff1a; 2.1 创建表 CREATE TABLE IF NOT EXISTS stuinfo(stuId INT,stuName V…

从人类交互通信发展简史看元宇宙发展趋势及商业价值

来源&#xff1a;科协频道从通信角度来看&#xff0c;人类社会通信方式的发展历程和趋势&#xff0c;它一共经历了以下几个阶段&#xff1a;通信方式的发展历程和趋势第一阶段几千年以前的人类通过口口相传的方式&#xff0c;实现人与人之间的通信&#xff0c;这种通信方式的深…

字符设备驱动

1 引言 APP&#xff1a;open("/dev/xxx")&#xff0c;read&#xff0c;write    ——  设备字符驱动文件包含属性、主设备号和次设备号C LibrarySystem call interface内核&#xff1a;根据文件类型为字符设备&#xff0c;查找字符设备。根据主设备号查找file_…

yii2的Console定时任务创建

https://www.cnblogs.com/dwj97/p/6632848.html 设置定时任务 linux下&#xff0c;运行crontab -e 30 21 * * * /usr/local/php/bin/php /your_project_path/yii test/test //应用程序 上面的例子表示每晚的21:30执行上面的定时程序 下面是定时任务设置的一些基本介绍 基本格…

数据库基础知识——TCL语言

1.TCL含义 TCL&#xff0c;事务控制语言。通过一组逻辑操作单元&#xff08;一组DML——sql语句&#xff09;&#xff0c;将数据从一种状态切换到另外一种状态&#xff0c;即要么全部成功&#xff0c;要么全部失败。2.特点 &#xff08;ACID&#xff09; 原子性(atomicity)&a…

谷歌时间晶体登上Nature,诺奖得主重大猜想成为现实

来源&#xff1a;机器之心没有能量的供给&#xff0c;没有能量的消耗&#xff0c;它的循环运动会永远持续下去。时间晶体就像是一个「永动机」在不同状态之间永久循环往复而不消耗任何能量。来自斯坦福大学、谷歌、马克思 普朗克复杂系统物理研究所和牛津大学的研究团队声称已…

【GoWeb开发实战】Beego的路由控制

Beego的路由控制 二、路由控制 web框架中&#xff0c;路由是重要的一环&#xff0c;对于beego的路由配置如何&#xff1f; 2.1 默认路由 让我们从入口文件main.go先分析起来吧&#xff1a; package mainimport (_ "beegoDemo/routers""github.com/astaxie/beego…

数据库基础知识——视图

视图 含义&#xff1a;理解成一张虚拟的表 视图和表的区别&#xff1a; 使用方式占用物理空间视图完全相同 不占用&#xff0c;仅仅保存的是sql逻辑表完全相同 占用 视图的好处&#xff1a; 1、sql语句提高重用性&#xff0c;效率高 2、和表实现了分离&#xff0c;提高了安…

挑战唯物论?诺奖得主彭罗斯:意识产生可能是大脑内的「量子叠加」的结果...

来源&#xff1a;新智元量子物理学取得了巨大成功&#xff0c;但其解释仍然不确定。大脑由神经元组成&#xff0c;而神经元又由分子组成&#xff0c;很可能会受到量子效应的影响。量子力学和神经科学能否融合成「量子意识」理论&#xff1f;「我们是谁」&#xff1f;恐怕没有什…