1、创建表的结构和数据
CREATE TABLE `t_student`(
`id` INT PRIMARY KEY,
`stuName` VARCHAR(10) NOT NULL,
`age` INT NOT NULL,
`sex` VARCHAR (4),
`gradeName` VARCHAR(10) NOT NULL
);
插入数据:
INSERT INTO `t_student`
(`id`,`stuName`,`age`,`sex`,`gradeName`)
VALUES
('1','张三','23','男','一年级')
('2','麻子','25','男','二年级'),
('3','李四','22','男','一年级'),
('4','王五','23','男','三年级'),
('5','小龙女','21','女','一年级'),
('6','周芷若','26','女','二年级'),
('7','汪峰','20','男','三年级'),
('8','黄欧阳锋','21','男','二年级'),
('9','杨过','22','男','二年级'),
('10','令狐冲','19','男','三年级'),
('11','东方不败','25','男','一年级'),
('12','无崖子','30',NULL,'一年级'),
('13','连城诀','28',NULL,'一年级');
2.单表查询
查询所有字段
SELECT 字段1,字段2,字段3.......FROM 表名;
SELECT id,stuName,age,sex,gradeName FROM t_student;
SELECT * FROM t_student;
两者区别在于前者可以通过查询字段的顺序来调整显示结果的顺序,后者是按照表结构的顺序显示。
where条件查询
SELECT 字段1,字段2,字段3......FROM 表名;
SELECT age,sex,gradeName FROM t_student WHERE 条件表达式;
查询编号为1的学生:
SELECT * FROM t_student WHERE id=1;
mysql> SELECT * FROM t_student WHERE id=1;
+----+---------+-----+------+-----------+
| id | stuName | age | sex | gradeName |
+----+---------+-----+------+-----------+
| 1 | 张三 | 23 | 男 | 一年级 |
+----+---------+-----+------+-----------+
1 row in set (0.00 sec)
查询年龄大于22岁的学生:
SELECT * FROM t_student WHERE age >22;
mysql> SELECT * FROM t_student WHERE age >22;
+----+--------------+-----+------+-----------+
| id | stuName | age | sex | gradeName |
+----+--------------+-----+------+-----------+
| 1 | 张三 | 23 | 男 | 一年级 |
| 2 | 麻子 | 25 | 男 | 二年级 |
| 4 | 王五 | 23 | 男 | 三年级 |
| 6 | 周芷若 | 26 | 女 | 二年级 |
| 10 | 令狐冲 | 23 | 男 | 三年级 |
| 11 | 东方不败 | 23 | 男 | 一年级 |
| 12 | 无崖子 | 23 | NULL | 一年级 |
| 13 | 连城诀 | 23 | NULL | 一年级 |
+----+--------------+-----+------+-----------+
8 rows in set (0.00 sec)
查询性别为男的学生:
SELECT * FROM t_student WHERE sex='男';
mysql> SELECT * FROM t_student WHERE sex='男';
+----+--------------+-----+------+-----------+
| id | stuName | age | sex | gradeName |
+----+--------------+-----+------+-----------+
| 1 | 张三 | 23 | 男 | 一年级 |
| 2 | 麻子 | 25 | 男 | 二年级 |
| 3 | 李四 | 22 | 男 | 一年级 |
| 4 | 王五 | 23 | 男 | 三年级 |
| 7 | 汪峰 | 20 | 男 | 三年级 |
| 8 | 黄欧阳锋 | 21 | 男 | 二年级 |
| 9 | 杨过 | 22 | 男 | 二年级 |
| 10 | 令狐冲 | 23 | 男 | 三年级 |
| 11 | 东方不败 | 23 | 男 | 一年级 |
+----+--------------+-----+------+-----------+
9 rows in set (0.00 sec)
带IN关键字的查询
查询年龄为22或者23岁的学生:
SELECT * FROM t_student WHERE age IN (22,23);
mysql> SELECT * FROM t_student WHERE age IN (22,23);
+----+--------------+-----+------+-----------+
| id | stuName | age | sex | gradeName |
+----+--------------+-----+------+-----------+
| 1 | 张三 | 23 | 男 | 一年级 |
| 3 | 李四 | 22 | 男 | 一年级 |
| 4 | 王五 | 23 | 男 | 三年级 |
| 9 | 杨过 | 22 | 男 | 二年级 |
| 10 | 令狐冲 | 23 | 男 | 三年级 |
| 11 | 东方不败 | 23 | 男 | 一年级 |
| 12 | 无崖子 | 23 | NULL | 一年级 |
| 13 | 连城诀 | 23 | NULL | 一年级 |
+----+--------------+-----+------+-----------+
8 rows in set (0.00 sec)
查询学号不是1和9 的学生记录:
SELECT * FROM t_student WHERE ID NOT IN (1,9);
mysql> SELECT * FROM t_student WHERE ID NOT IN (1,9);
+----+--------------+-----+------+-----------+
| id | stuName | age | sex | gradeName |
+----+--------------+-----+------+-----------+
| 2 | 麻子 | 25 | 男 | 二年级 |
| 3 | 李四 | 22 | 男 | 一年级 |
| 4 | 王五 | 23 | 男 | 三年级 |
| 5 | 小龙女 | 21 | 女 | 一年级 |
| 6 | 周芷若 | 26 | 女 | 二年级 |
| 7 | 汪峰 | 20 | 男 | 三年级 |
| 8 | 黄欧阳锋 | 21 | 男 | 二年级 |
| 10 | 令狐冲 | 23 | 男 | 三年级 |
| 11 | 东方不败 | 23 | 男 | 一年级 |
| 12 | 无崖子 | 23 | NULL | 一年级 |
| 13 | 连城诀 | 23 | NULL | 一年级 |
带BETWEEN的范围查询
SELECT 字段1,字段2,字段3....FROM 表名 WHERE 条件表达式 [NOT] BETWEEN 数值1,AND数值2;
SELECT * FROM t_student WHERE age NOT BETWEEN 22 AND 25;
mysql> SELECT * FROM t_student WHERE age NOT BETWEEN 22 AND 25;
+----+--------------+-----+------+-----------+
| id | stuName | age | sex | gradeName |
+----+--------------+-----+------+-----------+
| 5 | 小龙女 | 21 | 女 | 一年级 |
| 6 | 周芷若 | 26 | 女 | 二年级 |
| 7 | 汪峰 | 20 | 男 | 三年级 |
| 8 | 黄欧阳锋 | 21 | 男 | 二年级 |
+----+--------------+-----+------+-----------+
4 rows in set (0.00 sec)
查询学号为1-9的学生记录:
SELECT * FROM t_student WHERE id BETWEEN 1 AND 9;
mysql> SELECT * FROM t_student WHERE id BETWEEN 1 AND 9;
+----+--------------+-----+------+-----------+
| id | stuName | age | sex | gradeName |
+----+--------------+-----+------+-----------+
| 1 | 张三 | 23 | 男 | 一年级 |
| 2 | 麻子 | 25 | 男 | 二年级 |
| 3 | 李四 | 22 | 男 | 一年级 |
| 4 | 王五 | 23 | 男 | 三年级 |
| 5 | 小龙女 | 21 | 女 | 一年级 |
| 6 | 周芷若 | 26 | 女 | 二年级 |
| 7 | 汪峰 | 20 | 男 | 三年级 |
| 8 | 黄欧阳锋 | 21 | 男 | 二年级 |
| 9 | 杨过 | 22 | 男 | 二年级 |
+----+--------------+-----+------+-----------+
9 rows in set (0.00 sec)
查询年龄小于22但是大于25 的学生信息:
SELECT * FROM t_student WHERE age NOT BETWEEN 22 AND 25;
mysql> SELECT * FROM t_student WHERE age NOT BETWEEN 22 AND 25;
+----+--------------+-----+------+-----------+
| id | stuName | age | sex | gradeName |
+----+--------------+-----+------+-----------+
| 5 | 小龙女 | 21 | 女 | 一年级 |
| 6 | 周芷若 | 26 | 女 | 二年级 |
| 7 | 汪峰 | 20 | 男 | 三年级 |
| 8 | 黄欧阳锋 | 21 | 男 | 二年级 |
+----+--------------+-----+------+-----------+
4 rows in set (0.00 sec)
带LIKE的模糊查询:
SELECT 字段1,字段2,字段3 FROM 表名 WHERE 条件表达式 [NOT] LIKE '字符串';
查询姓名中包含张的学生信息:
SELECT * FROM t_student WHERE stuName LIKE '%张%';
mysql> SELECT * FROM t_student WHERE stuName LIKE '张%';
+----+-----------+-----+------+-----------+
| id | stuName | age | sex | gradeName |
+----+-----------+-----+------+-----------+
| 1 | 张三 | 23 | 男 | 一年级 |
| 2 | 张三丰 | 25 | 男 | 二年级 |
+----+-----------+-----+------+-----------+
2 rows in set (0.00 sec)
 
