- 浏览: 155253 次
- 性别:
- 来自: 长沙
文章分类
最新评论
-
vipbooks:
ioandy 写道首先感谢作者!使用中发现一个问题,就是生成j ...
基于数据库的代码自动生成工具,生成JavaBean、生成数据库文档、生成前后端代码等(v5.8.8版) -
ioandy:
首先感谢作者!使用中发现一个问题,就是生成javabean的时 ...
基于数据库的代码自动生成工具,生成JavaBean、生成数据库文档、生成前后端代码等(v5.8.8版) -
suncong1024:
不错不错,很好用
基于数据库的自动化生成工具,自动生成JavaBean、自动生成数据库文档等(v4.1.2版) -
vipbooks:
敲可爱的小花花世界上只有一个 写道不错不错、继续支持、哈哈,谢 ...
基于数据库的代码自动生成工具,生成JavaBean、生成数据库文档、生成前后端代码等(v5.8.0版) -
敲可爱的小花花世界上只有一个:
不错不错、继续支持、
基于数据库的代码自动生成工具,生成JavaBean、生成数据库文档、生成前后端代码等(v5.8.0版)
哈哈,再发一个用于JDBC操作数据库的公共类,这也是我在很久以前写的,其中的RWProperties类在我的“Java基础”分类中有一篇《用于读写Properties属性配制文件的通用类》的文章中就有,希望能对大家有些帮助,以后我还会发更多的原创文章上来,也希望大家能提出一些宝贵的建议和想法,让我们大家在这里共同成长!
修改日志(20111010)
在写完该工具之后的日子里对该工具进行过很多迭代式的修改,这里今年修改的最新的版本,更加通用、更加灵活,同时支持ICO、批量操作和手动提交事务,并去除了对RWProperties.java的依赖。
哈哈,不好意思啊,这个类已经改了很多地方了,我还没有把改好的上传上来,今天我就更新一下!
RWProperties已经更新过了,易用性更好了!
修改日志(20111010)
在写完该工具之后的日子里对该工具进行过很多迭代式的修改,这里今年修改的最新的版本,更加通用、更加灵活,同时支持ICO、批量操作和手动提交事务,并去除了对RWProperties.java的依赖。
/* * @(#)CommonSql.java 2011-9-5 * * Copyright 2011 Bianjing,All rights reserved. */ import java.sql.Connection; import java.sql.DatabaseMetaData; import java.sql.DriverManager; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; import java.sql.Statement; import java.util.List; import javax.naming.Context; import javax.naming.InitialContext; import javax.sql.DataSource; /** * 用于JDBC操作数据库的共通类 * * @author Bianjing * @version 1.0.0 2011-9-5 */ public class CommonSql { /** 数据源 */ private DataSource dataSource; /** 数据库连接对象 */ private Connection connection; /** 数据库操作对象 */ private PreparedStatement ps; /** 数据库操作对象 */ private Statement statement; /** 返回的数据结果集对象 */ private ResultSet rs; /** 是否自动提交事务,默认为true,如果该值为false则需要手动提交事务 */ private boolean autoCommit = true; /** 数据库连接是否已经打开 */ private boolean openConnection; /** JNDI名称 */ private String jndiName; /** 数据库驱动 */ private String driver; /** 数据库访问地址 */ private String url; /** 用户名 */ private String user; /** 密码 */ private String pwd; public CommonSql() { } public CommonSql(DataSource dataSource) { this.dataSource = dataSource; } public CommonSql(String jndiName) { this.jndiName = jndiName; } public CommonSql(String driver, String url, String user, String pwd) { this.driver = driver; this.url = url; this.user = user; this.pwd = pwd; } /** * 打开数据库连接并创建数据库连接对象<br/> * 支持通过ICO注入数据源、数据库驱动、数据库驱动、JNDI名称、数据库访问地址和用户名、密码 * * @return boolean true:连接成功,false:连接失败 */ public boolean openConnection() { /** * 通过数据源来获取数据库连接对象 */ if (dataSource != null) { try { connection = dataSource.getConnection(); // 数据库连接已经打开 openConnection = true; } catch (SQLException e) { closeAll(); // 所有的"System.out.println"都可以替换为"logger.error" System.out.println("从数据源获取数据库连接失败!"); throw new RuntimeException(e); } return openConnection; } /** * 通过JNDI来获取数据库连接对象 */ if (jndiName != null) { try { Context initContext = new InitialContext(); dataSource = (DataSource) initContext.lookup(jndiName); connection = dataSource.getConnection(); // 数据库连接已经打开 openConnection = true; } catch (Exception e) { closeAll(); System.out.println("从JNDI获取数据库连接失败!"); throw new RuntimeException(e); } return openConnection; } /** * 通过数据库驱动、数据库访问地址、用户名、密码来获取数据库连接对象 */ try { Class.forName(driver); connection = DriverManager.getConnection(url, user, pwd); // 数据库连接已经打开 openConnection = true; } catch (Exception e) { closeAll(); System.out.println("数据库连接失败!"); throw new RuntimeException(e); } return openConnection; } /** * 执行数据库的更新操作 * * @param sql * 要执行的SQL语句 * @return boolean true:执行成功,false:执行失败 */ public boolean execUpdate(String sql, Object... args) { boolean isPassed = false; // 判断连接数据库是否成功 if (openConnection) { try { ps = connection.prepareStatement(sql); // 设置参数 if (args != null && args.length > 0) { for (int i = 0; i < args.length; i++) { ps.setObject(i + 1, args[i]); } } ps.executeUpdate(); isPassed = true; } catch (SQLException e) { try { if (autoCommit) { connection.rollback(); } } catch (SQLException e1) { throw new RuntimeException(e1); } System.out.println("SQL:" + sql); throw new RuntimeException(e); } finally { if (autoCommit) { closeAll(); } } } else { System.out.println("数据库连接对象没有打开!"); } return isPassed; } /** * 执行数据库的更新操作 * * @param sql * 要执行的SQL语句 * @return boolean true:执行成功,false:执行失败 */ public boolean execUpdate(String sql, List<?> args) { return execUpdate(sql, args.toArray()); } /** * 执行批量更新数据库操作 * * @param sql * 要执行的SQL语句的字符串数组 * @return boolean true:执行成功,false:执行失败 */ public boolean execUpdate(Object[] sql) { boolean flag = false; // 判断连接数据库是否成功 if (openConnection) { try { statement = connection.createStatement(); for (int i = 0; i < sql.length; i++) { statement.addBatch((String) sql[i]); } statement.executeBatch(); flag = true; } catch (SQLException e) { try { if (autoCommit) { connection.rollback(); } } catch (SQLException e1) { throw new RuntimeException(e1); } for (int i = 0; i < sql.length; i++) { System.out.println("SQL " + (i + 1) + ":" + sql[i]); } throw new RuntimeException(e); } finally { if (autoCommit) { closeAll(); } } } else { System.out.println("数据库连接对象没有打开!"); } return flag; } /** * 执行批量更新数据库操作 * * @param sql * 要执行的SQL语句的集合 * @return boolean true:执行成功,false:执行失败 */ public boolean execUpdate(List<?> sql) { return execUpdate(sql.toArray()); } /** * 执行数据库查询操作 * * @param sql * 要执行的SQL语句 * @param args * 查询参数列表 * @return ResultSet 返回查询的结果集对象 */ public ResultSet execQuery(String sql, Object... args) { rs = null; // 判断连接数据库是否成功 if (openConnection) { try { ps = connection.prepareStatement(sql); // 设置参数 if (args != null && args.length > 0) { for (int i = 0; i < args.length; i++) { ps.setObject(i + 1, args[i]); } } rs = ps.executeQuery(); } catch (SQLException e) { if (autoCommit) { closeAll(); } System.out.println("SQL:" + sql); throw new RuntimeException(e); } } else { System.out.println("数据库连接对象没有打开!"); } return rs; } /** * 执行数据库查询操作 * * @param sql * 要执行的SQL语句 * @param args * 查询参数列表 * @return ResultSet 返回查询的结果集对象 */ public ResultSet execQuery(String sql, List<?> args) { return execQuery(sql, args.toArray()); } /** * 根据标准SQL查询数据库,返回一个int值 * * @param sql * 要执行的SQL语句 * @param args * 查询参数列表 * @return int值,如果出错则返回-1 */ public int findForInt(String sql, Object... args) { ResultSet rs = execQuery(sql, args); int count = -1; try { if (rs != null && rs.next()) { count = rs.getInt(1); } } catch (SQLException e) { throw new RuntimeException(e); } finally { if (autoCommit) { closeAll(); } } return count; } /** * 根据标准SQL查询数据库,返回一个int值 * * @param sql * 要执行的SQL语句 * @param args * 查询参数列表 * @return int值,如果出错则返回-1 */ public int findForInt(String sql, List<?> args) { return findForInt(sql, args.toArray()); } /** * 关闭所有数据库连接对象 */ public void closeAll() { if (rs != null || ps != null || statement != null || connection != null) { try { if (rs != null) { rs.close(); } } catch (SQLException e) { throw new RuntimeException(e); } finally { rs = null; if (ps != null || statement != null || connection != null) { try { if (ps != null && !ps.isClosed()) { ps.close(); } } catch (SQLException e) { throw new RuntimeException(e); } finally { ps = null; if (statement != null || connection != null) { try { if (statement != null && !statement.isClosed()) { statement.close(); } } catch (SQLException e) { throw new RuntimeException(e); } finally { statement = null; try { if (connection != null && !connection.isClosed()) { connection.close(); } } catch (SQLException e) { throw new RuntimeException(e); } finally { connection = null; } } } } } } } } /** * 提交事务并关闭数据库连接 */ public void commit() { try { if (!autoCommit) { connection.commit(); } } catch (SQLException e) { throw new RuntimeException(e); } finally { autoCommit = true; closeAll(); } } /** * 回滚事务并关闭数据库连接 */ public void rollback() { try { if (!autoCommit) { connection.rollback(); } } catch (SQLException e) { throw new RuntimeException(e); } finally { autoCommit = true; closeAll(); } } public DataSource getDataSource() { return dataSource; } public void setDataSource(DataSource dataSource) { this.dataSource = dataSource; } public String getDriver() { return driver; } public void setDriver(String driver) { this.driver = driver; } public String getUrl() { return url; } public void setUrl(String url) { this.url = url; } public boolean getAutoCommit() { return autoCommit; } public void setAutoCommit(boolean autoCommit) { try { connection.setAutoCommit(autoCommit); } catch (SQLException e) { closeAll(); throw new RuntimeException(e); } this.autoCommit = autoCommit; } public boolean getOpenConnection() { return openConnection; } public String getJndiName() { return jndiName; } public void setJndiName(String jndiName) { this.jndiName = jndiName; } public String getUser() { return user; } public void setUser(String user) { this.user = user; } public String getPwd() { return pwd; } public void setPwd(String pwd) { this.pwd = pwd; } public Connection getConnection() { return connection; } /** * 测试数据库连接是否成功 * * @param args * @throws SQLException */ public static void main(String[] args) throws SQLException { String driver = "com.microsoft.sqlserver.jdbc.SQLServerDriver"; String url = "jdbc:sqlserver://127.0.0.1:1433;databaseName=demo"; String user = "sa"; String pwd = "sa"; CommonSql commonSql = new CommonSql(driver, url, user, pwd); if (commonSql.openConnection()) { System.out.println("数据库连接成功!"); DatabaseMetaData dbMetaData = commonSql.getConnection() .getMetaData(); System.out .print("当前连接的数据库是:" + dbMetaData.getDatabaseProductName()); System.out.println(" " + dbMetaData.getDatabaseProductVersion()); } else { System.out.println("数据库连接失败!"); } commonSql.closeAll(); } }
评论
2 楼
vipbooks
2011-10-10
liangzai718 写道
RWProperties.getProperty("driver", "com/test/config/db.properties");
-- RWProperties类貌似没有getProperty(arg0,arg1)这个方法呀?这个怎么调呀?
-- RWProperties类貌似没有getProperty(arg0,arg1)这个方法呀?这个怎么调呀?
哈哈,不好意思啊,这个类已经改了很多地方了,我还没有把改好的上传上来,今天我就更新一下!
RWProperties已经更新过了,易用性更好了!
1 楼
liangzai718
2011-10-09
RWProperties.getProperty("driver", "com/test/config/db.properties");
-- RWProperties类貌似没有getProperty(arg0,arg1)这个方法呀?这个怎么调呀?
-- RWProperties类貌似没有getProperty(arg0,arg1)这个方法呀?这个怎么调呀?
相关推荐
为了简化这一过程,开发者通常会使用预定义的类库,其中一个常见的就是"操作数据库的公共类 jar 包"。这个jar包提供了一组通用的数据库操作类,使得程序员可以便捷地进行数据库的连接、查询、更新等操作,无需深入...
"JDBC数据库连接技术" JDBC(Java Database Connectivity)是一种Java API,用于连接和操作关系型数据库。它提供了一组统一的接口,允许Java程序与不同的关系型数据库管理系统进行交互。 1. 常见的关系型数据库 ...
这篇名为“JDBC公共操作方法代码”的博客文章可能详细介绍了如何使用JDBC进行常见的数据库操作。下面我们将深入探讨JDBC的关键知识点。 首先,JDBC连接数据库的步骤通常包括以下几个部分: 1. 导入JDBC驱动:在...
综上所述,JDBC连接mysql数据库.rar提供的两个JDBC驱动包主要用于在Java项目中与MySQL数据库建立连接,不同版本适应不同的MySQL服务和功能需求。在实际开发中,选择适合项目需求的版本并正确使用JDBC连接步骤,可以...
JDBC Jar包是实现这一连接功能的核心库,它包含了所有必要的类和接口,使得Java开发者能够编写程序来访问和操作数据库。在Java应用程序中,JDBC扮演着桥梁的角色,允许程序执行SQL语句,进行数据查询、插入、更新和...
在软件设计模式中,工厂模式是一种非常常见的创建型模式,它的主要目的是为了抽象产品的创建过程,使得客户端可以无须关心具体的产品实现,只需要通过一个公共的接口或者类来获取产品实例。在这个“用工厂模式开发多...
JDBC(Java Database Connectivity)是一种用于执行SQL语句的Java API,它可以为多种关系数据库提供统一访问,它由一组用Java语言编写的类和接口组成。JDBC提供了与数据库建立连接、发送SQL语句并处理结果的基本方法...
3. **hadoop-common*.jar**: Hadoop的公共库,包含了Hadoop系统的基本功能,如文件系统操作、网络通信等,对于Hive JDBC来说,它是连接HDFS(Hadoop Distributed File System)的基础。 4. **hadoop-hdfs*.jar**: ...
然而,直接使用JDBC进行数据操作可能会导致大量的重复代码,因此,将数据库表映射为实体类可以提高代码的可读性和可维护性。ORM框架如Hibernate、MyBatis等,它们提供了自动化的JavaBean到数据库表之间的映射功能。 ...
标题 "hive2.1.1 + hadoop2.6.0 jdbc驱动" 指的是一个包含特定版本的Hive和Hadoop组件的集合,这些组件特别针对通过JDBC进行数据库连接进行了优化。Hive是Apache软件基金会开发的一个数据仓库工具,它允许用户使用...
JDBC作为通用的SQL数据库存取和操作的公共接口,为访问不同的数据库提供了一种统一的途径,屏蔽了一些数据库访问的细节问题。 要使用JDBC,程序员不需要对特定的数据库系统的特点有过多了解,只需要使用JDBC提供的...
- 定义了一个公共类`BaseDao`,用于封装数据库访问逻辑。 4. **私有静态成员变量**: - `private static final String driverName = "oracle.jdbc.driver.OracleDriver";` - `private static final String url =...
1. msbase.jar:这是JDBC驱动的基础组件,包含了与SQL Server数据库交互所需的公共类和接口。这些类和接口是JDBC驱动的核心,用于执行SQL语句、处理结果集、管理数据库连接等。 2. mssqlserver.jar:这个文件是SQL ...
3. **获取方法**:通过`Class对象.getMethod()`或`getDeclaredMethod()`获取类的方法,这两个方法分别用于获取公共方法和所有方法,包括私有方法。 4. **执行方法**:有了Method对象后,我们就可以调用`invoke()`...
在"CommonLibJDK15(4hibernate)"这个子目录中,可能包含了支持Hibernate运行的公共库,如JDBC驱动、Hibernate核心库等。使用JDK15版本,说明此项目已经采用了较新的Java语言特性,如模块系统、增强的switch语句等,...
这是一个公共的数据库操作类,提供了五个静态字符串变量,用于定义数据库操作语句。这些变量分别是:createSqlString、insertData1String、insertData2String、insertData3String 和 selectSqlString。 实体类 ...
JDBC是Java与数据库交互的桥梁,它定义了一组接口和类,用于建立数据库连接、执行SQL语句以及处理结果集。为了使用JDBC,我们需要先加载数据库驱动,然后创建Connection对象,接着通过Statement或PreparedStatement...
JDBC(Java Database Connectivity)是Java语言中用于实现数据库操作的核心技术,它提供了一套标准的API,使得Java程序能够以一种统一的方式访问不同的数据库系统。以下将从JDBC概述、数据持久化、Java中的数据存储...
将这些JAR文件添加到项目的类路径中后,开发者就能够使用JDBC API编写代码来连接Oracle数据库,执行SQL查询、更新数据、处理结果集等操作。例如,使用`Class.forName()`加载驱动,然后通过`DriverManager.get...