转载至:https://www.liyongzhen.com/

在这一小节,我们将学习DriverManager对象和connection对象。

DriverManager对象用于从驱动里获取一个connection对象。

而connection对象功能颇多,可管理连接、管理事务、建立语句对象等。


加载JDBC驱动程序

在打开与数据库的JDBC连接之前,您需要做的第一件事是加载数据库的JDBC驱动程序。现在已经不需要程序员做这些事啦,因为从Java 6开始,Java 已经内置这步操作。

Java之前是这样加载JDBC驱动程:

语法:

1
Class.forName("driverClassName");

加载MySQL数据库:

1
Class.forName("com.mysql.jdbc.Driver");

打开JDBC连接

可以通过调用java.sql.DriverManager类方法getConnection()打开JDBC Connection。 这种方法有三种花样。

使用URL打开连接

第一种方法仅将数据库的URL作为参数。

1
2
3
String url = "jdbc:mysql://127.0.0.1:3306/dbname";
Connection connection =
    DriverManager.getConnection(url);

url是数据库的URL。不同的数据库url值不一样,上面是MySQL数据库的URL。

使用URL,用户名和密码打开连接

第二种方法将数据库的URL,用户名和密码作为参数。

1
2
3
4
5
String url = "jdbc:mysql://127.0.0.1:3306/dbname";
String user = "root";
String password = "123456";
Connection connection =
    DriverManager.getConnection(url,user,password);

user和password参数是数据库的用户名和密码。

使用URL和Properties对象打开连接

第三种方法是将数据库URL和Properties对象作为参数

1
2
3
4
5
6
String url = "jdbc:mysql://127.0.0.1:3306/dbname";
Properties properties = new Properties( );
properties.put( "user", "root" );
properties.put( "password", "123456" );
Connection connection =
    DriverManager.getConnection(url, properties);

Properties对象用于在打开连接时传递数据库所需的特殊属性。


关闭JDBC连接

当JDBC操作完成(执行完查询、删除、修改)后,应关闭它。

关闭连接有两种花样。

普通的close方法

这是通过调用Connection.close()方法完成的,如下所示:

1
connection.close();

数据库连接占用了一定数量的资源,因此关闭JDBC连接非常重要。

通过Try-With-Resources关闭连接

可以通过Java 7中添加的Java Try-with-resources自动关闭JDBC Connection 。下面的示例演示那如何使用Try-with-resources关闭连接:

1
2
3
4
5
6
7
8
9
String url = "jdbc:mysql://127.0.0.1:3306/dbname";
String user = "root";
String password = "123456";
 
try(Connection connection =
    DriverManager.getConnection(url, user, password)) {
 
    //其它业务代码
}

Connection在try块的括号内打开。

在try语句块中,可以像往常一样使用数据库连接。

一旦执行退出try块,Connection将自动关闭。

这样就不会忘记自己关闭Connection。


事务

事务的概念是:所有的操作要么同时成功,要么同时失败。

在JDBC里执行事务需要两步:先开户事务,再提交事务。如果事务失败,就产生事务回滚(所有的操作都捎回)。

在JDBC里有两种方式执行事务:一是自动执行,二是手动执行。

自动执行事务

Connection默认是自动提交事务,也可以手动开户自动提交事务。

1
connection.setAutoCommit(true);

手动执行事务

Connection setAutoCommit()方法,当参杂是false时,是手动提交事务。

在手动提交模式,则必须通过调用Connection commit()方法显式提交每个数据库事务。

1
2
3
4
5
connection.setAutoCommit(false);
 
// 其它业务代码
 
connection.commit();

回滚

如果事务执行失败时,就会触发回滚操作,所有的操作都取消。

1
2
3
4
5
6
7
8
9
try{
    connection.setAutoCommit(false); //开启手动提交事务
 
    // 其它业务代码
 
    connection.commit();
} catch (SQLException e) {// 产生异常
    connection.rollback();  // 事务回滚
}

建立语句

Connection 可建立Statement对象和PreparedStatement对象。

Statement对象

Statement对象可用于对数据库执行SQL更新 ,或对数据库执行SQL查询 。

1
Statement statement =connection.createStatement();

PreparedStatement对象

PreparedStatement对象,叫预处理对象,PreparedStatement对象可以对数据库执行SQL更新,或对数据库执行SQL查询。

1
PreparedStatement pre = connection.prepareStatement(sql);

元数据对象

Connection 对象可以获取DatabaseMetaData对象,DatabaseMetaData对象可以获取数据库的相关信息,比如:表、主键、列、索引等。

1
DatabaseMetaData metaData = connection.getMetaData();