查询姓名中第一个字为张的学生信息:
SELECT * FROM t_student WHERE stuName LIKE '张%';
mysql> SELECT * FROM t_student WHERE stuName LIKE '张%';
+----+-----------+-----+------+-----------+
| id | stuName | age | sex | gradeName |
+----+-----------+-----+------+-----------+
| 1 | 张三 | 23 | 男 | 一年级 |
| 2 | 张三丰 | 25 | 男 | 二年级 |
+----+-----------+-----+------+-----------+
2 rows in set (0.00 sec)
查询姓为张,名为一个字的学生信息:
SELECT * FROM t_student WHERE stuNAME LIKE '张_';
mysql> SELECT * FROM t_student WHERE stuNAME LIKE '张_';
+----+---------+-----+------+-----------+
| id | stuName | age | sex | gradeName |
+----+---------+-----+------+-----------+
| 1 | 张三 | 23 | 男 | 一年级 |
+----+---------+-----+------+-----------+
1 row in set (0.00 sec)
空值查询:
SELECT 字段1,字段2,字段3 FROM 表名 WHERE 条件表达式 IS [NOT] NULL;
SELECT * FROM t_student WHERE sex IS NULL;
mysql> SELECT * FROM t_student WHERE sex IS NULL;
+----+-----------+-----+------+-----------+
| id | stuName | age | sex | gradeName |
+----+-----------+-----+------+-----------+
| 12 | 无崖子 | 23 | NULL | 一年级 |
| 13 | 连城诀 | 23 | NULL | 一年级 |
+----+-----------+-----+------+-----------+
2 rows in set (0.00 sec)
 
