| 本帖最后由 小石姐姐 于 2018-10-19 10:57 编辑 
 MySQL多表&事务
 概述:多个表放在一起查询
 出现问题:出现笛卡尔积(就是出现的无用数据)
 解决方法:消除不合理的数据(笛卡尔积)
 通过主键和外键关联(外键的值引用于主键的值)
 多表查询的分类
 内连接查询
 隐式内连接:使用where条件消除无用的数据
 显示内连接:
 语法:select 字段列表 from 表名1 inner join 表名2 on 条件;
 外连接查询
 左外连接:
 语法:select 字段列表 from 表1 left outer join 表2 on 条件;
 查询的是左表所有数据以及其交集部分。
 右外连接:
 语法:select 字段列表 from 表1 right outer join 表2 on 条件;
 查询的是右表所有数据以及其交集部分。
 子查询:
 概念:查询中嵌套查询,称嵌套查询为子查询。
 子查询的不同情况
 第一种情况:子查询作为一个值(单行单列)
 子查询可以作为条件,使用运算符去判断。
 第二种情况:子查询作为一个数组(多行单列)
 子查询可以作为条件,使用运算符IN来判断。
 消除无效数据条件:外键的值=主键的值
 第三种情况:子查询的结果是多行多列的
 子查询可以作为一张虚拟表来进行查询
 事务:
 事务的基本介绍
 概念:如果一个包含多个步骤的业务操作,被事务管理,那么这些操作要么
 同时成功, 要么同时失败
 操作:开启事务:start transaction
 回滚:rollback;
 提交:commit;
 MySQL数据库中事务默认自动提交
 事务提交的两种方式
 自动提交:
 mysql就是自动提交的
 一条DML(增删改)语句会自动提交一次事务
 手动提交:
 Oracle 数据库默认是手动提交事务
 需要先开启事务,再提交
 
 修改事务的默认提交方式:
 查看事务的默认提交方式:SELECT @@autocommit;-- 1 代表自动提交
 0 代表手动提交
 修改默认提交方式:set @@autocommit = 0;
 事务的四大特征
 原子性:是不可分隔的最小操作单位,要么同时成功,要么同时失败
 持久性:当事务提交或回滚后,数据库会持久化保存数据
 隔离性:多个事务之间,相互独立
 一致性:事务操作前后数据总量不变
 事务的隔离级别(了解)
 概念:多个事务之间隔离的,相互独立的,但是如果多个事务操作同一批数据,
 则会引发一些问题,设置不同的隔离级别就可以解决这些问题
 存在问题:
 脏读:一个事务读取到另一个事务中没有提交的数据
 不可重复读:同一个事务中,两次读到的数据不一样
 幻读:一个事务操作(DML)数据表中所有记录,另一个事务添加了一条数据,
 则第一个事务查询不到自己的修改
 隔离级别:
 read uncommitted:读未提交
 产生的问题:脏读、不可重复读、幻读
 read committed:读已提交
 产生的问题:不可重复读、幻读
 repeatable read:可重复读
 产生的问题:幻读
 serializable:串行化
 可以解决所有问题
 注意:隔离级别从小到大安全性越来越高,但效率越来越低
 数据库查询隔离级别:
 select @@tx_isolation;
 数据库设置隔离级别:
 set global transaction isolation level 级别字符串;
 
 
 
 
 
 
 
 
 
 JDBC
 JDBC概念:Java DataBase Connectivity Java数据库连接,java语言操作系统
 JDBC本质:其实就是官方(sun公司)定义了一套操作所有关系型数据库的规则,即接口。各个数据库厂商去实现这套接口,提供数据库驱动jar包。我们可以使用这套接口(JDBC)编程,真正执行的代码是驱动jar包中的实现类
 JDBC:定义了操作所有关系型数据库的规则(接口)
 
 
 
 步骤:
 导入驱动jar包
 复制jar包到项目的libs目录下
 右键-->Add As Library
 注册驱动
 获取数据库连接对象Connection
 定义sql
 获取执行sql语句的对象Statement
 执行sql,接收返回结果
 处理结果
 释放资源
 
 详解各个对象:
 DriverManager:驱动管理对象
 功能:
 注册驱动
 获取数据库连接
 参数:
 url:指定连接的路径
 语法:jdbc:mysql://ip地址(域名):端口号/数据库名称
 user:用户名
 password:密码
 Connection:数据库连接对象
 功能:
 获取执行sql的对象
 管理事务
 Statement:执行sql对象
 ResultSet:结果集对象
 PreparedStatement:执行sql的对象
 
 
 
 JDBC连接池&JDBCTemplate
 1. 概念:其实就是一个容器(集合),存放数据库连接的容器。
 当系统初始化好后,容器被创建,容器中会申请一些连接对象,当用户来访问数据库时,从容器中获取连接对象,用户访问完之后,会将连接对象归还给容器。
 2.实现:
 1. 标准接口:DataSource javax.sql包下的
 1. 方法:
 获取连接:getConnection()
 归还连接:Connection.close()。如果连接对象Connection是从连接池中获取的,那么调用Connection.close()方法,则不会再关闭连接了。而是归还连接
 3. C3P0:数据库连接池技术
 步骤:
 1. 导入jar包 (两个) c3p0-0.9.5.2.jar mchange-commons-java-0.2.12.jar ,
 不要忘记导入数据库驱动jar包
 2. 定义配置文件:
 名称: c3p0.properties 或者 c3p0-config.xml
 路径:直接将文件放在src目录下即可。
 3. 创建核心对象 数据库连接池对象 ComboPooledDataSource
 4. 获取连接: getConnection
 代码:
 1.创建数据库连接池对象
 
 [Java] 纯文本查看 复制代码 DataSource ds = new ComboPooledDataSource();2. 获取连接对象
 
 [Java] 纯文本查看 复制代码 Connection conn = ds.getConnection();4 Druid:数据库连接池实现技术,由阿里巴巴提供的
 步骤:
 1. 导入jar包 druid-1.0.9.jar
 2. 定义配置文件:
 是properties形式的
 可以叫任意名称,可以放在任意目录下
 3. 加载配置文件。Properties
 4. 获取数据库连接池对象:通过工厂来来获取 DruidDataSourceFactory
 5. 获取连接:getConnection
 定义工具类
 1. 定义一个类 JDBCUtils
 2. 提供静态代码块加载配置文件,初始化连接池对象
 3. 提供方法
 1. 获取连接方法:通过数据库连接池获取连接
 2. 释放资源
 3. 获取连接池的方法
 
 
 
 Spring框架对JDBC的简单封装。提供了一个JDBCTemplate对象简化JDBC的开发
 步骤:
 1. 导入jar包
 2. 创建JdbcTemplate对象。依赖于数据源DataSource
 
 [Java] 纯文本查看 复制代码 JdbcTemplate template = new JdbcTemplate(ds);
 3.调用JdbcTemplate的方法来完成CRUD的操作
 update():执行DML语句。增、删、改语句
 queryForMap():查询结果将结果集封装为map集合,将列名作为key,将值作为value 将这条记录封装为一个map集合
 注意:这个方法查询的结果集长度只能是1
 queryForList():查询结果将结果集封装为list集合
 注意:将每一条记录封装为一个Map集合,再将Map集合装载到List集合中
 query():查询结果,将结果封装为JavaBean对象
 query的参数:RowMapper
 一般我们使用BeanPropertyRowMapper实现类可以完成数据到JavaBean的自动封装
 new BeanPropertyRowMapper<类型>(类型.class)
 queryForObject:查询结果,将结果封装为对象
 一般用于聚合函数的查询
 
 |