`

day12 mysql复杂sql语句编写

 
阅读更多

SQL基本部分:
1、数据库操作相关SQL ---- database
创建数据库 create database 数据库名称; ------ 在sql后通过 character set 指定数据库本身字符集,如果没有指定将服务器默认
* 服务器默认字符集 mysql安装目录/my.ini [mysqld] default-character-set

查看当前有哪些数据库 show databases;

修改数据库(修改数据库字符集) 数据库字符集存放mysql安装目录/data/数据库文件夹/db.opt
alter database 数据库名称 character set 字符集;
* collate 校对方式 ----- 用于数据库排序; 每一种字符集都存在一种默认校对方式(可以不用修改)

删除数据库 drop database 数据库名称;

切换数据库(设置当前使用数据库) use 数据库名称;
* select database(); 查看当前使用数据库

2、数据表操作相关SQL ---- table表结构
创建数据表 create table 表名(列名 类型(长度) 约束,列名 类型(长度) 约束... ) ----- 在创建表之前必须指定数据库
* 查看当前有哪些数据表 show tables;

查看数据表表结构 desc table;

修改表结构:
修改列类型(长度) : alter table 表名 modify ...
添加一个新列 : alter table 表名 add ...
修改列名称 : alter table 表名 change ...
删除列 : alter table 表名 drop 列名
修改表名 : rename table 旧表名 to 新表名

* table 在创建时 character set 指定表字符集,如果没有指定采用数据库默认字符集

删除表 drop table 表名;

3、数据记录增删改查  insert update delete select
数据记录插入 insert into 表名(列,...)  values(值,...);
* 值的顺序和列顺序一致,个数一致 , 在开发中经常省略列名,值按照表结构所有字段进行设值

数据查看 select * from 表名;

数据记录修改 update 表名 set 列名=值,列名= 值 where 条件语句

数据记录删除 delete from 表名 where 语句
* truncate 与 delete区别 ? truncate删除表,重新创建, delete from 逐行删除----- 性能truncate好于 delete,delete被事务控制,删除后回滚取消删除,truncate不可恢复


select 语句
S - F - W - G - H - O
select ... from ... where ... group by ... having ... order by ... ; 顺序固定的

1、from 指定查询数据表
2、where 前置过滤条件 --- 将表数据过滤掉一部分
3、group by 对where 过滤后数据进行分组
4、having 对分组后结果添加条件过滤
5、select 指定检索哪些字段
6、order by 对检索结果排序

4、数据库备份和恢复
备份命令: mysqldump -u 用户名 -p 数据库名 > sql脚本位置 (回车输入密码)
恢复命令: mysql -u 用户名 -p 数据库名 < sql脚本位置 (回车输入密码 )
* 在mysql连接后,通过source 进行数据库恢复 source sql脚本位置

5、数据库完整性约束 ----- 保证数据表中记录完整性
主键约束 primary key : 用来指定数据表数据记录的唯一标识
唯一约束 unique : 该字段取值唯一
非空约束 not null ; 该字段值不能为null
外键约束 foreign key : 当两个数据表存在关联时,添加外键约束,外键约束引用另一张表主键
条件约束 check : mysql不支持 Oracle支持 check age<100 ; 向数据表存入age值,必须小于100
* 完整性约束有5类

----------------------------------------------------------
多表设计
数据表与数据表之间关系三种:实体之间关系 多对多、一对多、一对一

多对多案例:项目和程序员
一个项目可以由多个程序员参与
一个程序员可以参与多个项目开发

建表原则:多对多关系,必须引入第三张数据表,同时引入另两张实体表主键作为外键

一对多案例:老师与课程
一个老师可以教授多门课程
一门课程只能有一个老师教授

建表原则:一对多关系,在多的一方添加一方 主键作为外键

一对一关系:班级与班长关系
一个班只能有一个班长
一个班长只能负责一个班

* 该关系比较少见
建表原则:一对一关系,可以在任何一方添加 另一方主键作为外键

建表练习:
设计学生成绩管理系统数据表
1、每个教师可以教多门课程
2、每门课程可以由多个学生选修
3、每个学生可以选修多门课程
4、学生选修课程要有成绩

关系表表名,通常用两个实体表表名组合而成!

-------------------------------------------------------------------------------
笛卡尔积
当两个数据表进行关联查询时,用第一张数据表每一条记录去匹配第二张数据表每一条记录。

第一张表10条数据
第二张表20条数据
使用笛卡尔积 结果 10*20 = 200 条记录

在实际开发中,获得笛卡尔积中有意义的记录 ? ---- 连接查询
内连接
外连接

内连接 : 将两张表相同意义字段连接起来
select * from A,B where A.A_ID = B.A_ID; 条件 A表中A_ID与 B表中 A_ID 相等匹配
* 返回结果一定是两个表都存在信息 , 最有意义的信息,如果第一张表记录在第二张表找不到匹配信息,不显示,第二张表记录在第一张表无匹配信息,不显示

第一张表10条数据
第二张表20条数据
内连接 结果 <= 10条

语法:select * from a inner join b on A.A_ID = B.A_ID;
简化:select * from a,b where A.A_ID = B.A_ID;

外连接:左外连接、右外连接、全外连接
左外连接 :用第一张表每条记录去匹配第二张表对应记录,无论是否找到匹配信息,都显示第一张表匹配结果
例如:每个水果价格 ? 没有价格水果也要显示
select * from a left outer join b on A.A_ID = B.A_ID ;

第一张表10条数据
第二张表20条数据
左外连接 --- 10条

右外连接:从第二张表找第一张表匹配记录,无论是否找到,第二张表所有记录都显示
select * from a right outer join b on A.A_ID = B.A_ID ;


第一张表10条数据
第二张表20条数据
右外连接 --- 20条

全外连接:左外连接与右外连接 结果和 ---- 排除重复数据
select * from a full outer join b on A.A_ID = B.A_ID ; ----- MySQL 不支持

使用union关键字实现全外连接效果
select * from A left outer join B on A.A_ID = B.A_ID
union
select * from A right outer join B on A.A_ID = B.A_ID;

------------------------------------------------------------------------------------
关联子查询:将第一个查询结果 ,作为第二个查询条件
查询student表中年龄最大学员的信息
select * from student where age = (select max(age) from student);

等价于
select max(age) from student; ----- 25
select * from student where age = 25; ----- 学生信息

IN/EXISTS 当前查询记录在子查询结果中存在
查询所有成绩小于60分的同学名称

查询studentcource表成绩小于60 所有记录
select student_id from studentcource where score < 60; --- 小于60分学生学号 2,8
再根据id去查询学生表,得知学生姓名
select * from student where id in(2,8);

select * from student where id in(select student_id from studentcource where score < 60);

exists实现上面in 语句效果
select name from student where exists (select * from studentcource where score < 60 and student.id = studentcource.student_id);

select * from studentcource,student where score < 60 and student.id = studentcource.student_id;

select name from student where exists (select * from studentcource where score < 60 and student.id = studentcource.student_id);

* 在实际开发中 exists比 in效率要高

ANY、SOME、ALL 用法
SOME和ANY作用相同的  ----- 一些 >any(1,2,3) 大于任何一个都可以 等价于 >min
ALL ---- 所有  >all(1,2,3) 必须同时大于三个值   等价于 >max

查询获得最高分的学生学号
select max(score) from studentcource; 最高学分
select student_id from studentcource where score = (select max(score) from studentcource);
* 自我比较
select student_id from studentcource where score >=all(select score from studentcource);

查询编号2课程比编号1课程成绩高所有学号
select score from studentcource where cource_id = 2 and score > any(select score from studentcource where cource_id = 1);

select score from studentcource where cource_id = 2; 课程2所有成绩
select score from studentcource where cource_id = 1; 课程1所有成绩

使用union将两个查询结果合并,union 排重重复数据 union all 不会排重重复数据
* 合并时列名必须一致

------------------------------------------------------------------------------------------------------
查询语文课程比数学课程成绩高的所有学生的学号
mysql> select * from cource,studentcource where cource.id = studentcource.cource
_id and cource.name='语文';
+----+------+------------+------------+-----------+-------+
| id | name | teacher_id | student_id | cource_id | score |
+----+------+------------+------------+-----------+-------+
|  1 | 语文 |          1 |          1 |         1 |    80 |
|  1 | 语文 |          1 |          3 |         1 |    71 |
|  1 | 语文 |          1 |          5 |         1 |    60 |
|  1 | 语文 |          1 |          6 |         1 |    76 |
|  1 | 语文 |          1 |         10 |         1 |    77 |
+----+------+------------+------------+-----------+-------+
5 rows in set (0.02 sec)

mysql> select * from cource,studentcource where cource.id = studentcource.cource
_id and cource.name='数学';
+----+------+------------+------------+-----------+-------+
| id | name | teacher_id | student_id | cource_id | score |
+----+------+------------+------------+-----------+-------+
|  2 | 数学 |          1 |          1 |         2 |    90 |
|  2 | 数学 |          1 |          2 |         2 |    53 |
|  2 | 数学 |          1 |          3 |         2 |    70 |
|  2 | 数学 |          1 |          4 |         2 |    90 |
|  2 | 数学 |          1 |          5 |         2 |    70 |
|  2 | 数学 |          1 |          6 |         2 |    88 |
|  2 | 数学 |          1 |          8 |         2 |    71 |
|  2 | 数学 |          1 |          9 |         2 |    88 |
|  2 | 数学 |          1 |         10 |         2 |    76 |
+----+------+------------+------------+-----------+-------+
9 rows in set (0.00 sec)

select t1.student_id,t1.score 语文,t2.score 数学 from (select * from cource,studentcource where cource.id = studentcource.cource_id and cource.name='语文') t1,(select * from cource,studentcource where cource.id = studentcource.cource_id and cource.name='数学') t2 where t1.student_id = t2.student_id and t1.score > t2.score;

查询平均成绩大于70分的同学的学号和平均成绩
* 按人取平均成绩 ------ 分组
select student_id,avg(score) from studentcource group by student_id having avg(score)>70;
* 打印学生姓名
select student.name,t.avgscore from student,(select student_id,avg(score) avgscore from studentcource group by student_id having avg(score)>70) t where student.id = t.student_id;

查询所有同学的学号、姓名、选课数、总成绩
*学生信息:select * from student;
*选课数、总成绩 select student_id,count(*),sum(score) from studentcource group by student_id;

select student.id 学号,student.name 姓名,t.courcenum 选课数, t.sumscore 总成绩 from student,(select student_id,count(*) courcenum,sum(score) sumscore from studentcource group by student_id) t where student.id = t.student_id; 

查询没学过关羽老师课的同学的学号、姓名
* 关羽老师教什么课 select cource.id from teacher,cource where teacher.id = cource.teacher_id and teacher.name='关羽';
* 选过关羽老师课 select distinct student_id from studentcource where cource_id in (select cource.id from teacher,cource where teacher.id = cource.teacher_id and teacher.name='关羽');

select id,name from student where id not in (select distinct student_id from studentcource where cource_id in (select cource.id from teacher,cource where teacher.id = cource.teacher_id and teacher.name='关羽'));

查询学过语文并且也学过数学课程的同学的学号、姓名
* 语文和数据 课程编号  select id from cource where name='语文' or name='数学';
* 学过语文的学生 select * from cource,studentcource where cource.id = studentcource.cource_id and cource.name='语文';
* 学过数学的学生 select * from cource,studentcource where cource.id = studentcource.cource_id and cource.name='数学';

select t1.student_id  from (select * from cource,studentcource where cource.id = studentcource.cource_id and cource.name='语文') t1, (select * from cource,studentcource where cource.id = studentcource.cource_id and cource.name='数学') t2 where t1.student_id = t2.student_id ;

select student.id,student.name from student,(select t1.student_id  from (select * from cource,studentcource where cource.id = studentcource.cource_id and cource.name='语文') t1, (select * from cource,studentcource where cource.id = studentcource.cource_id and cource.name='数学') t2 where t1.student_id = t2.student_id) t where student.id = t.student_id;

查询学过赵云老师所教的所有课的同学的学号、姓名

查询没有学三门课以上的同学的学号、姓名

查询至少有一门课与学号为“1”的同学所学相同的同学的学号和姓名

查询和小李同学学习的课程完全相同的其他同学学号和姓名

查询各科成绩最高和最低的分

查询学生信息和平均成绩

查询上海和北京学生数量

查询不及格的学生信息和课程信息

查询每门功成绩最好的前两名

统计每门课程的学生选修人数(超过两人的进行统计)

把成绩表中“关羽”老师教的课的成绩都更改为此课程的平均成绩

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 


 

分享到:
评论

相关推荐

    mysql的sql语句优化方法面试题总结.docx

    MySQL的SQL语句优化是数据库性能提升的关键环节。在面试中,掌握这些技巧不仅可以展示你的专业能力,还能帮助你在实际工作中提升数据库的运行效率。以下是一些关于SQL语句优化的重要知识点: 1. **避免无意义的查询...

    sql语句大全

    本篇文章将深入探讨SQL语句的主要类型、语法以及在不同数据库系统中的应用。 一、SQL基础 SQL主要包括以下几种语句: 1. 数据查询(SELECT):用于从数据库中检索数据,是最常用的功能之一。可以指定字段、表、条件...

    sql 语句自学宝典

    - **流行的SQL开发工具**:市场上有多种SQL开发工具,如MySQL Workbench、SQL Server Management Studio、Oracle SQL Developer等,这些工具提供了图形界面,使用户能够更方便地进行数据库管理。 #### 第二天:...

    day01-sql安装与SQL语句-笔记.zip

    在本压缩包“day01-sql安装与SQL语句-笔记.zip”中,我们可以预见到包含的内容主要是关于SQL(Structured Query Language)的基础知识,包括SQL的安装过程以及基本的SQL语句。SQL是用于管理和处理关系数据库的强大...

    mysql中获取一天、一周、一月时间数据的各种sql语句写法

    总结,通过上述SQL语句,我们可以有效地在MySQL中获取特定时间段内的数据。在实际应用中,这些技巧对于数据分析、报表生成以及基于时间的查询非常有用。理解并熟练运用这些函数和操作,将极大地提升数据库管理的效率...

    自动执行SQL语句&创建标准的Sql 存储过程

    总的来说,自动执行SQL语句和创建标准的SQL存储过程是数据库管理和开发中的关键技术,它们有助于提升数据处理的自动化水平,简化复杂的操作,并优化性能。理解并熟练运用这些技术,能够让你在面对大量数据和复杂业务...

    万年历数据库,从1970年1月1月开始到2100年12月31日,完整的万年历MySQL数据库的sql建表语句以及插入语句

    总之,一个万年历数据库是一个实用的工具,它通过SQL语句在MySQL中创建并填充数据,提供了一种高效的方式查询和管理跨越多个世纪的日期信息。通过合理的表设计和索引优化,这样的数据库可以支持快速的日期查询,为...

    mysql的sql语句特殊处理语句总结(必看)

    在MySQL中,有些特殊的SQL语句可以帮助我们更高效、更精确地处理数据。以下是一些MySQL SQL语句的特殊处理技巧,这些技巧在日常数据库操作中非常实用。 1. **条件更新**: - `IF` 函数可以用于条件更新,如示例中...

    MySQL训练营视频.zip

    │ day1-不同存储引擎建表语句.sql │ day1_MySQL架构与SQL执行流程-笔记.pdf │ day1_MySQL架构与SQL执行流程-课件.pdf │ day1_MySQL架构与SQL执行流程.mp4 │ day2-相关SQL.sql │ day2_MySQL索引深入剖析-笔记....

    SQL语句21日自学通

    这些工具不仅提供了一个友好的图形界面来编写和执行SQL语句,还包含了数据可视化、性能分析等功能。 - **SQL在编程中的应用**:SQL广泛应用于Web开发、企业级应用开发等领域,作为数据持久层的重要组成部分。通过...

    自己常用的sql语句

    这里我们主要探讨的是在“自己常用的sql语句”这个主题下,与Hive和MySQL相关的SQL知识。 首先,让我们关注Hive SQL,它是在大数据处理领域中广泛使用的工具,尤其适合处理PB级别的数据。在`kpy_create_table.sql`...

    Sql语句 查询本周记录\本月记录\本季度记录\本年记录

    本文将为您提供 MySQL 和 SQL Server 两种数据库管理系统的查询语句,帮助您快速实现这些查询操作。 查询本周记录 MySQL 中,您可以使用以下语句查询本周记录: ```sql SELECT * FROM ht_invoice_information ...

    sql server ,mysql,starrocks性能对比.docx

    **结论**:在复杂查询方面,即使是在低负载环境下,SQL Server仍然表现得比MySQL更快。这一结果可能与两种数据库对查询优化的支持程度有关,也可能是由于查询本身的设计和SQL Server对GROUP BY子句支持的效率更高。...

    SQL Server 和 MySql 语法和关键字的区别

    - MySQL 使用 `EXECUTE` 语句执行动态 SQL,需要先用 `PREPARE` 声明 SQL 语句。 - SQL Server 使用 `EXEC` 或 `EXECUTE` 直接执行动态 SQL。 10. **调用存储过程** - MySQL 通过 `CALL` 函数来调用存储过程,...

    SQL数据库查询语句基础文本——可复制的查询语句

    本资源“SQL数据库查询语句基础文本——可复制的查询语句”提供了丰富的SQL语句实例,不仅方便用户直接在数据库中运行,还配以中文解释,帮助理解其工作原理。 1. **基本查询** SQL的基本查询包括`SELECT`语句,...

    SQL Server 和 MySql 语法和关键字的区别——用于SQLServer到MySql的转换

    例如,在 SQL Server 中,我们可以使用 `SELECT DATEDIFF(day, '2022-01-01', '2022-01-31') FROM table` 来计算两个日期之间的差异,而在 MySql 中,我们可以使用 `SELECT DATEDIFF('2022-01-01', '2022-01-31') ...

    常用sql语句汇总

    以下是对标题"常用sql语句汇总"和描述"一些常用的sql语句、函数介绍以及使用方法汇总"中涉及的知识点的详细解释: 1. **数据查询**: - `SELECT`:这是SQL中最基础的语句,用于从表中检索数据。例如,`SELECT * ...

    Mysql高级-day04.pdf

    它能导出创建表的SQL语句以及插入表数据的SQL语句。使用示例: - 备份单个表:`mysqldump -uroot -pmysql db01 tb_book --add-drop-database --add-drop-table` - 备份所有数据库:`mysqldump -uroot -pmysql --all...

    SQL语句自学通

    ### SQL语句自学通知识点梳理 #### 一、SQL简介及历史 - **SQL简史:** - SQL(Structured Query Language,结构化查询语言)是一种用于管理关系型数据库的标准语言。 - SQL最初由IBM的Raymond Boyce和Donald ...

Global site tag (gtag.js) - Google Analytics