查询性别不为NULL 的学生信息:
SELECT * FROM t_student WHERE sex IS NOT NULL;
mysql> SELECT * FROM t_student WHERE sex IS NOT NULL;
+----+--------------+-----+------+-----------+
| id | stuName | age | sex | gradeName |
+----+--------------+-----+------+-----------+
| 1 | 张三 | 23 | 男 | 一年级 |
| 2 | 张三丰 | 25 | 男 | 二年级 |
| 3 | 李四 | 22 | 男 | 一年级 |
| 4 | 王五 | 23 | 男 | 三年级 |
| 5 | 小龙女 | 21 | 女 | 一年级 |
| 6 | 周芷若 | 26 | 女 | 二年级 |
| 7 | 汪峰 | 20 | 男 | 三年级 |
| 8 | 黄欧阳锋 | 21 | 男 | 二年级 |
| 9 | 杨过 | 22 | 男 | 二年级 |
| 10 | 令狐冲 | 23 | 男 | 三年级 |
| 11 | 东方不败 | 23 | 男 | 一年级 |
+----+--------------+-----+------+-----------+
11 rows in set (0.00 sec)
注意:在插入数据库的时候如果是NULL的话就直接插入NULL,这个值不等于空,也不等于'NULL';
带AND的多条件查询:
SELECT 字段1,字段2,字段3 FROM 表名 WHERE 表达式1 AND 表达式2 [...AND表达式N];
SELECT * FROM t_student WHERE gradeName='一年级' AND sex='男';
mysql> SELECT * FROM t_student WHERE gradeName='一年级' AND sex='男';
+----+--------------+-----+------+-----------+
| id | stuName | age | sex | gradeName |
+----+--------------+-----+------+-----------+
| 1 | 张三 | 23 | 男 | 一年级 |
| 3 | 李四 | 22 | 男 | 一年级 |
| 11 | 东方不败 | 23 | 男 | 一年级 |
+----+--------------+-----+------+-----------+
3 rows in set (0.01 sec)
带OR的多条件查询:
SELECT 字段1,字段2,字段3 FROM 表名 WHERE 表达式1 OR 表达式2 [...OR表达式N];
SELECT * FROM t_student WHERE gradeName='一年级' OR age=23;
mysql> SELECT * FROM t_student WHERE gradeName='一年级' OR age=23;
+----+--------------+-----+------+-----------+
| id | stuName | age | sex | gradeName |
+----+--------------+-----+------+-----------+
| 1 | 张三 | 23 | 男 | 一年级 |
| 3 | 李四 | 22 | 男 | 一年级 |
| 4 | 王五 | 23 | 男 | 三年级 |
| 5 | 小龙女 | 21 | 女 | 一年级 |
| 10 | 令狐冲 | 23 | 男 | 三年级 |
| 11 | 东方不败 | 23 | 男 | 一年级 |
| 12 | 无崖子 | 23 | NULL | 一年级 |
| 13 | 连城诀 | 23 | NULL | 一年级 |
+----+--------------+-----+------+-----------+
8 rows in set (0.00 sec)
去重复查询:
SELECT DISTINCT gradeName FROM t_student;
mysql> SELECT DISTINCT gradeName FROM t_student;
+-----------+
| gradeName |
+-----------+
| 一年级 |
| 二年级 |
| 三年级 |
+-----------+
3 rows in set (0.01 sec)
对查询结果进行排序:
SELECT 字段1,字段2,字段3.... FROM 表名 GROUP BY 字段名;[HAVING 条件表达式][WITH ROLLUP];
1、GROUP BY单独使用时并无太大意义
2、与GROUP_CONCAT()函数一起使用;
3、与聚合函数一起使用;
4、与HAVING一起使用(对查询结果进行排序)
5、与WITH ROLLUP 一起使用(最后一行加入一个总和行)
查询每个年级所有学生的姓名:
SELECT gradeName,GROUP_CONCAT(stuName) FROM t_student GROUP BY gradeName;
mysql> SELECT gradeName,GROUP_CONCAT(stuName) FROM t_student GROUP BY gradeName;
+-----------+----------------------------------------------------------+
| gradeName | GROUP_CONCAT(stuName) |
+-----------+----------------------------------------------------------+
| 一年级 | 张三,无崖子,东方不败,连城诀,小龙女,李四 |
| 三年级 | 王五,令狐冲,汪峰 |
| 二年级 | 周芷若,黄欧阳锋,杨过,张三丰 |
+-----------+----------------------------------------------------------+
3 rows in set (0.00 sec)
查询每一个年级的学生数量:
SELECT COUNT(stuNAme) AS '学生总数',gradeName AS '年级' FROM t_student GROUP BY gradeName;
mysql> SELECT COUNT(stuNAme) AS '学生总数',gradeName AS '年级' FROM t_student GROUP BY gradeName;
+--------------+-----------+
| 学生总数 | 年级 |
+--------------+-----------+
| 6 | 一年级 |
| 3 | 三年级 |
| 4 | 二年级 |
+--------------+-----------+
3 rows in set (0.00 sec)
查询每个年级的学生,并且筛选出人数大于3的年级:
SELECT COUNT (stuName) AS '学生总数',gradeName AS '年级' FROM t_student GROUP BY gradeName HAVING COUNT(stuName) >3;
mysql> SELECT COUNT(stuName) AS '学生总数',gradeName AS '年级' FROM t_student GROUP BY gradeName HAVING COUNT(stuName) >3;
+--------------+-----------+
| 学生总数 | 年级 |
+--------------+-----------+
| 6 | 一年级 |
| 4 | 二年级 |
+--------------+-----------+
2 rows in set (0.00 sec)
 
