一、查询语句

  1.  select [选项] 列名 [from 表名]  [where 条件]  [order by 排序]  [group by 分组]  [having 条件]  [limit 限制]

  2. 字段表达式

    select 10*10

    select '锄禾日当午'

  3. 通过as给列名取别名,as可以省略 

    select 10*10 as result

    select 10*10 result

  4. from子句

    a. from:来自,from后面跟的是数据源。数据源可以有多个。返回笛卡尔积。

  5. dual伪表

    dual是一个伪表。在有些特殊情况下,没有具体的表可以参与,但是为了保证select语句的完整又必须要一个表名,这时候就要用伪表。

    dual表示为了保证select语句的完整性。

  6. where子句

    a. where后面跟的是条件,在数据源中进行筛选。条件为真,就 返回当前记录。

    b. mysql支持的运算符

      大于:>  小于:<  大于等于:>=  小于等于:<=  等于:=  不等于:!=  与:and  或:or  非:not

  7. in | not in

    a. 查找北京和上海的学生

      select * from stu where stuAddr='北京' or stuAddr='上海'

      select * from stu where stuAddr in ('北京','上海')

    b. 查找不是北京和上海的学生

      select * from stu where stuAddr not in ('北京','上海')

  8. between ... and | not between ... and 查找某个范围的记录 

    a. 查找年龄在18到20之间的学生

      select * from stu where stuAge >=18 and stuAge <=20

      select * from stu where stuAge between 18 and 20

    b. 查找年龄不在18到20之间的学生

      select * from stu where stuAge <18 or stuAge >20

      select * from stu where not (stuAge >=18 or stuAge <=20)

      select * from stu where stuAge not between 18 and 20  

  9. is null | is not null

    a. 查找ch为null或者math为null的学生

      select * from stu where ch is null or math is null

    b. 查找ch和math都不为null的学生

      select *from stu where ch is not null and math is not null

  10. 聚合函数

    a. sum() :求和

      select sum(ch) from stu; 求语文成绩总分

    b. avg():平均数

    c. max():最大值

    d. min():最小值

    e. count():记录数

      select sum(ch) '语文总分', avg(ch) '语文平均分', max(ch) '语文最高分', min(ch) '语文最低分', count(*) '总记录数' from stu;

  11. 通配符

    a. _ [下划线] 表示任意一个字符

    b. % 表示任意字符

  12. 模糊查询(like)

     select * from stu where stuName like '张%'

  13. order by 排序

    a. asc 升序【默认】

    b. desc 降序

      select * from stu order by ch desc;语文成绩降序排列

      select * from stu order by ch; 默认升序排列

    c. 多列排序

      select *,(ch+math) as '总分' from stu order by stuAge asc, (ch+math) desc;

  14. group by 分组查询(将查询的结果分组,分组查询的目的在于统计数据)

    a. select avg(stuage) as '平均年龄',stusex from stu group by stusex;

    b. 注意:如果是分组查询,查询字段必须是分组字段和聚合函数,如果查询字段是普通字段,只取分组的第一个值。

    c. select group_concat(stuname),stusex from stu group by stusex 将同一组的值连接起来显示

    d. 注意:分组默认为升序排序,可以加desc改为降序。select * from stu group by stuage desc;  

    e. 多列分组:select stuaddr,stusex,avg(stuage) from stu group by stuaddr,stusex;

  15. having条件:在结果集上继续进行筛选

    a. select stusex,count(*) total from stu group by stusex having totalz >=5;

  16. limit

    a. 语法:limit起始位置,显示长度

      select * from stu limit 0,2; (从0开始取2条)

    b. 起始位置可以省略,默认从0开始

    c. 例子:班级总分前三名 select *,(ch+math) total from stu order by total desc limit 3;

      前三个地址改成上海:update stu set stuaddr='上海' where name is not null limit 3;

  17. 选项

    a. all:显示所有数据【默认】

    b. distinct:去除结果集中重复的数据

    

    

    

