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

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,193评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,306评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,130评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,110评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,118评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,085评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,007评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,844评论 0 273
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,283评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,508评论 2 332
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,667评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,395评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,985评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,630评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,797评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,653评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,553评论 2 352