查询每个年级的学生并在查询的结果添加一个总和行:
SELECT COUNT(studName ) AS '学生人数',gradeName AS '年级' FROM t_student GROUP BY gradeNAME AS ’总数‘ WITH ROLLUP;
mysql> SELECT COUNT(stuName) AS '学生人数',gradeName AS '年级' FROM t_student GROUP BY gradeName WITH ROLLUP;
+--------------+-----------+
| 学生人数 | 年级 |
+--------------+-----------+
| 6 | 一年级 |
| 3 | 三年级 |
| 4 | 二年级 |
| 13 | NULL |
+--------------+-----------+
4 rows in set (0.00 sec)
查询LIMIT分页:
SELECT 字段1,字段2,字段3 FROM表名LIMIT 条件开始,条件结束;
查询前5条学生的详细信息:
SELECT stuName, age,sex gradeName From t_student LIMIT 0,5;
mysql> SELECT stuName,age,sex,gradeName From t_student LIMIT 0,5;
+-----------+-----+------+-----------+
| stuName | age | sex | gradeName |
+-----------+-----+------+-----------+
| 张三 | 23 | 男 | 一年级 |
| 张三丰 | 25 | 男 | 二年级 |
| 李四 | 22 | 男 | 一年级 |
| 王五 | 23 | 男 | 三年级 |
| 小龙女 | 21 | 女 | 一年级 |
+-----------+-----+------+-----------+
5 rows in set (0.00 sec)
 
 