mysql学习笔记--数据库单表查询的更多相关文章

  1. mysql学习笔记--数据库多表查询

    一.内连接[inner join] 1. 语法一:select 列名 from 表1 inner join 表2 on 表1.公共字段=表2.公共字段 2. 语法二:select 列名 from 表1 ...

  2. MySQL学习笔记8——多表查询

    多表查询 多表查询 *合并结果集 *连接查询 *子查询 合并结果集 *要求被合并的表中,列的类型和列数相同(实际上是查询的结果集列类型和列数相同即可) *UNION,去除重复行 *UNION ALL, ...

  3. Mariadb/MySQL数据库单表查询基本操作及DML语句

    Mariadb/MySQL数据库单表查询基本操作及DML语句 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一数据库及表相关概述 1>.数据库操作 创建数据库: CREATE ...

  4. MySQL学习笔记-数据库文件

    数据库文件 MySQL主要文件类型有如下几种 参数文件:my.cnf--MySQL实例启动的时候在哪里可以找到数据库文件,并且指定某些初始化参数,这些参数定义了某种内存结构的大小等设置,还介绍了参数类 ...

  5. MySQL学习笔记-数据库内存

    数据库内存 InnoDB存储引擎内存由以下几个部分组成:缓冲池(buffer pool).重做日志缓冲池(redo log buffer)以及额外的内存池(additional memory pool ...

  6. MySQL学习笔记-数据库后台线程

    数据库后台线程 默认情况下讲述的InnoDB存储引擎,以后不再重复声明.后台线程有7个--4个IO thread,1个master thread,1个锁监控线程,1个错误监控线程.IO thread的 ...

  7. Mysql数据库单表查询

    1.单表查询语法 #查询数据的本质:mysql会到你本地的硬盘上找到对应的文件,然后打开文件,按照你的查询条件来找出你需要的数据.下面是完整的一个单表查询的语法 select * from,这个sel ...

  8. oracle数据库单表查询

    今天给大家分享的是关于数据库的单表查询,像单表查询/多表查询/分组查询/子查询,这些方法的使用在实际项目过程中会经常用到,作为一名合格的测试人员如果不会数据库那肯定是不行的,行走江湖可能随时会面临被侮 ...

  9. MySql(六)单表查询

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

随机推荐

  1. How to Install Tomcat 8.0.27 on CentOS/RHEL and Ubuntu【转】

    https://tecadmin.net/install-tomcat-8-on-centos-rhel-and-ubuntu/ Apache Tomcat is an opensource web ...

  2. DataTable与DataSet之间的转换Class

    using System;using System.Collections.Generic;using System.Data;using System.Linq; namespace Convert ...

  3. _Bool and bool

    _Bool is the defined before C99. bool has been defined in C99. bool is an alias for _Bool if you inc ...

  4. 解决Visual Studio禁止使用strlen函数的问题

    问题描述: 在学习C++的复制构造函数以及复制赋值运算符的重载时,需要用到使用C风格的字符串作为引入,由于我用的是VS2015(社区版),在编译时出错.编译器提醒strcpy函数是不安全的,建议改用s ...

  5. [zz]有哪些优秀的科学网站和科研软件推荐给研究生?

    https://www.zhihu.com/question/37061410 如题,各位科研前辈,有没有一些好的科研网站或者适合科研人员用的软件以及APP,推荐给一只研一的菜鸡,帮助我们提高科研效率 ...

  6. django 神奇的双下划线,通过外键的三种查询方式

    一,用于跨表操作 只要是object后面字符串都是用双下划线__.其它地方用点. 如:的values中的group_code__name.group_code是一个外键 def list(reques ...

  7. 【C++】 多态的实现和原理

    本文转自 https://www.cnblogs.com/cxq0017/p/6074247.html 安利一篇blog,https://blog.csdn.net/u013982161/articl ...

  8. perl open函数的使用

    本文和大家重点讨论一下如何读写Perl文件,主要包括打开.关闭Perl文件,读写Perl文件,Perl文件的状态,命令行参数和打开管道六部分内容,希望通过本文的学习你对读写Perl文件有深刻的认识. ...

  9. 网络共享存储服务NFS

    网络共享存储服务NFS 作者:Eric 微信:loveoracle11g 环境准备 服务器系统 角色 IP RHEL 7.5 x86-64 NFS服务端 192.168.10.201 RHEL 7.5 ...

  10. JAVA 每周一 每周日 时间

    Calendar cal = Calendar.getInstance(); SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd&q ...