查询数据

1.查询所有数据:

select * from 表名;

2.根据指定条件查询数据:

select * from 表名 where 查询条件

3.根据where条件查询:

  3.1 根据指定条件查询指定字段的数据

select 字段1,... from 表名 where 查询条件

   这里为大家简述一下这条命令执行的基本流程:

    1.先执行from命令,从指定表中取出数据;

    2.在通过查询条件,将符合条件的数据筛选出来;

    3.最后,再查询出指定字段包含的数据并显示出来。

  3.2 where结合逻辑运行算符进行查询

  首先,我们需要先明确一下逻辑运算符都包括什么:

    and:与运算;

-- where结合and使用
select * from 表名 where 查询条件1 and 查询条件2;

当两个查询条件都满足时才能够查询出数据。

    or:或运算;

-- where 结合 or
select * from 表名 where 查询条件1 or 查询条件2;

当两个查询条件中有一个满足时就会查询出数据。

    not:取反。

--where 结合 not
select * from 表名 where not (查询条件);

当满足与查询条件相反时查询出数据。

注意:not的运算符优先级比and 和 or 大;not>and>or。

  3.3 模糊查询

利用通配符进行模糊查询。

模糊查询的通配符有:

  1.%:匹配任意个字符;

  2._:匹配任意一个字符。

-- 模糊查询
select * from t_student where name='王%';
-- 表示查询出所有姓王的学生的信息 select * from t_student where name='王_';
-- 表示查询出所有姓王、名字为两个字的学生的信息

  3.4 范围查询

范围查询的关键字有:

  1.between ... and ..

  2.in(数据1,...)

--between ... and 使用
select name.age from t_student where age between 18 and 20;
-- 表示查询出年龄在18到20之间的学生姓名和年龄(包括18和20) -- in 使用
select s_id,name from t_student where s_id in(16280101,16280202,16280333);
-- 表示查询出学号在这个范围(16280101,16280202,16280333)内的学生的学号和姓名

  3.5 空判断查询

关键字:

  1.is null :空

  2.is not null :非空

-- is null 使用
select * from t_student where phone is null;
-- 表示查询出所有电话号为空的学生信息 --is not null使用
select * from t_student where phone is not null;
-- 表示查询出所有电话号非空的学生信息

注意:

is not null 和not is null查询出来的数据是一样的但是原理不同;

is not nul 是 直接判断字段内的数据是否为非空;

not is null 是 先判断字段内的数据是否为空,然后再进行取反操作,效率较低。

  3.6 数据排序

使用关键字order by desc/asc对查询出的数据进行排序。

-- order by desc
select * from 表名 where 查询条件 order by 字段名 desc
-- 表示先查询出指定数据在进行降序排列 -- order by asc
select * from 表名 where 查询条件 order by 字段名 asc;
-- 表示先查询出指定数据再进行升序排列

  3.7 分页查询

使用关键字limit进行分页查询

-- limit 使用
select * from t_student where phone is not null limit 0,10;
--表示查询出10条电话非空的学生的信息 --分页查询计算公式
limit (page-1)*count,count;

  3.8 分组查询

使用group by关键字进行分组,having关键字后一般使用聚合函数。

-- 无分组条件查询
select adress,group_concat(name) from t_student group by address;
-- 表示使用address分组,并查询出分组信息以及每组内的学生姓名 -- 有分组条件查询
select address,group_concat(name) from t_student group by address having count(name)<3;
-- 表示使用address分组,并显示出人数小于3人的小组信息以及组内的学生姓名

