数据库单表查询的方法:1、select查询操作,筛选列;2、where语句,筛选行;3、group by分组;4、having过滤条件,是针对组做过滤条件,是放在group by后面执行的;5、order by排序,对查询出来的数据排序。
数据库单表查询的方法:
1、关键字执行的优先级(重点)
重点中的重点:关键字的执行优先级 1:from #找到表 2:where #使用where指定的条件,去表中取出一条条记录 3:group by #将取出的数据进行分组,如果没有指定,则整体作为一组 4:having #将分组的结果按照having指定的条件进行过滤 5:select #指定select查询 6:distinct #去重 7:order by #将查询的结果按照order by指定的字段进行排序 8:limit #限制结果的显示数量
2、select查询操作(筛选列)
1:#select 查询操作 ''' 注意所有select 查询后面右加括号的方法,比如,select user()这种带括号的都是Mysql的 内置方法,select本身就是查询操作,from只是说明从哪查, ''' select * from 表名; #查询表中所有的数据 *代表所有 select 字段名 from 表名;#查询表中某一个字段的数据 select 字段名,字段名,字段名 from 表名;#查询表中多个字段的数据 select database();#查询返回当前操作的数据库 select user();#查询当前登陆的用户 select now;#查询返回当前的时间 =========================================================== 2:#distinct 去重操作 ''' 当使用select查询表某些字段数据的时候,这个字段中可能出现多个重复的数据,就可以使用distinct对查询出来的数据进行去重操作,distinct也可以对多个字段的数据进行联合去重 ''' select dictinct 字段名 from 表名;#对查出来的字段数据进行去重 select distinct 字段名,字段名 from 表名;#对多个字段查询的数据进行联合去重 =========================================================== 3:#四则运算 ''' 使用select 查询某个字段的数据的时候,对数值类型的字段数据,可以进行四则运算,四则运 算包括加减乘除等操作 ''' select 字段名*12 from 表名;#对查询出来的数据乘以12,返回结果,>>字段名要是数值类型 =========================================================== 4:#concat字符串拼接和concat_ws指定分割符进行拼接(自定义显示的格式) ''' concat内置函数可以对查询出来的字段数据进行字符串拼接 ''' select concat('姓名:',name) from 表名;#对查询出来的姓名字段的数据前面都加上一 个字符串姓名,能够友好的显示查询出来的数据的意思,其实就是字符串拼接 select concat(name,':',salary)as info from 表名;#concat还可以将两个字段的数据拼接,,产生一个新的字段数据显示出来,as是个这个字段重命名 ''' concat_ws()函数也只是字符串拼接,不过concat_ws的凭借方式是类似与python join拼接 的方式,就是以某个元素对多个字段的数据进行拼接 ''' select concat_ws('_','姓名:',name,'性别:',sex)as info from 表名; ========================================================== 5:#case end 语句 对查询出来的每一个数据进行加工和显示 ''' case语句的作用是,对表中数据进行查询时,对于查询出来的语句进行进一步的加工,并且显示出来,case end语句有点像python里的if语句,不过sql的case语句需要表明开始和结束,case代表开始,end代表结束.when代表的就是if条件,else就是其他,当有多个when的时候,从第二个when开始就代表的类似于elif的意思,,,,,知道了解就好>>>>>> ''' select( case when name='田少岗' concat(name,'逗比') when name='田彩' concat(name,'女神') else concat(name,'边玩去') end )as now_name from 表名; ========================================================== 6:#select的相关总结; 可以查一个,多个,*所有 调用函数:now(),database(),concat(),concat_ws() 可以四则运算 可以去重 distinct 可以使用case end 条件判断语句
3、where 筛选行语句
1:#范围查询 #< > >= <= != <>代表不等于和!=是一个意思 select age from 表名 where age <100 and age>20;(多条件查询) #between 1 and 10 找寻1到10之间的 select age from 表名 where between 1 and 100; >>注意包含1和100 #in (1,2,3,4) 多选一 select age from 表名 where age in (10,20,30,40); #将age=10和age=20的都能取出来 select age from 表名 where age=10 or age=20; 2:#模糊查询 #like like的表现形式是,'%a'查询以a结尾的,'a%'查询以a开始的,'%a%'查询包含a的 select name from 表名 where name like '田%';>>>查询出姓田的所有人 like还有一种形式,'_a','a_','a__'一个划线代表一个字符,%代表的是任意长度 select name from 表名 where name 'like '田_';>>>查询出以田开头的两个字的姓名 #regexp 可以使用正则匹配(记一下正则表达式) 3:#is is not is null is not null 一般用来判断是不是空, 4:#逻辑运算 and or not
4、group by(分组)
'''group by可以对某个字段的值进行分组,这个字段有多少种值就分多少组,group by还有一个特性就是去重,一旦使用group by对数据分组了,就不能对某一条数据进行操作,永远都是这一组数据''' group_concat()函数(只用来做最终的显示,不做中间数据的操作)可以显示当前这一组的所有信息,拼在一起显示 select post,group_concat(name),count(id) from employee group by post having count(id) < 2; ''' mysql> set global sql_mode='STRICT_TRANS_TABLES,ONLY_FULL_GROUP_BY'; ONLY_FULL_GROUP_BY的语义就是确定select target list中的所有列的值都是明确语义,简单的说来,在ONLY_FULL_GROUP_BY模式下,target list中的值要么是来自于聚集函数的结果,要么是来自于group by list中的表达式的值。(了解就好) '''
5、聚合函数
1:#count 计数 2:#max 求最大值 3:#avg 求平均值 4:#min 求最小值 5:#sum 求和
6、having 过滤条件
''' having是针对一个组做的过滤条件,是放在group by 后面执行的,他的意思和where是一样的 where group 和 having的执行顺序是,where>group by>having,所以having一般都是和having一起用的 ''' select post,group_concat(name),count(id) from employee group by post having count(id) < 2;
7、order by 排序
''' 对查询出来的数据进行排序,可以升序或者降序(desc),可以使用多个条件一起排序,执行顺序按照从左到右执行排序 ''' SELECT * FROM employee ORDER BY salary; #默认是升序排列 SELECT * FROM employee ORDER BY salary ASC; #升序 SELECT * FROM employee ORDER BY salary DESC; #降序
8limit 分页
''' 可以和order by一起使用,先排序再分页取几个,还可以指定删选的范围,limit m,n这个意思是从m+1开始取n条数据,不如limit 0,6,就是从1开始取六条数据,然是limit分页时,只适合做小数据的分页,当数据量过大时,效率就会非常慢,limit还有一种语法是:limit n offset m,这个意思也是从m+1开始,取n条,这个语法知道就行, ''' #默认初始位置为0,从第一条开始顺序取出三条 SELECT * FROM employee ORDER BY salary DESC LIMIT 3; #从第0开始,即先查询出第一条,然后包含这一条在内往后查5条 SELECT * FROM employee ORDER BY salary DESC LIMIT 0,5; ##从第5开始,即先查询出第6条,然后包含这一条在内往后查5条 SELECT * FROM employee ORDER BY salary DESC LIMIT 5,5;
相关学习推荐:mysql视频教程
以上是数据库怎么做单表查询?的详细内容。更多信息请关注PHP中文网其他相关文章!

