一、查询语句

  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. hdu 1874 畅通工程续 floyed

    裸题 题意:求任意两点之间的最短路径 坑点:测试数据同一条路径有可能出现多次,然后值不一样,注意筛选最小边 #include <iostream> #include <cstdio& ...

  2. while RE Validation

    一.简介 为什么需要正则表达式? 文本的复杂处理 正则表达式的优势和用途? 一种强大而灵活的文本处理工具: 大部分编程语言.数据库.文本编辑器.开发环境都支持正则表达式. 正则表达式定义: 正如它的名 ...

  3. Windows7 密码修改

    一:不用输入原密码的方式修改用户的密码 1 命令行输入命令:mmc  #进入到控制台 2 点击左上角的文件,选择添加/删除管理单元 3 选择本地用户和组管理单元,添加到本地计算机,完成,确定 4 添加 ...

  4. hibernate---session查询

    一.hql语句查询(适合多表) public class MyTest { public static void main(String[] args) { //查询集合 Session sessio ...

  5. Office常用技巧

    文章目录 大小写切换 把word里的自动编号转换为真实的文本 大小写切换 word中修改单词/句子的大小写:选中文字,按shift+F3,可在全大写.全小写.首字符大写间切换. 把word里的自动编号 ...

  6. lsof一些使用

    查看某进程和哪些文件相关 [root@linux-node2 ~]# netstat -lntp Active Internet connections (only servers) Proto Re ...

  7. 1.3 Linux分区类型

    1.主分区最多只能有4个. 2.扩展分区: 最多只能有一个: 主分区加扩展分区最多只能有4个: 扩展分区只能包含逻辑分区,不能写数据. 3.格式化目的: 写入文件系统:清除数据:划出文件分配表(i n ...

  8. [转]golang的goroutine调度机制

    golang的goroutine调度机制 版权声明:本文为博主原创文章,未经博主允许不得转载.   目录(?)[-] 一直对goroutine的调度机制很好奇最近在看雨痕的golang源码分析基于go ...

  9. javaScript 中的私有,共有,特权属性和方法

    function constructor () { var private_v; // 私有属性 var private_f = function () { // 私有方法 // code }; th ...

  10. python修改字典的值(update map value)

    mydict.update({'newkey':'newvalue'})