0

0

select 语句

大家讲道理

大家讲道理

发布时间:2017-05-28 11:22:26

|

1600人浏览过

|

来源于php中文网

原创

1. order by (排序)

   通常使用一个字段作为参考标准,进行排序。

   语法:order by 【字段】 asc|desc;(升序、降序)

   tip : 校对规则 决定 排序关系。

          允许多字段排序(先按第一个字段排序,当出现不能区分的时候,按第二个字段进行排序,依此类推)。

【举个栗子】 对于下表,输入select * from tb_name; 时,会按照输入顺序依次显示表中的数据:

         

       当需要对表中数据按照字段 stu_score 进行降序排列时,在输入语句后加上order by stu_score desc .

        

       如果不注明升序、降序,默认使用升序:

       

      若使用多字段排序,eg. 先按stu_score进行排序,若分数相同,再按照开课时间date_begin进行排序,语句为:

       select * from tb_name order by stu_score desc , date_begin , asc;

tip : order by是对检索出来的信息进行排序,因此需要写在where语句后。

      如果是分组,则应该使用对分组字段进行排序的group by语法。

2. limit(限制获得的记录数量)

   limit 发生在排序、检索等行为之后,所以 limit 出现在最后。

   对于下面的数据表,若限制只显示其中的1个数据,则输出结果为右图:

                                         

   即会按照最初数据输入的顺序,取第一组数据进行输出。

   也可以在进行完排序后,限制只输出前3名:

          

   语法:limit 偏移量 总记录数

           偏移量:截取的开始点。      总记录数:截取的长度。

          若不写偏移量,默认从0开始。

3. distinct(去除重复记录)(与all相对应)

PaperAiBye
PaperAiBye

支持近30多种语言降ai降重,并且支持多种语言免费测句子的ai率,支持英文aigc报告等

下载

    当在表exam_stu中,显示字段stu_score中的所有数据时,结果如下:

    

   若想去除其中的重复记录,可使用一下语句,于是两个95分便只剩下了一个:

    

   重复记录的标准是按照查询的字段来确定的,当语句为select distinct * 时,只有当所有字段都一样时,才认为两条数据重复;

   当语句是 select distinct stu_score时,当两条数据的stu_score相同时,认为二者重复;

   当语句是select distinct stu_score,stu_name时,必须分数和名字一样,才认为二者重复。

4. union查询联合查询

    将多条 select 语句合并到一起,称为联合操作。

    使用 union 关键字,联合两个 select 语句即可。

【举个栗子】要在表中查询给php0228班和php0331班上课天数最多的两个老师,语句为

                select teacher_name,days from teacher_class where class_name='php0228' order by days desc limit 1;

                select teacher_name,days from teacher_class where class_name='php0331' order by days desc limit 1;

             这两个分开的语句的确可以查找出想要的结果,但是若要做联合查询呢?

            语句是 :(语句1)union(语句2);

                          但这种写法会将重复的记录删除,若想保留所有记录,哪怕重复,可用一下格式:

                        (语句1)union all (语句2); 

tip:在使用union的情况下,排序有几点需要注意。

     子语句的排序

       ① 将子语句包裹在子括号内;

       ② 子语句的order by只有在配合limit使用时,才生效。原因是:union会对没有limit的字句的order by优化(忽略)。

若相对union的结果进行排序,使用如下语句:

     (语句1)union(语句2)order by days ;

注意: ① 多个 select 语句的检索到的字段数必须一致;更严格的是,数据类型上也应该要求一致(但是mysql内部会做类型转换处理,要              求是能转换成功)。

相关专题

更多
Java编译相关教程合集
Java编译相关教程合集

本专题整合了Java编译相关教程,阅读专题下面的文章了解更多详细内容。

11

2026.01.21

C++多线程相关合集
C++多线程相关合集

本专题整合了C++多线程相关教程,阅读专题下面的的文章了解更多详细内容。

4

2026.01.21

无人机驾驶证报考 uom民用无人机综合管理平台官网
无人机驾驶证报考 uom民用无人机综合管理平台官网

无人机驾驶证(CAAC执照)报考需年满16周岁,初中以上学历,身体健康(矫正视力1.0以上,无严重疾病),且无犯罪记录。个人需通过民航局授权的训练机构报名,经理论(法规、原理)、模拟飞行、实操(GPS/姿态模式)及地面站训练后考试合格,通常15-25天拿证。

16

2026.01.21

Python多线程合集
Python多线程合集

本专题整合了Python多线程相关教程,阅读专题下面的文章了解更多详细内容。

1

2026.01.21

java多线程相关教程合集
java多线程相关教程合集

本专题整合了java多线程相关教程,阅读专题下面的文章了解更多详细内容。

4

2026.01.21

windows激活码分享 windows一键激活教程指南
windows激活码分享 windows一键激活教程指南

Windows 10/11一键激活可以通过PowerShell脚本或KMS工具实现永久或长期激活。最推荐的简便方法是打开PowerShell(管理员),运行 irm https://get.activated.win | iex 脚本,按提示选择数字激活(选项1)。其他方法包括使用HEU KMS Activator工具进行智能激活。

2

2026.01.21

excel表格操作技巧大全 表格制作excel教程
excel表格操作技巧大全 表格制作excel教程

Excel表格操作的核心技巧在于 熟练使用快捷键、数据处理函数及视图工具,如Ctrl+C/V(复制粘贴)、Alt+=(自动求和)、条件格式、数据验证及数据透视表。掌握这些可大幅提升数据分析与办公效率,实现快速录入、查找、筛选和汇总。

6

2026.01.21

毒蘑菇显卡测试网站入口 毒蘑菇测试官网volumeshader_bm
毒蘑菇显卡测试网站入口 毒蘑菇测试官网volumeshader_bm

毒蘑菇VOLUMESHADER_BM测试网站网址为https://toolwa.com/vsbm/,该平台基于WebGL技术通过渲染高复杂度三维分形图形评估设备图形处理能力,用户可通过拖动彩色物体观察画面流畅度判断GPU与CPU协同性能;测试兼容多种设备,但中低端手机易卡顿或崩溃,高端机型可能因发热降频影响表现,桌面端需启用独立显卡并使用支持WebGL的主流浏览器以确保准确结果

25

2026.01.21

github中文官网入口 github中文版官网网页进入
github中文官网入口 github中文版官网网页进入

github中文官网入口https://docs.github.com/zh/get-started,GitHub 是一种基于云的平台,可在其中存储、共享并与他人一起编写代码。 通过将代码存储在GitHub 上的“存储库”中,你可以: “展示或共享”你的工作。 持续“跟踪和管理”对代码的更改。

7

2026.01.21

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号