首页 > 代码库 > Mysql(二)
Mysql(二)
一、连接查询
-- 查询课程名称 和年级的名称
-- 非等值连接查询
SELECT subjectname,gradeName FROM `subject`,grade
-- 等值连接查询
SELECT subjectname,gradeName
FROM `subject`,grade
WHERE subject.gradeId=grade.`GradeID`
-- 非等值连接查询
SELECT subjectname,gradeName FROM `subject`,grade
-- 等值连接查询
SELECT subjectname,gradeName
FROM `subject`,grade
WHERE subject.gradeId=grade.`GradeID`
-- 外连接 左外连接 以左表为准,右表中没有数据 返回null
-- 查询课程名称,课时数还有年级名称
SELECT subjectname,gradeName,classHour
FROM `subject` s LEFT JOIN grade g
ON s.gradeId=g.`GradeID`
-- 查询课程名称,课时数还有年级名称
SELECT subjectname,gradeName,classHour
FROM `subject` s LEFT JOIN grade g
ON s.gradeId=g.`GradeID`
-- 外连接 右外连接 以右表为准,左表中没有数据 返回null
SELECT subjectname,gradeName,classHour
FROM `subject` s RIGHT JOIN grade g
ON s.gradeId=g.`GradeID`
SELECT subjectname,gradeName,classHour
FROM `subject` s RIGHT JOIN grade g
ON s.gradeId=g.`GradeID`
-- 自身连接查询
CREATE TABLE IF NOT EXISTS teacher(
id INT(10), -- 老师自身的编号
`name` VARCHAR(20),
pid INT(10) -- 老师对应的导师编号
)
CREATE TABLE IF NOT EXISTS teacher(
id INT(10), -- 老师自身的编号
`name` VARCHAR(20),
pid INT(10) -- 老师对应的导师编号
)
-- 新增教师信息
INSERT INTO teacher
VALUES
(1,‘老师1‘,5),
(2,‘老师2‘,5),
(3,‘老师3‘,5),
(4,‘老师4‘,3),
(5,‘老师5‘,3)
INSERT INTO teacher
VALUES
(1,‘老师1‘,5),
(2,‘老师2‘,5),
(3,‘老师3‘,5),
(4,‘老师4‘,3),
(5,‘老师5‘,3)
-- 查询老师 和对应导师的姓名
SELECT t1.`name` AS ‘老师姓名‘, t2.`name` AS ‘导师姓名‘
FROM teacher t1,teacher t2
WHERE t2.id=t1.pid
SELECT t1.`name` AS ‘老师姓名‘, t2.`name` AS ‘导师姓名‘
FROM teacher t1,teacher t2
WHERE t2.id=t1.pid
二、Order by
-- 查询 课程名称是 数据库结构-1 的所有考试成绩和学生的姓名 并且按照成绩降序进行查看
-- order by 排序 默认是升序 asc desc 降序
SELECT subjectName,StudentResult,studentName
FROM `subject`,result,student
WHERE
student.`StudentNo`=result.`StudentNo`
AND
result.`SubjectNo`=subject.`SubjectNo`
AND
subjectName=‘数据库结构-1‘
ORDER BY StudentResult DESC
-- order by 排序 默认是升序 asc desc 降序
SELECT subjectName,StudentResult,studentName
FROM `subject`,result,student
WHERE
student.`StudentNo`=result.`StudentNo`
AND
result.`SubjectNo`=subject.`SubjectNo`
AND
subjectName=‘数据库结构-1‘
ORDER BY StudentResult DESC
三、limit
-- 查询 课程名称是 数据库结构-1 的所有考试成绩和学生的姓名 并且按照成绩降序进行查看
-- order by 排序 默认是升序 asc desc 降序
-- 分页 使用 limit begin,pageSize
-- begin 从那一条数据开始 (当前页码-1)*pageSize
-- pageSize 每页显示的数量
SELECT subjectName,StudentResult,studentName
FROM `subject`,result,student
WHERE
student.`StudentNo`=result.`StudentNo`
AND
result.`SubjectNo`=subject.`SubjectNo`
AND
subjectName=‘数据库结构-1‘
ORDER BY StudentResult DESC
LIMIT 10,5
-- order by 排序 默认是升序 asc desc 降序
-- 分页 使用 limit begin,pageSize
-- begin 从那一条数据开始 (当前页码-1)*pageSize
-- pageSize 每页显示的数量
SELECT subjectName,StudentResult,studentName
FROM `subject`,result,student
WHERE
student.`StudentNo`=result.`StudentNo`
AND
result.`SubjectNo`=subject.`SubjectNo`
AND
subjectName=‘数据库结构-1‘
ORDER BY StudentResult DESC
LIMIT 10,5
四、子查询
-- 子查询 把自身的查询结果 当作 另一条查询语句的条件来使用
-- 查询 课程名称是 数据库结构-1 并且分数不小于80分的学生姓名和学号
SELECT studentName,studentNo
FROM student
WHERE studentNo IN
(SELECT studentNo
FROM result
WHERE
subjectno=(SELECT subjectno FROM SUBJECT WHERE subjectName=‘数据库结构-1‘)
AND StudentResult>=80
)
-- 查询 课程名称是 数据库结构-1 并且分数不小于80分的学生姓名和学号
SELECT studentName,studentNo
FROM student
WHERE studentNo IN
(SELECT studentNo
FROM result
WHERE
subjectno=(SELECT subjectno FROM SUBJECT WHERE subjectName=‘数据库结构-1‘)
AND StudentResult>=80
)
五、统计函数
-- 统计函数
-- count() sum() avg() min() max()
SELECT
COUNT(*) AS 总记录数,
MAX(studentResult) AS 最高分,
MIN(studentResult) AS 最低分,
AVG(studentResult) AS 平均分,
SUM(studentResult) AS 总成绩
FROM result
-- count() sum() avg() min() max()
SELECT
COUNT(*) AS 总记录数,
MAX(studentResult) AS 最高分,
MIN(studentResult) AS 最低分,
AVG(studentResult) AS 平均分,
SUM(studentResult) AS 总成绩
FROM result
六、执行顺序
-- 执行顺序
FROM 表
WHERE 条件
GROUP BY 分组(列)
HAVING 分组的条件
SELECT 查询的内容
ORDER BY
FROM 表
WHERE 条件
GROUP BY 分组(列)
HAVING 分组的条件
SELECT 查询的内容
ORDER BY
---------代码演示
SELECT sex AS 性别,COUNT(sex) AS 人数
FROM tb
WHERE sex IS NOT NULL
GROUP BY sex
ORDER BY COUNT(sex) DESC
FROM tb
WHERE sex IS NOT NULL
GROUP BY sex
ORDER BY COUNT(sex) DESC
SELECT sex AS 性别,COUNT(sex) AS 人数
FROM tb
WHERE sex IN(‘男‘,‘女‘)
GROUP BY sex
ORDER BY COUNT(sex) DESC
FROM tb
WHERE sex IN(‘男‘,‘女‘)
GROUP BY sex
ORDER BY COUNT(sex) DESC
七、事务隔离
-- 查询 mysql默认的事务隔离级别
SELECT @@tx_isolation
-- 改变事务隔离级别
SET tx_isolation=‘Read-committed‘
-- 开启事务
START TRANSACTION
SELECT @@tx_isolation
-- 改变事务隔离级别
SET tx_isolation=‘Read-committed‘
-- 开启事务
START TRANSACTION
-- 回滚 rollback
-- 提交 commit
Mysql(二)
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。