JDBC是什么?
JDBC(Java DataBase Connectivity) 是一组用于执行SQL语句的Java API,
它由一组用Java语言编写的类和接口组成,可以为多种关系型数据提供统一访问
。它是一种标准,是由oracle公司制定的一套使用Java语言访问数据库的语言的标注。
JDBC提供的常用接口和类
1.DriverManager:管理数据库驱动程序,用于建立数据连接
2.Driver:提供哥哥数据库厂商的接口,每一个数据库厂商要想可以使用java语言
来与他们的数据库进行通信,必须实现此接口(主要处理与数据服务之间的通信)
3.Connection:此接口具有用于联系数据库的所有方法
4.Statemen: 从此接口创建对象将SQL语句提交到数据库
5.ResutlSet:在使用Statement对象执行SQL查询后,这个对象保存从数据检索的数据
6.SQLException:处理数据库应用程序中发生的异常
JDBC入门
导包
加载驱动
创建数据库的连接
闯将Statement对象
写sql
将sql传入Satement对象执行sql
PrepareStatement接口
1. 它是扩展了Statement的接口(PreparedStatement本身也是接口)
2. 功能比Statement更强大
3. 可以动态地提供/接受参数
4. 创建PreparedStatement对象 --> conn.prepareStatement(通过Connection对象获取)
5. 可以使用占位符(?)来进行数据绑定
6. 通过stmt.setInt(1, 35);绑定参数
JDBC的事务处理
jdbc默认情况下每执行一条sql就会提交到数据库一次,因为jdbc默认提交事务
的方式是自动提交,但是在正常的业务逻辑下,一个业务正常要执行多条sql
语句,如果每执行一条sql都进行事务提交就很容易出现前后数据不一致的问题,
所以要保证这一组的sql语句操作都在一个事务管理中,所以我们要取消
JDBC的默认事务提交
1.使用Connection对象的SetAutoCommit()方法关闭它的自动提交
2.手动提交事务调用connection的commit()方法
3.事务回滚调用connectinon的rollback()方法
## 第五章 JDBC批量处理
> 使用JDBC进行批处理的对象有两个:AA
>
> > 1. Statement
> > 2. PreparedStatement
* Statement
* * 介绍
```
①使用Statement对象批量添加要执行的SQL语句,事例如下:
statement.addBatch(sql1);
statement.addBatch(sql2);
statement.addBatch(sql3);
statement.addBatch(sql4);
②执行批处理SQL语句:statement.executeBatch();
③清除批处理命令:statement.clearBatch();
```
* * 代码
```
Statement statement = connection.createStatement();
//批量准备SQL
String sql1="INSERT INTO user(user_name,price,create_time) VALUES('AA',12.12,NOW())";
String sql2="INSERT INTO user(user_name,price,create_time) VALUES('BB',13.12,NOW())";
String sql3="INSERT INTO user(user_name,price,create_time) VALUES('CC',14.12,NOW())";
String sql4="DELETE FROM user WHERE user_id=100";
//批量添加SQL
statement.addBatch(sql1);
statement.addBatch(sql2);
statement.addBatch(sql3);
statement.addBatch(sql4);
//批量执行
statement.executeBatch();
```
* PreparedStatement
* * 代码
```
String sql="INSERT INTO user(user_name,price,create_time) VALUES(?,?,?)";
PreparedStatement prepareStatement = connection.prepareStatement(sql);
//绑定参数1
prepareStatement.setString(1, "AA");
prepareStatement.setDouble(2, 12.12);
prepareStatement.setDate(2, new Date(new java.util.Date().getTime()));
prepareStatement.addBatch();
//绑定参数2
prepareStatement.setString(1, "BB");
prepareStatement.setDouble(2, 12.12);
prepareStatement.setDate(2, new Date(new java.util.Date().getTime()));
prepareStatement.addBatch();
//执行
prepareStatement.executeBatch();
```
* Statement和PrepareStatement的优缺点:
```
1.Statement可以添加不同的SQL语句INSERT UPDATE DELETE可以同时进行批处理,但是效率相对较差
2.PrepareStatement执行同一条SQL不同参数的SQL语句,但是效率相对较高
大字段介绍
对于字段长度要求超过 255 个的情况下,MySQL 提供了 TEXT 和 BLOB 两种类型。根据存储数据的大小,它们都有不同的子类型。这些大型的数据用于存储文本块或图像、声音文件等二进制数据类型
6.2 大字段类型
4种文本: TINYTEXT(0-255字节)、TEXT(0-65535字节)、MEDIUMTEXT(0-16777215字节) 和 LONGTEXT(0-4294967295字节)
4种二进制: TINYBLOB(0-255字节)、BLOB(0-65535字节)、MEDIUMBLOB(0-16777215字节) 和 LONGBLOB(0-4294967295字节)