Python连接Liunx中mysql数据库-多表查询【10个经典案例】

有目标就不怕路远。年轻人.无论你现在身在何方.重要的是你将要向何处去。只有明确的目标才能助你成功。没有目标的航船.任何方向的风对他来说都是逆风。因此,再遥远的旅程,只要有目标.就不怕路远。没有目标,哪来的劲头?一车尔尼雷夫斯基

导读:本篇文章讲解 Python连接Liunx中mysql数据库-多表查询【10个经典案例】,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com,来源:原文

在这里插入图片描述
关于Python连接liunx中mysql数据库的方式在这一篇文章
Python连接Liunx中mysql数据库-保姆级教程
关于Python针对liunx中的mysql数据库进行增删改查操作的文章在这一篇可以看一下
Python连接Liunx中mysql数据库-增删改查
对于单表查询的学习可以看这一篇文章
Python对liunx中mysql数据库进行单表查询 10个案例带你了解
今天持续分享Liunx连接mysql数据库进行多表查询
首先创建两个表

1.dept表

CREATE TABLE `dept` (
  `dept1` varchar(10) DEFAULT NULL,
  `dept_name` varchar(20) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=latin1;

插入数据

在这里插入图片描述

2.emp表

CREATE TABLE `emp` (
  `id` varchar(10) DEFAULT NULL,
  `name` varchar(25) DEFAULT NULL,
  `age` varchar(10) DEFAULT NULL,
  `worktime` varchar(10) DEFAULT NULL,
  `dept2` varchar(10) DEFAULT NULL,
  `incoming` int(10) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=latin1;

插入数据

在这里插入图片描述

python中连接liunx中mysql数据库

import pymysql
db = pymysql.connect(host='192.168.52.129',#数据库的ip地址
                     user='root',#连接名
                     passwd='',#你的密码
                     database='test',#数据库名称
                     port=3306)#端口号
curs = db.cursor()

1.列出每个部门里面有那些员工及部门名称

sql1 ='select name,dept_name from dept left join emp on dept.dept1 = emp.dept2;'
curs.execute(sql1)
print(curs.fetchall())

在这里插入图片描述

2.运维部门的收入总和

sql1 ='select sum(incoming) from dept left join emp on dept.dept1 = emp.dept2 where dept_name="yunwei";'
curs.execute(sql1)
print(curs.fetchall())

在这里插入图片描述

3.zhubo部入职员工的员工号

sql1 ='select id from dept left join emp on dept.dept1 = emp.dept2 where dept_name="HR";'
curs.execute(sql1)
print(curs.fetchall())

在这里插入图片描述

4.财务部门收入超过3000元的员工姓名

sql1 =‘select name from dept left join emp on dept.dept1 = emp.dept2 where dept_name=“chaiwu” and incoming>3000;’
curs.execute(sql1)
print(curs.fetchall())
在这里插入图片描述

5.找出zhubo部收入最低的员工的入职时间;

sql1 ='select min(incoming),worktime from dept left join emp on dept.dept1 = emp.dept2 where dept_name="zhubo" GROUP BY worktime;'
curs.execute(sql1)
print(curs.fetchall())

在这里插入图片描述

6.找出年龄小于平均年龄的员工的姓名,ID和部门名称

sql1 ='select name,id,dept_name from dept left join emp on dept.dept1 = emp.dept2 where age<(select avg(age) from emp);'
curs.execute(sql1)
print(curs.fetchall())

在这里插入图片描述

7.列出每个部门收入总和高于5000的部门名称

sql1 ='select dept_name from dept left join emp on dept.dept1 = emp.dept2 group by dept_name having sum(incoming)>5000;'
curs.execute(sql1)
print(curs.fetchall())

在这里插入图片描述

8.查出财务部门工资少于20000元的员工姓名

sql1 ='select name from dept left join emp on dept.dept1 = emp.dept2 where incoming<10000 and dept_name = "chaiwu";'
curs.execute(sql1)
print(curs.fetchall())

在这里插入图片描述

9.求收入最高的员工姓名及所属部门名称

sql1 ='select name,dept_name from dept left join emp on dept.dept1 = emp.dept2 where incoming=(select max(incoming) from emp join dept on emp.dept2 = dept.dept1) ;'
curs.execute(sql1)
print(curs.fetchall())

在这里插入图片描述

10.求员工收入小于5000元的员工部门编号名字及其部门名称;

sql1 ='select name,id,dept_name from dept left join emp on dept.dept1 = emp.dept2 where incoming<5000 '
curs.execute(sql1)
print(curs.fetchall())

在这里插入图片描述

在这里插入图片描述

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/134078.html

(0)
飞熊的头像飞熊bm

相关推荐

发表回复

登录后才能评论
极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!