数据库学习Day03

综合练习题

use empdb;

  1. 查询工资在 1000 到 2000 之间有领导的员工信息

    select * from emp where sal between 1000 and 2000 and manager is not null;

  2. 查询有领导的员工工资按照降序排序取前三条数据

    select * from emp where manager is not null order by sal desc limit 0,3;

  3. 查询 1 号和 3 号部门出现了哪几种不同的工作

    select distinct job from emp where dept_id in(1,3);

  4. 查询每个部门的人数

    select dept_id,count(*) from emp group by dept_id;

  5. 查询每种工作有领导的员工人数

    select job,count(*) from emp where manager is not null group by job;

  6. 查询每个部门的最低工资,最高工资和平均工资

    select dept_id,min(sal) 最低工资, max(sal) 最高工资, avg(sal) 平均工资 from emp group by dept_id;

having

  • where 后面只能写普通字段条件, 不能写聚合函数条件

  • having关键字专门用来写聚合函数条件的, 并且需要和分组group by结合使用, 写在分组的后面

  1. 查询每个部门的平均工资,要求平均工资大于2000;

    select dept_id,avg(sal) a from emp group by dept_id having a>2000;

  2. 查询每种工作的人数,只查询人数大于 1 的

    select job,count(*) c from emp group by job having c>1;

  3. 查询每个部门的工资总和,只查询有领导的员工, 并且要求工资总和大于 5400.

    select dept_id,sum(sal) s from emp

    where manager is not null group by dept_id having s>5400;

  4. 查询每个部门的平均工资, 只查询工资在 1000 到 3000 之间的,并且过滤掉平均工资低于 2000 的

    select dept_id,avg(sal) a from emp where sal between 1000 and 3000 group by dept_id having a>=2000;

子查询(嵌套查询)

  • 把一条SQL语句嵌套到另外一条SQL语句中,称为子查询
  1. 查询工资高于程序员最高工资的员工信息

    select max(sal) from emp where job='程序员';

    select * from emp where sal>(select max(sal) from emp where job='程序员');

  2. 查询工资最高的员工信息

    select * from emp where sal=(select max(sal) from emp);

  3. 查询和孙悟空相同工作的员工信息

    select * from emp where job=(select job from emp where name='孙悟空') and name!='孙悟空';

  4. 查询拿最低工资员工的同事们的信息 (同事指同一部门)

    select min(sal) from emp;

    select dept_id from emp where sal=(select min(sal) from emp);

    select * from emp where dept_id=(select dept_id from emp where sal=(select min(sal) from emp)) and sal!=(select min(sal) from emp);

数值计算

  1. 查询每个人的姓名,工资和年终奖(5个月的工资)

    select name,sal,5*sal 年终奖 from emp;

  2. 给每个2号部门的员工涨薪5块钱

    update emp set sal=sal+5 where dept_id=2;

关联关系

  • 创建表时,表和表之间存在的业务关系

  表之间存在哪几种关系?

       1. 一对一:有AB两张表, A表中的一条数据对应B表中的一条数据, 同时B表中的一条数据也对应A表中的一条数据.

         2.一对多:有AB两张表, A表中的一条数据对应B表中的多条数据, 同时B表中的一条数据对应A表中的一条数据.

        3.多对多:有AB两张表, A表中的一条数据对应B表中的多条数据, 同时B表中的一条数据也对应A表中的多条数据.

 

 

  • 如何建立关系:
    • 一对一: 在AB两张表中任意一张表里面添加一个建立关系的字段指向另外一张表的主键
    • 一对多: 在AB两张表中,表示多的表中添加建立关系的字段指向另外一张表的主键
    • 多对多: 在单独的关系表中添加两个建立关系的字段指向另外两张表的主键

关联查询

  • 同时查询多张表数据的查询方式称为关联查询

  • 三种关联查询的方式:

    • 等值连接
    • 内连接
    • 外连接

等值连接

  • 格式: select 字段信息 from A,B where A.x=B.x(关联关系) and 其它条件
  1. 查询每个员工的姓名和对应的部门名
select e.name,d.name from emp e,dept d 
where e.dept_id=d.id;
  1. 查询工资高于2000的员工姓名,工资和部门名称

    select e.name,sal,d.name
    from emp e,dept d 
    where e.dept_id=d.id and sal>2000;
  2. 查询孙悟空的部门地址

    select loc
    from emp e,dept d
    where e.dept_id=d.id and e.name='孙悟空';

内连接

  • 内连接和等值连接作用一样, 查询到的是两个表之间的交集数据(有关系的数据)

