`

Jdbc小结

阅读更多
、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简介与初始化 **JDBC**(Java Database Connectivity)是一种用于执行 SQL 语句的 Java API,可以为多种关系数据库提供统一访问,它由一组用 Java 编程语言编写的接口和类组成。...

    达内科技jdbc学习笔记

    #### JDBC小结 - **JDBC实现方式**:JDBC通过一系列API实现了与数据库的交互,包括连接数据库、执行SQL语句等功能。 - **JDBCAPI的操作步骤**:包括加载驱动、建立连接、执行SQL语句、处理结果、关闭资源等。 - **...

    JDBC详解 JDBC详解

    小结 JDBC详解为我们提供了一个完整的JDBC应用程序接口的概述,包括管理层、驱动程序、连接建立和数据库操作等方面的知识点。这将帮助开发者更好地理解和使用JDBC技术,实现数据库的访问和操作。

    MyEclipse10使用教程.docx

    本文档主要介绍了 MyEclipse 10 的使用教程,涵盖了 MyEclipse 的基本使用、内存管理、快捷键、编译与调试、JDBC 小结、Hibernate 示例代码、jadclipse 插件安装等内容。 一、MyEclipse 基本使用 MyEclipse 支持 ...

    基于JDBC操作数据库

    #### 四、小结 通过以上步骤,我们可以清晰地了解到如何使用JDBC来连接MySQL数据库并执行基本的操作。掌握了这些基础内容后,再学习更高级的技术,比如ibatis等ORM框架时,将会更加得心应手。理解JDBC的工作原理和...

    Weblogic JDBC 数据源配置和详细参数说明

    Weblogic JDBC 数据源配置和详细参数说明 一、JDBC 概述 ...十、小结 本文详细介绍了 Weblogic 8.1 中 JDBC 数据源的配置和详细参数说明,包括连接池、数据源、JDBC 驱动程序设置、配置 JDBC 连接池等内容。

    JDBC与Java数据库编程

    #### 小结 通过本章节的学习,我们了解了JDBC的基本概念、体系结构、API及其版本发展情况,同时也学习了如何使用JDBC来进行基础的数据库操作。接下来,我们将在后续章节中深入探讨JDBC的高级应用以及其他相关的主题...

    MyEclipse8.5学习手册

    JDBC小结 JDBC(Java Database Connectivity)是一种Java API,用于连接和操作数据库。JDBC提供了许多接口,例如java.sql.*,并且可以通过rs.getMetaData()来获取ResultSetMetaData对象,从而获得关于字段和类型的...

    关于JDBC数据分页跨数据库小结.rar

    JDBC(Java Database Connectivity)作为Java语言与各种数据库交互的标准接口,提供了强大的数据操作能力。而数据分页是优化用户体验、提高系统性能的重要技术,尤其在处理大数据量时。本文将深入探讨如何使用JDBC...

    JDBC连接8种数据库.docx

    JDBC连接8种数据库 ...八、小结 JDBC连接数据库时需要加载驱动程序,并提供连接URL、用户名和密码。不同的数据库管理系统有不同的驱动程序和连接URL格式。了解这些差异性是使用JDBC连接数据库的基础。

    关于JDBC数据分页跨数据库小结.pdf

    这种方法适用于数据量较小的情况,避免了直接在数据库层面执行复杂的分页操作。然而,当数据量较大时,这种策略可能导致性能问题,因为它会占用更多的内存和网络资源。 五、跨数据库分页策略 为了实现跨数据库的...

    JDBC调DB2存储过程

    ### 小结 通过以上步骤,我们不仅了解了如何使用JDBC连接DB2数据库,还学习了如何通过JDBC调用DB2中的存储过程,并处理其返回的结果集。这种技术在实际开发中非常实用,特别是在需要执行复杂操作或重复使用的逻辑时...

Global site tag (gtag.js) - Google Analytics