ACID属性包括原子性、一致性、隔离性和持久性,是数据库设计的基石。1.原子性确保事务要么完全成功,要么完全失败。2.一致性保证数据库在事务前后保持一致状态。3.隔离性确保事务之间互不干扰。4.持久性确保事务提交后数据永久保存。

MySQL既是数据库管理系统(DBMS),也与编程语言紧密相关。1)作为DBMS,MySQL用于存储、组织和检索数据,优化索引可提高查询性能。2)通过SQL与编程语言结合,嵌入在如Python中,使用ORM工具如SQLAlchemy可简化操作。3)性能优化包括索引、查询、缓存、分库分表和事务管理。

MySQL使用SQL命令管理数据。1.基本命令包括SELECT、INSERT、UPDATE和DELETE。2.高级用法涉及JOIN、子查询和聚合函数。3.常见错误有语法、逻辑和性能问题。4.优化技巧包括使用索引、避免SELECT*和使用LIMIT。

MySQL是一种高效的关系型数据库管理系统,适用于存储和管理数据。其优势包括高性能查询、灵活的事务处理和丰富的数据类型。实际应用中,MySQL常用于电商平台、社交网络和内容管理系统,但需注意性能优化、数据安全和扩展性。

SQL和MySQL的关系是标准语言与具体实现的关系。1.SQL是用于管理和操作关系数据库的标准语言,允许进行数据的增、删、改、查。2.MySQL是一个具体的数据库管理系统,使用SQL作为其操作语言,并提供高效的数据存储和管理。

InnoDB使用redologs和undologs确保数据一致性和可靠性。1.redologs记录数据页修改,确保崩溃恢复和事务持久性。2.undologs记录数据原始值,支持事务回滚和MVCC。

EXPLAIN命令的关键指标包括type、key、rows和Extra。1)type反映查询的访问类型,值越高效率越高,如const优于ALL。2)key显示使用的索引,NULL表示无索引。3)rows预估扫描行数,影响查询性能。4)Extra提供额外信息,如Usingfilesort提示需要优化。

Usingtemporary在MySQL查询中表示需要创建临时表,常见于使用DISTINCT、GROUPBY或非索引列的ORDERBY。可以通过优化索引和重写查询避免其出现,提升查询性能。具体来说,Usingtemporary出现在EXPLAIN输出中时,意味着MySQL需要创建临时表来处理查询。这通常发生在以下情况:1)使用DISTINCT或GROUPBY时进行去重或分组;2)ORDERBY包含非索引列时进行排序;3)使用复杂的子查询或联接操作。优化方法包括:1)为ORDERBY和GROUPB


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

ZendStudio 13.5.1 Mac
功能强大的PHP集成开发环境

PhpStorm Mac 版本
最新(2018.2.1 )专业的PHP集成开发工具

SecLists
SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。

DVWA
Damn Vulnerable Web App (DVWA) 是一个PHP/MySQL的Web应用程序,非常容易受到攻击。它的主要目标是成为安全专业人员在合法环境中测试自己的技能和工具的辅助工具,帮助Web开发人员更好地理解保护Web应用程序的过程,并帮助教师/学生在课堂环境中教授/学习Web应用程序安全。DVWA的目标是通过简单直接的界面练习一些最常见的Web漏洞,难度各不相同。请注意,该软件中

VSCode Windows 64位 下载
微软推出的免费、功能强大的一款IDE编辑器