​ insert into emp(name,sal) values('灭霸',5);

  • 内连接格式: select 字段信息 from A join B on A.x=B.x(关联关系) where 其它条件;
  1. 查询每个员工的姓名和对应的部门名
select e.name,d.name
from emp e join dept d on e.dept_id=d.id;
  1. 查询工资高于2000的员工姓名,工资和部门名称

    select e.name,sal,d.name
    from emp e join dept d on e.dept_id=d.id
    where sal>2000;
  2. 查询孙悟空的部门地址

select loc
from emp e join dept d on e.dept_id=d.id
where e.name='孙悟空';

外连接

  • 内连接和等值连接作用一样, 查询到的是两个表之间的交集数据

  • 外连接查询的是一张表的全部和另外一张表的交集

  • 格式: select 字段信息 from A left/right join B on A.x=B.x where 其它条件;

  1. 查询所有员工姓名和对应的部门名

​ insert into emp(name,sal) values('灭霸',5);

select e.name,d.name
from emp e left join dept d on e.dept_id=d.id;
  1. 查询所有部门的工作地点,和对应的员工姓名,工作
select loc,e.name,job
from emp e right join dept d on e.dept_id=d.id;

综合练习题

  1. 查询工资高于程序员平均工资的员工信息

    select * from emp where sal>(select avg(sal) from emp where job='程序员');

  2. 查询工作人数为1的 工作名称

    select job from emp where job is not null group by job having count(*)=1;

  3. 查询1号和2号部门中工资大于2000的员工姓名和部门名

    select e.name,d.name

    from emp e join dept d on e.dept_id=d.id

    where dept_id in(1,2) and sal>2000;

  4. 查询所有员工的名称,工资和对应的部门信息

    select e.name,sal,d.*

    from emp e left join dept d on e.dept_id=d.id;

JDBC

  • Java DataBase connectivity: Java数据库连接
  • 学习JDBC主要学习的是如何通过Java代码执行SQL语句
  • JDBC是Sun公司提供的一套专门用于Java语言和数据库软件进行连接的API(Application Programma Interface应用程序编程接口),Sun公司为了避免Java程序员每一种数据库软件都学习一套全新的方法, Sun公司通过JDBC接口定义好了方法名,让各个数据库的厂商根据此方法名写各自的实现类(驱动), 这样的话Java程序员只需要学会JDBC接口中方法的调用即可访问任何数据库软件, 甚至换数据库时代码都不需要改变. 这样的话大大提高了开发效率.

 

如何使用JDBC连接数据库软件

  1. 创建Maven工程 jdbc01

  2. 在pom.xml文件中添加引入MySQL驱动(jar包) 的依赖.

 

//1. 获取数据库连接  异常抛出
Connection conn = DriverManager.getConnection(
        "jdbc:mysql://localhost:3306/empdb?characterEncoding=utf8&serverTimezone=Asia/Shanghai&useSSL=false",
        "root","root");
System.out.println("连接对象:"+conn);
//2. 创建执行SQL语句的对象
Statement s = conn.createStatement();
//3. 执行SQL语句 execute=执行
s.execute("create table jdbct1(name varchar(20),age int)");
//4. 关闭资源
conn.close();
System.out.println("执行完成!");

Statement执行SQL语句的对象

  • execute("sql"); 可以执行任意SQL语句, 推荐执行数据库相关和表相关的SQL
  • int row = executeUpdate("sql"); 此方法执行增删改相关的SQL语句. row代表生效的行数
  • ResultSet rs = executeQuery("sql"); 此方法专门用于执行查询相关的SQL语句, ResultSet是结果集对象, 里面装着查询回来的所有数据

DBCP

  • DataBaseConnectionPool: 数据库连接池

  • 作用: 是将连接重用,避免了频繁开关连接导致的资源浪费,从而提高执行效率

 

  • 如何使用数据库连接池?

    • 在pom.xml里面添加数据库连接池的依赖 ,从苍老师文档服务器中找到依赖

    • 相关代码:

  • //创建数据库连接池
    DruidDataSource dds = new DruidDataSource();
    //设置连接数据库的信息
    dds.setUrl("jdbc:mysql://localhost:3306/empdb?characterEncoding=utf8&serverTimezone=Asia/Shanghai&useSSL=false");
    dds.setUsername("root");
    dds.setPassword("root");
    //设置初始连接数量
    dds.setInitialSize(3);
    //设置最大连接数量
    dds.setMaxActive(5);
    //获取连接对象  异常抛出
    Connection conn = dds.getConnection();
    System.out.println("连接:"+conn);
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

专注摸鱼的汪

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值