、java数据库操作基本流程
2、几个常用的重要技巧:
可滚动、更新的记录集
批量更新
事务处理
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接
1、取得数据库连接
1)用DriverManager取数据库连接
例子:
String className,url,uid,pwd; className = "oracle.jdbc.driver.OracleDriver"; url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; uid = "system"; pwd = "manager"; Class.forName(className); Connection cn = DriverManager.getConnection(url,uid,pwd);
2)用jndi(java的命名和目录服务)方式
例子
String jndi = "jdbc/db"; Context ctx = (Context) new InitialContext().lookup ("java:comp/env"); DataSource ds = (DataSource) ctx.lookup(jndi); Connection cn = ds.getConnection();
多用于jsp中
2、执行sql语句
1)用Statement来执行sql语句
String sql;Statement sm = cn.createStatement();sm.executeQuery(sql); // 执行数据查询语句(select)sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close();
2)用PreparedStatement来执行sql语句
String sql;sql = "insert into user (id,name) values (?,?)";PreparedStatement ps = cn.prepareStatement(sql);ps.setInt(1,xxx);ps.setString(2,xxx);...ResultSet rs = ps.executeQuery(); // 查询int c = ps.executeUpdate(); // 更新
3、处理执行结果
查询语句,返回记录集ResultSet。
更新语句,返回数字,表示该更新影响的记录数。
ResultSet的方法:
1、next(),将游标往后移动一行,如果成功返回true;否则返回false。
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值。
3、释放连接。
cn.close();
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection
可滚动、更新的记录集
1、创建可滚动、更新的Statement
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY);
该Statement取得的ResultSet就是可滚动的
2、创建PreparedStatement时指定参数
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY);ResultSet.absolute(9000);
批量更新
1、Statement
Statement sm = cn.createStatement();sm.addBatch(sql1);sm.addBatch(sql2);...sm.executeBatch()
一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有
2、PreparedStatement
PreparedStatement ps = cn.preparedStatement(sql);{ ps.setXXX(1,xxx); ... ps.addBatch();}ps.executeBatch();
一个PreparedStatement,可以把一个sql语句,变换参数多次执行,一次更新。
事务的处理
1、关闭Connection的自动提交
cn.setAutoCommit(false);
2、执行一系列sql语句
要点:执行每一个新的sql语句前,上一次执行sql语句的Statement(或者PreparedStatemet)必须先close
Statement sm ;sm = cn.createStatement(insert into user...);sm.executeUpdate();sm.close();sm = cn.createStatement("insert into corp...);sm.executeUpdate();sm.close();
3、提交
cn.commit();
4、如果发生异常,那么回滚
分享到:
相关推荐
### JDBC个人小结 #### 一、JDBC简介与初始化 **JDBC**(Java Database Connectivity)是一种用于执行 SQL 语句的 Java API,可以为多种关系数据库提供统一访问,它由一组用 Java 编程语言编写的接口和类组成。...
#### JDBC小结 - **JDBC实现方式**:JDBC通过一系列API实现了与数据库的交互,包括连接数据库、执行SQL语句等功能。 - **JDBCAPI的操作步骤**:包括加载驱动、建立连接、执行SQL语句、处理结果、关闭资源等。 - **...
小结 JDBC详解为我们提供了一个完整的JDBC应用程序接口的概述,包括管理层、驱动程序、连接建立和数据库操作等方面的知识点。这将帮助开发者更好地理解和使用JDBC技术,实现数据库的访问和操作。
本文档主要介绍了 MyEclipse 10 的使用教程,涵盖了 MyEclipse 的基本使用、内存管理、快捷键、编译与调试、JDBC 小结、Hibernate 示例代码、jadclipse 插件安装等内容。 一、MyEclipse 基本使用 MyEclipse 支持 ...
#### 四、小结 通过以上步骤,我们可以清晰地了解到如何使用JDBC来连接MySQL数据库并执行基本的操作。掌握了这些基础内容后,再学习更高级的技术,比如ibatis等ORM框架时,将会更加得心应手。理解JDBC的工作原理和...
Weblogic JDBC 数据源配置和详细参数说明 一、JDBC 概述 ...十、小结 本文详细介绍了 Weblogic 8.1 中 JDBC 数据源的配置和详细参数说明,包括连接池、数据源、JDBC 驱动程序设置、配置 JDBC 连接池等内容。
#### 小结 通过本章节的学习,我们了解了JDBC的基本概念、体系结构、API及其版本发展情况,同时也学习了如何使用JDBC来进行基础的数据库操作。接下来,我们将在后续章节中深入探讨JDBC的高级应用以及其他相关的主题...
JDBC小结 JDBC(Java Database Connectivity)是一种Java API,用于连接和操作数据库。JDBC提供了许多接口,例如java.sql.*,并且可以通过rs.getMetaData()来获取ResultSetMetaData对象,从而获得关于字段和类型的...
JDBC(Java Database Connectivity)作为Java语言与各种数据库交互的标准接口,提供了强大的数据操作能力。而数据分页是优化用户体验、提高系统性能的重要技术,尤其在处理大数据量时。本文将深入探讨如何使用JDBC...
JDBC连接8种数据库 ...八、小结 JDBC连接数据库时需要加载驱动程序,并提供连接URL、用户名和密码。不同的数据库管理系统有不同的驱动程序和连接URL格式。了解这些差异性是使用JDBC连接数据库的基础。
这种方法适用于数据量较小的情况,避免了直接在数据库层面执行复杂的分页操作。然而,当数据量较大时,这种策略可能导致性能问题,因为它会占用更多的内存和网络资源。 五、跨数据库分页策略 为了实现跨数据库的...
### 小结 通过以上步骤,我们不仅了解了如何使用JDBC连接DB2数据库,还学习了如何通过JDBC调用DB2中的存储过程,并处理其返回的结果集。这种技术在实际开发中非常实用,特别是在需要执行复杂操作或重复使用的逻辑时...