Java JDBC 基础
JDBC API 包含以下几个核心部分:
1:JDBC 驱动
2:Connections (连接)
3:Statements (声明)
4:Result Sets (结果集)
JDBC: 打开数据库连接
Loading the JDBC Driver(加载数据库驱动)
在打开数据库连接前必须先加载数据库驱动
- Class.forName("driverClassName");
Opening the Connection(打开连接)
- String url = "jdbc:mysql://127.0.0.1:3306/appName";
- String user = "root";
- String password = "123456";
- Connection connection = DriverManager.getConnection(url,user,password);
Closing the Connection(关闭连接)
- connection.close();
JDBC:查询数据库
对数据库进行操作,你需要创建SQL Statement,然后发送至数据库,得到返回结果.
- Statement statement = conn.createStatement();
创建Statement后执行查询
- String sql = "select * from table";
- ResultSet result = statement.executeQuery(sql);
对结果集进行迭代
- while(result.next()){
- String name = result.getString("name");
- int age = result.getInt("age");
- }
- //根据数据库字段名获取对应的数据
- result.getString("columnName");
- result.getInt("columnName");
- result.getLong("columnName");
- result.getDouble("columnName");
- result.getBigDecimal("columnName");
- //通过字段索引顺序获取字段数据,索引从1开始
- result.getInt(1);
- result.getString(2);
- //通过字段名找到数据库对应字段索引的位置
- int columnIndex = result.findColumn("columnName");
如果需要迭代大量数据,使用索引的效率要比查询字段名获取数据要快.
完成数据迭代后需要对resultSet和statement进行关闭.
- result.close();
- statement.close();
JDBC:更新数据库
更新数据库包含更新数据库记录和删除数据库记录
excuteUpdate()方法可以用来更新和删除数据库记录.
更新记录
- Statement statement = conn.createStatement();
- String sql = "update table set name = ’name‘ where id = 1“;
- int rowAffected = statement.executeUpdate(sql);
rowsAffected代表有多少条记录被更新了.
删除记录
像上面那样更新直接执行sql语句
JDBC:结果集
创建结果集
可以通过执行Statement和PreparedStatement来创建结果集.
- Statement statement = conn.createStatement();
- String sql = "select * from table";
- ResultSet result = statement.executeQuery(sql);
- PrepareStatement statement = conn.preparedStatement();
- ResultSet result = statement.executeQuery(sql);
更新结果集
- result.updateString("name","alex");
- result.updateInt("age",33);
- result.updatBigDecimal("cofficient",new BigDecimal("0.1343");
- result.updateRow();
数据将在调用updateRow()方法后才将数据真正更新至数据库,如果updateRow()执行与事物中则需等到事物提交才将数据提交更新.
JDBC:PreparedStatement
PreparedStatement特性:
更容易操作sql statement 参数
可对preparedstatement的重用
更容易的批处理
操作示例
- String sql = "update people set firstname=? , lastname=? where id=?";
- PreparedStatement preparedStatement = connection.prepareStatement(sql);
- preparedStatement.setString(1, "Gary");
- preparedStatement.setString(2, "Larson");
- preparedStatement.setLong (3, 123);
- int rowsAffected = preparedStatement.executeUpdate();
创建PreparedStatement
- String sql = "select * from people where firstname=? and lastname=?";
- PreparedStatement preparedStatement = connection.prepareStatement(sql);
- preparedStatement.setString(1, "John");
- preparedStatement.setString(2, "Smith");
- ResultSet result = preparedStatement.executeQuery();
PreparedStatement的重用
- String sql = "update people set firstname=? , lastname=? where id=?";
- PreparedStatement preparedStatement = connection.prepareStatement(sql);
- preparedStatement.setString(1, "Gary");
- preparedStatement.setString(2, "Larson");
- preparedStatement.setLong (3, 123);
- int rowsAffected = preparedStatement.executeUpdate();
- preparedStatement.setString(1, "Stan");
- preparedStatement.setString(2, "Lee");
- preparedStatement.setLong (3, 456);
- int rowsAffected = preparedStatement.executeUpdate();
Statement Batch Updates
- Statement statement = null;
- try{
- statement = conn.createStatement();
- statement.addBatch("update people set firstname='John' where id=123");
- statement.addBatch("update people set firstname='Eric' where id=456");
- int[] recordsAffected = statement.executeBatch();
- }finally{
- if(statent != null) statement.close();
- }
PreparedStatement Batch Updates
- String sql = "update people set firstname=? , lastname=? where id=?";
- PreparedStatement preparedStatement = null;
- try{
- preparedStatement =
- connection.prepareStatement(sql);
- preparedStatement.setString(1, "Gary");
- preparedStatement.setString(2, "Larson");
- preparedStatement.setLong (3, 123);
- preparedStatement.addBatch();
- preparedStatement.setString(1, "Stan");
- preparedStatement.setString(2, "Lee");
- preparedStatement.setLong (3, 456);
- preparedStatement.addBatch();
- int[] affectedRecords = preparedStatement.executeBatch();
- }finally {
- if(preparedStatement != null) {
- preparedStatement.close();
- }
- }
开始事务
- conn.setAutoCommit(false);
事务回滚
- conn.rollback();
提交事务
- conn.commit();
示例
- Connection connection = ...
- try{
- connection.setAutoCommit(false);
- Statement statement1 = null;
- try{
- statement1 = connection.createStatement();
- statement1.executeUpdate(
- "update people set name='John' where id=123");
- } finally {
- if(statement1 != null) {
- statement1.close();
- }
- }
- Statement statement2 = null;
- try{
- statement2 = connection.createStatement();
- statement2.executeUpdate(
- "update people set name='Gary' where id=456");
- } finally {
- if(statement2 != null) {
- statement2.close();
- }
- }
- connection.commit();
- } catch(Exception e) {
- connection.rollback();
- } finally {
- if(connection != null) {
- connection.close();
- }
- }
Java JDBC 基础的更多相关文章
- Java JDBC基础学习小结
JDBC是一个Java应用程序接口,作用是封装了对数据库的各种操作.JDBC由类和接口组成,使用Java开发数据库应用都需要4个主要的接口:Driver.Connection.Statement.Re ...
- Java JDBC 基础知识
一.JDBC常用接口.类介绍 JDBC提供对独立于数据库统一的API,用以执行SQL命令.API常用的类.接口如下: DriverManager 管理JDBC驱动的服务类,主要通过它获取Connect ...
- Java JDBC高级特性
1.JDBC批处理 实际开发中需要向数据库发送多条SQL语句,这时,如果逐条执行SQL语句,效率会很低,因此可以使用JDBC提供的批处理机制.Statement和PreparedStatemen都实现 ...
- Java JDBC的基础知识(五)
本文主要记录JDBC基础知识之后的部分内容.另外,我看到<Java核心基础2>中第四章是主要介绍数据库编程的.里面有一些说明和应用特别灵活,有些部分也太容易理解,建议大家看一下.这篇是依然 ...
- Java JDBC的基础知识(三)
在前面的Java JDBC的基础知识(二)和(三)中,主要介绍JDBC的原理和简单的应用过程.尤其在(二)中,可以发现代码进行多次try/catch,还有在前面创建连接等过程中好多参数我都给写定了. ...
- Java JDBC的基础知识(二)
在我的上一篇Java JDBC的基础知识(一)中,最后演示的代码在关闭资源的时候,仅仅用了try/catch语句,这里是有很大的隐患的.在程序创建连接之后,如果不进行关闭,会消耗更多的资源.创建连接之 ...
- Java 中 JDBC 基础配置
Java 中 JDBC 基础配置 <resource auth="Container" driverclassname="oracle.jdbc.driver.Or ...
- Java应用程序连接数据库--JDBC基础
Java应用程序连接数据库--JDBC基础 Java应用程序连接数据库–JDBC基础 <!-- MySQL驱动,连接数据库用,由数据库厂商提供 --> <dependency&g ...
- Java JDBC的基础知识(四)
之前学习了如何创建一个数据库工具类,如下: import java.sql.Connection; import java.sql.DriverManager; import java.sql.Res ...
随机推荐
- 跑满带宽的一款百度网盘下载工具 : PanDownload
下载地址 : 点击进入 官网上面也有介绍使用.在这里,我再说一下 下载之后,解压,运行,登录, 登录好之后,准备进行设置 重要:下载情况分以下三部分 下载内容 < 300M,选择`打包下载`,只 ...
- python-嵌套函数
python-嵌套函数 定义:在函数体内用def定义一个函数,它的作用域只在该函数体内有效. def outside(): print("int the outside") def ...
- python生成器并行实例
生成器并行实例: send发送值被yield接受到赋值给baozi变量 #yield作用只是在这里保存这个值的当前状态然后返回之后在调用next,又回到yield #单纯调用next不会给yield传 ...
- grunt的安装及使用
windows下安装grunt需要先安装ruby和nodejsruby -v 测试ruby是否安装成功node -v 测试nodejs是否安装成功npm -v 测试npm是否安装成功(npm是node ...
- 2017noip总结
day0 酒店位置很好,旁边就是玉树公园,3公里处还有万达广场: 晚上去万达吃喝玩乐, 不过,打车等了好久,手机还没电了. 同时水杯还在广州扎根了...(暗示后文悲惨结局) day1 8:30 监考老 ...
- Junit 4测试框架使用
断言是编写测试用例的核心实现方式,即期望值是多少,测试的结果是多少,以此来判断测试是否通过. 断言核心方法 assertArrayEquals(expecteds, actuals) 查看两个数组是否 ...
- Python CGI编程Ⅴ
通过CGI程序传递 Textarea 数据 Textarea 向服务器传递多行数据,HTML代码如下: textarea.py 脚本代https://www.xuanhe.net/码如下: 修改 te ...
- vs2017 2019 下载更新慢的解决方法
国庆期间 下载的速度只有20多kb. 1.去掉网络适配器里面的 ip6勾选. 2.修改电脑的自动dns, 修改为1.1.1.1 , 修改为8.8.8.8 更快. 记得禁用再启用网络: dns为1. ...
- javascript / angular 如何把object转成array
取出的api 格式是纯object格式 {"name":"james","city":"Taipei","co ...
- “==”与equals方法
“==”操作符 基本类型比较值:判断两个变量的值相等. 引用类型比较引用(是否指向同一个对象):只有指向同一个对象时才相等. 用“==”进行比较时,两边的数据类型必须兼容(可自动转换的基本数据类型除外 ...