MySql数据库之单表数据查询的更多相关文章

  1. MySQL数据库之单表查询中关键字的执行顺序

    目录 MySQL数据库之单表查询中关键字的执行顺序 1 语法顺序 2 执行顺序 3 关键字使用语法 MySQL数据库之单表查询中关键字的执行顺序 1 语法顺序 select distinct from ...

  2. MySQL数据库语法-单表查询练习

    MySQL数据库语法-单表查询练习 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 本篇博客主要是对聚合函数和分组的练习. 一.数据表和测试数据准备 /* @author :yinz ...

  3. MySQL单表数据查询(DQL)

    数据准备工作: CREATE TABLE student( sid INT PRIMARY KEY AUTO_INCREMENT, sname ), age TINYINT, city ), scor ...

  4. 基于MySql数据库的单表与多表联合查询

    这里以学生 班级 身份证 以及课程为例 1,启动MySql数据库  开启服务 2.1.0新建一张班级表 备注:CHARSET = UTF8 (指定编码格式为utf8 防止中文乱码) /*班级表*/ C ...

  5. mysql数据库之单表查询多表查询

    单表查询 前期表准备 create table emp( id int not null unique auto_increment, name varchar(20) not null, sex e ...

  6. mysql数据库之单表查询

    单标查询 单表查询语句 关键字执行的优先级 简单查询 where约束 group by 聚合函数 HAVING过滤 order by 查询排序 LIMIT限制查询的记录数 使用正则表达式查询 单表查询 ...

  7. 黑马MySQL数据库学习day02 表数据CRUD 约束CRUD

    /* 基础查询练习: 1.字段列表查询 当查询全部字段时,一种简便方式,使用*代替全部字段(企业中不推荐使用) 2.去除重复行 DISTINCT,注意修饰的是行,也就是整个字段列表,而不是单个字段. ...

  8. 向MySql数据库导入excel表数据

    最近要开发一个小的答题系统,如果题目人工录入那确实很麻烦.所以想到是不是可以从用一些现有数据格式的文件导入数据.在网上查了一下,看到有关于将excel的数据导入到mysql的方法.所以将题库数据整理成 ...

  9. java对mysql数据库进行单表筛选备份、还原操作

    最近在做的一个项目需要对mysql数据库中的单个表格进行备份 其中,一部分表格需要进行筛选备份(例如对最近插入的1000条记录进行备份) 思路:java调用系统命令完成备份操作 假设现在有数据库tes ...

随机推荐

  1. curl太复杂难用记不住?来试试Httpie一个简单的现代化命令行Http客户端

    HTTPie 是一个简单的现代化命令行 HTTP 客户端. 交互友好,JSON支持,语法高亮,类wget下载,支持拓展等 功能特性 自然而且简单的命令语句 格式化且高亮显示输出内容 内置 JSON 支 ...

  2. Golang 基础学习笔记(2)| 如何安装Go工具

    可参考官网:http://docscn.studygolang.com/doc/install#安装 1.OS要求 gc 编译器支持以下操作系统及架构.在开始前,请确保你的系统满足这些需求. 若你的O ...

  3. 易初大数据 2019年11月8日 linux 王庆超

    ◆linux系统的特点: (1)完全免费. (2)高效.安全.稳定. (3)支持多种硬件平台. (4)友好的用户界面. (5)强大的网络功能. (6)支持多任务.多用户. ◆linux体系: 1.li ...

  4. 接口测试专题(Java & jmeter & Linux基础)

    以下是我和两个朋友原创文章合集,主题是接口测试,有Java接口测试案例和jmeter的案例,还有接口测试相关服务器操作基础.欢迎点赞.关注和转发. 接口测试 httpclient处理多用户同时在线 h ...

  5. pat 1108 Finding Average(20 分)

    1108 Finding Average(20 分) The basic task is simple: given N real numbers, you are supposed to calcu ...

  6. opencv 2 Opencv数据结构与基本绘图

    基础图像容器Mat Mat 是一个类,又两个数据部分组成:矩阵头(包含矩阵尺寸,存储方法,存储地址等信息)和一个指向存储所有像素值的矩阵(根据所选存储方法不同,矩阵可以是不同的维数)的指针.矩阵头的尺 ...

  7. Linux下安装和使用WPS,体验良好

    最近,我在ubuntu18.04.3下面使用LibreOffice,感觉良好. 正值政府机关在进行2019年度正版软件使用情况整改,保护知识产权,我表示热烈欢迎并强烈支持. 通过摸底,因为以前采购的w ...

  8. Spring Boot (一) 校验表单重复提交

    一.前言 在某些情况下,由于网速慢,用户操作有误(连续点击两下提交按钮),页面卡顿等原因,可能会出现表单数据重复提交造成数据库保存多条重复数据. 存在如上问题可以交给前端解决,判断多长时间内不能再次点 ...

  9. 探索 IPv6 网络

    目录 0x00 前言 0x01 探索 服务器配置 IPv6 地址 服务器部署网络代理 客户端配置网络代理 测试访问 IPv6 地址 给博客添加 IPv6 地址 0x00 前言 IPv4 地址枯竭的事情 ...

  10. linux字符集修改

    首先介绍一下变量. 1.变量类型:本地变量.环境变量.局部变量.特殊变量(内置).参数变量.只读变量. 2.bash的配置文件:profile类和bashrc类 profile类:为交互式登录的she ...