JDBC

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字节)

你可能感兴趣的:(JDBC)