热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

java数据库操作基本流程等或兼有_java数据库编程中的技巧

java数据库编程中的技巧【Java数据库编程中的技巧】1、java数据库操作基本流程2、几个常用的重要技巧:可滚动、更新的记录集批量更新事务处理java数据库操作基

41528d3028836879cd698677c3999917.gifjava数据库编程中的技巧

【Java 数据库编程中的技巧】 1、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.cuteQuery(sql); // 执行数据查询语句(select) sm.cuteUpdate(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.cuteQuery(); // 查询 int c = ps.cuteUpdate(); // 更新 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.cuteBatch() 一个 Statement 对象,可以执行多个 sql 语句以后,批量更新。这多个语句可以是 delete、update 、insert 等或兼有 2、PreparedStatement PreparedStatement ps = cn.preparedStatement(sql); { ps.setXXX(1,xxx); . ps.addBatch(); } ps.cuteBatch(); 一个 PreparedStatement,可以把一个 sql 语句,变换参数多次执行,一次更新。 事务的处理 1、关闭 Connection 的自动提交 cn.setAutoCommit(false); 2、执行一系列 sql 语句 要点:执行每一个新的 sql 语句前,上一次执行 sql 语句的 Statement (或者 PreparedStatemet )必须先 close Statement sm ; sm = cn.createStatement(insert into user.); sm.cuteUpdate(); sm.close(); sm = cn.createStatement(“insert into corp.); sm.cuteUpdate(); sm.close(); 3、提交 mit(); 4、如果发生异常,那么回滚 cn.rollback();



推荐阅读
  • Java String与StringBuffer的区别及其应用场景
    本文主要介绍了Java中String和StringBuffer的区别,String是不可变的,而StringBuffer是可变的。StringBuffer在进行字符串处理时不生成新的对象,内存使用上要优于String类。因此,在需要频繁对字符串进行修改的情况下,使用StringBuffer更加适合。同时,文章还介绍了String和StringBuffer的应用场景。 ... [详细]
  • 本文详细介绍了SQL日志收缩的方法,包括截断日志和删除不需要的旧日志记录。通过备份日志和使用DBCC SHRINKFILE命令可以实现日志的收缩。同时,还介绍了截断日志的原理和注意事项,包括不能截断事务日志的活动部分和MinLSN的确定方法。通过本文的方法,可以有效减小逻辑日志的大小,提高数据库的性能。 ... [详细]
  • 本文介绍了使用Java实现大数乘法的分治算法,包括输入数据的处理、普通大数乘法的结果和Karatsuba大数乘法的结果。通过改变long类型可以适应不同范围的大数乘法计算。 ... [详细]
  • Spring特性实现接口多类的动态调用详解
    本文详细介绍了如何使用Spring特性实现接口多类的动态调用。通过对Spring IoC容器的基础类BeanFactory和ApplicationContext的介绍,以及getBeansOfType方法的应用,解决了在实际工作中遇到的接口及多个实现类的问题。同时,文章还提到了SPI使用的不便之处,并介绍了借助ApplicationContext实现需求的方法。阅读本文,你将了解到Spring特性的实现原理和实际应用方式。 ... [详细]
  • 本文介绍了lua语言中闭包的特性及其在模式匹配、日期处理、编译和模块化等方面的应用。lua中的闭包是严格遵循词法定界的第一类值,函数可以作为变量自由传递,也可以作为参数传递给其他函数。这些特性使得lua语言具有极大的灵活性,为程序开发带来了便利。 ... [详细]
  • 本文介绍了数据库的存储结构及其重要性,强调了关系数据库范例中将逻辑存储与物理存储分开的必要性。通过逻辑结构和物理结构的分离,可以实现对物理存储的重新组织和数据库的迁移,而应用程序不会察觉到任何更改。文章还展示了Oracle数据库的逻辑结构和物理结构,并介绍了表空间的概念和作用。 ... [详细]
  • 开发笔记:加密&json&StringIO模块&BytesIO模块
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了加密&json&StringIO模块&BytesIO模块相关的知识,希望对你有一定的参考价值。一、加密加密 ... [详细]
  • 本文介绍了如何使用php限制数据库插入的条数并显示每次插入数据库之间的数据数目,以及避免重复提交的方法。同时还介绍了如何限制某一个数据库用户的并发连接数,以及设置数据库的连接数和连接超时时间的方法。最后提供了一些关于浏览器在线用户数和数据库连接数量比例的参考值。 ... [详细]
  • 本文讨论了如何优化解决hdu 1003 java题目的动态规划方法,通过分析加法规则和最大和的性质,提出了一种优化的思路。具体方法是,当从1加到n为负时,即sum(1,n)sum(n,s),可以继续加法计算。同时,还考虑了两种特殊情况:都是负数的情况和有0的情况。最后,通过使用Scanner类来获取输入数据。 ... [详细]
  • 在说Hibernate映射前,我们先来了解下对象关系映射ORM。ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现。这样开发人员就可以把对数据库的操作转化为对 ... [详细]
  • 本文由编程笔记小编整理,介绍了PHP中的MySQL函数库及其常用函数,包括mysql_connect、mysql_error、mysql_select_db、mysql_query、mysql_affected_row、mysql_close等。希望对读者有一定的参考价值。 ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • 基于事件驱动的并发编程及其消息通信机制的同步与异步、阻塞与非阻塞、IO模型的分类
    本文介绍了基于事件驱动的并发编程中的消息通信机制,包括同步和异步的概念及其区别,阻塞和非阻塞的状态,以及IO模型的分类。同步阻塞IO、同步非阻塞IO、异步阻塞IO和异步非阻塞IO等不同的IO模型被详细解释。这些概念和模型对于理解并发编程中的消息通信和IO操作具有重要意义。 ... [详细]
  • Oracle分析函数first_value()和last_value()的用法及原理
    本文介绍了Oracle分析函数first_value()和last_value()的用法和原理,以及在查询销售记录日期和部门中的应用。通过示例和解释,详细说明了first_value()和last_value()的功能和不同之处。同时,对于last_value()的结果出现不一样的情况进行了解释,并提供了理解last_value()默认统计范围的方法。该文对于使用Oracle分析函数的开发人员和数据库管理员具有参考价值。 ... [详细]
  • 本文详细介绍了在ASP.NET中获取插入记录的ID的几种方法,包括使用SCOPE_IDENTITY()和IDENT_CURRENT()函数,以及通过ExecuteReader方法执行SQL语句获取ID的步骤。同时,还提供了使用这些方法的示例代码和注意事项。对于需要获取表中最后一个插入操作所产生的ID或马上使用刚插入的新记录ID的开发者来说,本文提供了一些有用的技巧和建议。 ... [详细]
author-avatar
大伟
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有