深入学习之mysql(三)单表操作的更多相关文章

  1. 学习MySQL之单表操作(二)

    ##单表操作 ##创建表 CREATE TABLE t_employee( empno ), ename ), job ), MGR ), Hiredate DATE DEFAULT '0000-00 ...

  2. Mysql(三):表操作

    一 存储引擎介绍 存储引擎即表类型,mysql根据不同的表类型会有不同的处理机制 详见:http://www.cnblogs.com/6324TV/p/8481061.html 二 表介绍 表相当于文 ...

  3. Hibernate学习笔记(一)-->数据库单表操作

    Hibernate框架是一个全ORM映射框架,是一个非常流行的数据库操作框架之一,现在比较流行的还有MyBatis半ORM映射框架 在MyEclipse IDE开发工具中,可以很轻松的搭建Hibern ...

  4. mysql三:表操作

    一.存储引擎介绍 存储引擎即表类型,mysql根据不同的表类型会有不同的处理机制. 详见:点击查看 二.表的介绍 表相当于文件,表中的一条记录就相当于文件的一行内容,不同的是,表中的一条记录有对应的标 ...

  5. orm单表操作

    二.orm简介 ORM:object relation mapping (ORM是“对象-关系-映射”的简称) MVC或者MVC框架中包括一个重要的部分,就是ORM,它实现了数据模型与数据库的解耦, ...

  6. Django单表操作

    一.数据库相关设置 配置ORM的loggers日志: # 配置ORM的loggers日志 LOGGING = { 'version': 1, 'disable_existing_loggers': F ...

  7. MySQL之单表查询 一 单表查询的语法 二 关键字的执行优先级(重点) 三 简单查询 四 WHERE约束 五 分组查询:GROUP BY 六 HAVING过滤 七 查询排序:ORDER BY 八 限制查询的记录数:LIMIT 九 使用正则表达式查询

    MySQL之单表查询 阅读目录 一 单表查询的语法 二 关键字的执行优先级(重点) 三 简单查询 四 WHERE约束 五 分组查询:GROUP BY 六 HAVING过滤 七 查询排序:ORDER B ...

  8. Django系列(三):单表操作

    1.ORM简介 MTV或者MTV框架中包括一个重要的部分,就是ORM,它实现了数据模型与数据库的解耦,即数据模型的设计不需要依赖于特定的数据库,通过简单的配置就可以轻松更换数据库,这极大的减轻了开发人 ...

  9. Django学习笔记(7)——单表操作和多表操作

    单表操作 1,创建模型 创建名为book的APP,在book下的models.py中创建模型: from django.db import models # Create your models he ...

  10. day 46 Django 学习3 数据库单表操作以及反向解析

    前情提要: Django 已经学了不少了, 今天学习链接数据库的操作.以及相关的反向解析等 一:反向解析 1:反向解析模板层 跳转时设定url会随着前面的路由改变而改变         2:反向解析之 ...

