JDBC操作技巧
来源:互联网 发布:手机服务器软件 编辑:程序博客网 时间:2024/06/18 10:39
对于纯JDBC连接数据库连接工具如下:
public static final String DBDRIVER="com.microsoft.sqlserver.jdbc.SQLServerDriver"; public static final String DBURL="jdbc:sqlserver://10.81.35.35:1433;databaseName=Company"; public static final String DBUSERNAMW="sa"; public static final String DBPSD="1111111"; private Connection conn=null; public DataBaseConnection(){ try{ Class.forName(DBDRIVER); conn=DriverManager.getConnection(DBURL,DBUSERNAMW,DBPSD); }catch(Exception e){ e.printStackTrace(); } } public Connection getConnection(){ return this.conn ; } public void close() throws SQLException{ if(this.conn!=null){ conn.close(); } }
然后我们便是采用PreparedStatement对SQL语句进行预处理,如下:
PreparedStatement pstm = null; String sql = "insert into Person(UserName,Password) values(?,?)"; try { pstm = this.conn.prepareStatement(sql); pstm.setString(1, person.getUserName()); pstm.setString(2, person.getPassword()); int count = pstm.executeUpdate(); if (count > 0) { flag = true; } } catch (Exception e) { throw e; } finally { try { pstm.close(); } catch (Exception e) { } }
这是我们最常用的一种操作方式,可是问题就来了,我们所要操作的,必须对sql中的字段很明确,比如我们按条件来查询的时候,我们就必须对条件的字段很清楚,可是,当数据库字段增多的时候,我们所要查询的条件规则很多,是不是每一个条件,我们就要写一个方法呢?显然,这种是直接的思维,然而这样思维却增加了很多代码的冗余,又或者说是,每次变换条件或者新增条件的时候,我们都必须对方法进行修改,甚至是增加。于是乎,我们想有没有一种方式可以传递字段名称进去查询,如where ?=?
本人亲测,这种方式是不存在的,因为预处理字段的时候,PreparedStatement会自动在字符串上加引号,那此时就不能达到我们想要的效果(如想要的是where name=? 得到的却是 where 'name'=?),本人曾经在这样的问题上纠结了很久。最终找到一种破解的方式,这里借鉴了IBatis的Map传参方式。希望同行爱好者,我们除了要学会使用框架或插件,得找个时间去研究一下它的原理(源码)哦。
对于where ?=? 显然是不可取,但是对于字符串占位就可以的。例子如下:
public List<Person> findByParams(Map<String, Object> params) throws Exception { Iterator it = params.entrySet().iterator(); List<Person> list = new ArrayList<Person>(); Person person = null; String key = null; Object value = null; PreparedStatement pstm = null; while (it.hasNext()) { Map.Entry<String, Object> entry = (Map.Entry<String, Object>) it .next(); key = entry.getKey(); value = entry.getValue(); } <span style="color:#FF0000;"> String sql = String.format( "select userid,username,password from person where %s=?", key);</span> pstm = this.conn.prepareStatement(sql); pstm.setObject(1, value); ResultSet rs = pstm.executeQuery(); while(rs.next()) { person = new Person(); person.setUserID(rs.getInt(1)); person.setUserName(rs.getString(2)); person.setPassword(rs.getString(3)); } rs.close(); pstm.close(); return list; }
哈哈 此种方式可以替代where ?=?,参照ibatis
- JDBC操作技巧
- JDBC操作各种数据库经验技巧集萃(转)
- JDBC 操作
- JDBC操作
- JDBC操作
- JDBC 操作
- JDBC操作
- JDBC操作
- JDBC操作
- JDBC操作
- jdbc操作
- JDBC性能技巧
- JDBC性能技巧(4)
- JDBC优化技巧之一
- JDBC连接数据库技巧
- JDBC性能技巧
- JDBC 中的一些技巧
- JDBC性能优化技巧
- linux 下 自己写的 html文件产生中文乱码问题 解决办法。。
- 【2012-12-10更新】GPS类,封装了GPS细节,通过start和stop调用
- There is no Action mapped for namespace xxand action name xx
- static全局变量与普通的全局变量有什么区别?static局部变量和普通局部变量有什么区别?static函数与普通函数有什么区别?
- mongodb源码分析(十二)数据的更新
- JDBC操作技巧
- poj1222(暴力枚举)
- 【C/C++】boost regex正则表达式的安装及使用
- linux下android开发环境搭建及NDK安装[集成gcc编译器]
- 【学习笔记】log4cxx安装和使用
- PHP版本VC6与VC9、Thread Safe与None-Thread Safe等的区别
- fuseki推理
- Linq 检测DbDataReader 对象中是否有特定名字的列存在
- 解决oracle initialization or shutdown in progress问题----oracle