详解JDBC数据库链接及相关方法的封装
详解JDBC数据库链接及相关方法的封装
使用的是MySQL数据库,首先导入驱动类,然后根据数据库URL和用户名密码获得数据的链接。由于使用的是MySQL数据库,它的URL一般为,jdbc:mysql://主机地址:端口号/库名。
下面是封装的具体类,用到了泛型和反射,不过还存在些问题,就是对使用的泛型对象有些限制,只能用于泛型类对象属性名与数据库表中列名相同的对象,而且初始化对象的方法必须为set+属性名的方法。本来想通过返回值类型,参数列表来确定该属性初始化方法的,然而可能是目前学到的还是太少,只学了三周,所以并没有实现,感觉这个方法还是很low,以后还要继续完善。本来看到网上有用beanUtils包,利用map将查询的一列存起来,直接转化成该对象的,但是就是想试试新学到的反射。而且最后的垃圾回收器并不能如同C++的析构函数一样,所以关闭数据库链接的地方也需要改善。
实现代码:
publicclassConsql{
privatestaticConsqlconsql=null;//单例设计模式
privateConnectionconn=null;//数据库链接
privatefinalStringurl;//数据库url
privatefinalStringusername;//数据库用户名
privatefinalStringpassword;//数据库密码
//驱动类的加载
static{//以静态代码块的形式加载驱动类,静态代码块只在类加载的时候执行一次
try{
Class.forName("com.mysql.jdbc.Driver");
}catch(ClassNotFoundExceptione){
e.printStackTrace();
}
}
//构造函数
privateConsql(Stringurl,Stringusername,Stringpassword)throwsSQLException{
this.url=url;
this.username=username;
this.password=password;
open();//创建连接
}
privateConnectionopen()throwsSQLException
{
try{//驱动器获取数据库链接
conn=DriverManager.getConnection(url,username,password);
}catch(SQLExceptione){
//TODOAuto-generatedcatchblock
//e.printStackTrace();
throwe;
}
returnconn;
}
/**
*带限制条件查找
*@paramsql带占位符?的sql语句
*@paramt返回相关类型对象的类(T.class)
*@paramparams替换占位符的数据,为动态数组
*@returnArrayList
*@throwsSQLException
*/
publicArrayListselect(Stringsql,Classt,Object...params)throwsSQLException
{//获取T类所有public方法
Method[]declaredMethods=t.getDeclaredMethods();
//创建一个盛放该类型对象集合
ArrayListarrayList=newArrayList<>();
try(PreparedStatementpStatement=conn.prepareStatement(sql);)
{
for(inti=0;i
*@throwsSQLException
*/
publicArrayListselect(Stringsql,Classt)throwsSQLException
{
Method[]declaredMethods=t.getDeclaredMethods();
ArrayListarrayList=newArrayList<>();
try(PreparedStatementpStatement=conn.prepareStatement(sql);)
{
try(ResultSetrSet=pStatement.executeQuery();)
{
ResultSetMetaDatarData=rSet.getMetaData();
intcolumnCount=rData.getColumnCount();
while(rSet.next()){
Ta=t.newInstance();
for(inti=0;i
以上就是详解JDBC数据库链接及相关方法的封装的实例详解,如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!