JDBC 连接的更多相关文章

  1. JDBC连接SQL Server代码模板

    *                  JDBC连接SQL Server数据库 代码模板* Connection: 连接数据库并担任传送数据的任务:* Statement :  执行SQL语句:* Re ...

  2. JDBC连接MySQL数据库代码模板

    下面这个例子是最简单的JDBC连接MySQL数据库的例子. 一般步骤: 1.注册驱动: 2.建立连接: 3.创建语句: 4.处理结果: 5.释放资源. 注意: 1.软件开发环境:MyEclipse 8 ...

  3. Java操作Sqlite数据库-jdbc连接

    Java操作Sqlite数据库步骤: 1. 导入Sqlite jdbc 本文使用sqlite-jdbc-3.7.2.jar,下载地址 http://pan.baidu.com/s/1kVHAGdD 2 ...

  4. Field 'id' doesn't have a default value(jdbc连接错误)

    JDBC 连接错误: 编写数据库连接增添数据时,出现以下错误: error : java.sql.SQLException: Field 'id' doesn't have a default val ...

  5. JDBC连接MySQL 方法 实例及资料收集

    JDBC连接MySQL 方法 实例及资料收集 准备工作 首先,安装MySQL,配置用户名和密码,创建数据库. 可参见之前的文章: http://www.cnblogs.com/mengdd/p/315 ...

  6. java jdbc 连接mysql数据库 实现增删改查

    好久没有写博文了,写个简单的东西热热身,分享给大家. jdbc相信大家都不陌生,只要是个搞java的,最初接触j2ee的时候都是要学习这么个东西的,谁叫程序得和数据库打交道呢!而jdbc就是和数据库打 ...

  7. Java使用JDBC连接MySQL数据库

    1.引用 JDBC(Java Data Base Connectivity,java数据库连接)是一种用于执行SQL语句的Java API,可以为多种关系数据库提供统一访问,它由一组用Java语言编写 ...

  8. jdbc连接oracle数据库

    /*** 通过改变配置文件来连接不同数据库*/package com.xykj.jdbc; import static org.junit.Assert.*; import java.io.Input ...

  9. JDBC连接各种数据库的字符串,就是不好记

    JDBC连接各种数据库的字符串大同小异,在此总结一下,备忘. oracle    driverClass:oracle.jdbc.driver.OracleDriver    url:jdbc:ora ...

  10. Crystal Reports 2008(水晶报表) JDBC连接mysql数据库

    在本blog中,主要介绍的是Crystal Reports 2008使用JDBC连接mysql数据库. 在连接之间,首先要确认你电脑上面都安装了mysql数据库. 其次,就是jdbc连接数据时候所使用 ...

随机推荐

  1. 洛谷P1197 [JSOI2008]星球大战

    题目 由于题目不要求强制在线,所以可以离线. 而离线的话就会带来许多便利,所以我们可以先处理出全部打击后的图,通过并查集来判断是否连通. 然后再从后往前枚举,得出答案 #include <bit ...

  2. 「ZJOI Day2」游记

    Day-1 晚上一直在出自己做的模拟赛的T1,真的快要死掉了. 分类讨论几十种情况. 窝还是找了Bluesky大佬一起来验题,她瞬间就A掉了这一道题目...自闭了.. 诶,我还是太弱了. 之前教练组织 ...

  3. 数论ex

    数论ex 数学学得太差了补补知识点or复习 Miller-Rabin 和 Pollard Rho Miller-Rabin 前置知识: 费马小定理 \[ a^{p-1}\equiv 1\pmod p, ...

  4. 指路Reactive Programming

    指路Reactive Programming Mar 02, 2016 in Engineering 我在工作中采用Reactive Programming(RP)已经有一年了,对于这个“新鲜”的辞藻 ...

  5. 应用系统如何分析和获取SQL语句的执行代码

    大部分开发人员都有这样一个需求,在程序连接数据库执行时,有时需要获取具体的执行语句,以便进行相关分析,这次我向大家介绍一下通用权限管理系统提供的SQL语句执行跟踪记录,直接先看看代码吧:(这个功能我也 ...

  6. IIS8的SNI功能实现同一服务器多HTTPS站点

    名词解释: SNI指是一项用于改善SSL/TLS的技术,在SSLv3/TLSv1中被启用.它允许客户端在发起SSL握手请求时(具体说来,是客户端发出SSL请求中的ClientHello阶段),就提交请 ...

  7. zabbix模板化监控

    zabbix模板化监控 1. 实验简述 在zabbix监控中,有很多组的概念,具体有以下几种: 1. 主机和主机组,相同类型/应用的主机,可以归属于同一个主机组 2. item和application ...

  8. 如何为 Jupyter Notebook 安装代码提示功能

    按照上一篇博客安装完 Python 和 Jupyter Notebook 后,我们已经可以使用 Notebook 愉快的编写 Python 代码了,但是发现它不像其他编辑器那样会弹出代码提示,这稍微有 ...

  9. HDU 1228(字符串处理)

    题意是将所给算式求出结果. 用的方法非常麻烦,开始没考虑到零也需要处理,以为遇上零直接跳过即可,知道发现零可以占位,比如 one zero 值为 10 而不是 1…… 代码如下: #include & ...

  10. java 代码

    java 里的 pandas tablesaw DataFrame 再有就是 spark 了 java 代码规范 Java8特性详解 lambda表达式 Stream Sonar 规则检测 sprin ...