DBConnectionFactory.java它有一个辅助类DBConnectionConfig.java用来读取配置文件
[code]
public class DBConnectionConfig {
private static Properties prop = new Properties();
static {
try {
prop.load(DBConnectionConfig.class
.getResourceAsStream("DBConnectionConfig.properties"));
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
public static String className = prop.getProperty("className");
}
[/code]
接下来才是我怎么去访问数据库了,这里我写了一个接口
具体是谁是获得连接对象,让实现该接口的类去做吧
[code]
package org.cdy.www.service;
import java.sql.Connection;
public interface IDBConnection {
public abstract Connection getConnection();
public abstract void closeConnection(Connection conn);
}
[/code]
由于数据库的关闭操作对于所有实现该接口的类都是采用一样的方法conn.close()所有我写了一个抽象类AbstractConnectionImpl.java
[code]
import java.sql.Connection;
import java.sql.SQLException;
import org.cdy.www.service.IDBConnection;
public abstract class AbstractConnectionImpl implements IDBConnection {
public void closeConnection(Connection conn) {
try {
conn.close();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
public Connection getConnection() {
// TODO Auto-generated method stub
return null;
}
}
至于获得连接对象Connection则由各种数据库类自己去实现,它们只需要override就行了
下面是采用MSSQL数据库的方式
package org.cdy.www.serviceImpl;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
public class MSSqlConnectionImpl extends AbstractConnectionImpl {
@Override
public Connection getConnection() {
// TODO Auto-generated method stub
Connection conn = null;
try {
Class.forName(MSSqlConnectionConfig.driver);
} catch (ClassNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
try {
conn = DriverManager.getConnection(MSSqlConnectionConfig.url,
MSSqlConnectionConfig.user, MSSqlConnectionConfig.password);
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return conn;
}
@Override
public void closeConnection(Connection conn) {
// T
super.closeConnection(conn);
}
}
它对应自己的配置类、配置文件
package org.cdy.www.serviceImpl;
import java.io.IOException;
import java.util.Properties;
public class MSSqlConnectionConfig {
private static Properties prop = new Properties();
static {
try {
prop.load(MSSqlConnectionConfig.class
.getResourceAsStream("MSSqlConnectionConfig.properties"));
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
public static String driver = prop.getProperty("driver");
public static String url = prop.getProperty("url");
public static String user = prop.getProperty("user");
public static String password = prop.getProperty("password");
}
配置文件
driver=com.microsoft.JDBC.sqlserver.SQLServerDriver
url=jdbc:microsoft:sqlserver://localhsot:1433;databaseName=test
user=sa
password=sa
[/code]
分享到:
相关推荐
现在的数据层的开发,大多会使用...但是在一些极端的场景下往往原生的jdbc方式操作数据库更灵活,性能更高。由于部分场景下MyBatis或JPA之类无法满足我的需求,所以我打算自己封装一套查数据库的工具类。 文章地址: ...
封装jdbc即是把对数据库的连接操作封装在一个类中, 外部使用无需在重新建立连接,只需写出要执行的sql语句,就可执行。 也无需关闭,所有的都封装在一个类中。
实现完全的对jdbc对象的封装,只需调用则可对数据库进行CRUD操作
JDBC封装的工具类,将所有共同的代码提取过来,形成工具类
封装jdbc,用Map实现快速的数据库增删改例子,具体可以参考util包下的BaseDao
spring封装jdbc查询这是一个完整的范例!!!
游戏服务器 数据库连接池 jdbc 简单封装
这个jdbc的jar包里面有四个类以及一个DataSource.properties配置文件。该文件中放的是四大参数。如果你下载了这个jar包,那么在你使用的时候,你需要自己创建一个DataSource.properties文件,你需要把这个DataSource...
Java反射封装jdbc方法,查询,修改,添加,删除,查询全部,为一个方法,SQL语句自己拼接,可常用,下载可终身受益
看到很多人不知道使用泛型,所有我利用方法泛型以及类泛型,封装了几个JDBC链接Oracle的方法,可以适用增删改查任意表以及任意返回值和任意个数查询条件。可以自己改成mysql或其他数据库
关于Java Web的Servlet+JDBC(封装)+JSP的登录(送给入门的你)
jdbc封装(实现对实体的增删改查[分页]),辅助学习Hibernate 包含三个文件夹,分别是: code-access实现 是用access实现的,本意是access方便,就一个文件,方便部署。但access有好多不支持,就写成这样.主要是可参考Dao...
NULL 博文链接:https://wa491o.iteye.com/blog/1149987
jdbc 封装例子 jdbc 封装例子 jdbc 封装例子 jdbc 封装例子
jdbc的封装类,便于在开发时候方便,实现了数据库的加载,连接,增、删、查、改。
java增删改查JDBC封装类(泛型封装),这个是高度封装化的,增删改查,直接用到我的项目中去的。
jdbc封装工具类,此类事封装成list,Object>>格式,可直接把转换为jsonArray格式传输数据。
对jdbc简单封装,实现基本增删改查,使用时请用编译器导入继承BaseDao类即可
文档脉络清楚的详述了实现JDBC封装所需要进行的步骤。
java JDBC 连接sql server封装