随机推荐

  1. [Rails学习之路]Rails路由配置

    如果是使用Rails的默认约定,那么几乎是零配置. 但有些时候,我们可能不得不(或者更喜欢)进行一些特殊的配置. 其实Rails在路由功能中也有很丰富的配置选项. routes.rb文件中靠前的规则优 ...

  2. DongDong坐飞机

    题目连接:https://ac.nowcoder.com/acm/contest/904/D 第一次研究了一下这种题型,还是比较好理解的,因为有半价次数的限制,所以要把每一中情况都写出来,dp[现在的 ...

  3. click

    click简介 Click是一个Python包,用于以可组合的方式创建漂亮的命令行界面,只需要很少的代码.这是“命令行界面创建工具包”.它具有高度可配置性,但具有开箱即用的合理默认值. 点击三点: 任 ...

  4. 基于CXF开发crm服务

    1 基于CXF开发crm服务 1.1 数据库环境搭建 1.2 web项目环境搭建 第一步:创建动态web项目 第二步:导入CXF相关jar包 第三步:配置web.xml <context-par ...

  5. js表单序列化时,非空判断

    在项目中,对于数据的传输一般需要非空的判断,而数据字段较多时一般直接将表单序列化,此时如何判断非空,如下 因为将表单序列化时,数据格式为 trainKind=1&trainKindCode=1 ...

  6. 多线程中使用HttpContext.Current为null的解决办法

    HttpContext.Current.Server.MapPath(logFile)   这个是得到具体路径的方法  正常情况下是可以的 多线程情况下就为null 下边的代码原本的作用是把网站的异常 ...

  7. C#Aspose操作Word & Excel简版(后会研究补充更多功能)

    利用Aspose操作Word & Excel首先要在项目中标引用Aspose.Words.dll和Aspose.Cells.dll. 首先说一说向Word中写入数据,目前做的是向Word中的标 ...

  8. js中的||、&&与!用法

    &&和||在JQuery源代码内尤为使用广泛,由网上找了些例子作为参考,对其用法研究了一下: 1. && function a(){ alert("a&quo ...

  9. 如何在vue项目中使用md5加密

    npm安装: npm install --save js-md5 1.在需要使用的项目文件中引入: import md5 from 'js-md5'; 使用: md5('hello world') / ...

  10. vue-cli的build的文件夹下没有dev-server.js文件,怎么配置mock数据

    因为最新版本的vue-cli已经放弃dev-server.js,只需在webpack.dev.conf.js配置就行 新版webpack.dev.conf.js配置如下: 在const portfin ...