body
{
font-family: "Microsoft YaHei UI","Microsoft YaHei",SimSun,"Segoe UI",Tahoma,Helvetica,Sans-Serif,"Microsoft YaHei", Georgia,Helvetica,Arial,sans-serif,宋体, PMingLiU,serif;
font-size: 10.5pt;
line-height: 1.5;
}
html, body
{

}
h1 {
font-size:1.5em;
font-weight:bold;
}
h2 {
font-size:1.4em;
font-weight:bold;
}
h3 {
font-size:1.3em;
font-weight:bold;
}
h4 {
font-size:1.2em;
font-weight:bold;
}
h5 {
font-size:1.1em;
font-weight:bold;
}
h6 {
font-size:1.0em;
font-weight:bold;
}
img {
border:0;
max-width: 100%;
}
blockquote {
margin-top:0px;
margin-bottom:0px;
}
table {
border-collapse:collapse;
border:1px solid #bbbbbb;
}
td {
border-collapse:collapse;
border:1px solid #bbbbbb;
}

ibatis参数传递小技巧 - 疯狂的菠菜 - ITeye技术网站使用ibatis操作数据库的时候, 如果这个操作需要一些参数, 一般我们会使用map将这些参数封装起来,
然后调用SqlMapClient或者SqlMapClientTemplate的update, insert, queryForXxx方法.
每次构造这个map, 重复性的东东比较多, 于是改进了一下. 在基类DAO中构建了一个内部类:

  1. /** 
  2. * 用来封装多个参数, 并实现连接操作 
  3. *  
  4.  */  
  5. protected static class Parameter extends HashMap<String, Object> {  
  6.     private static final long serialVersionUID = -1756000414146772526L;  
  7.   
  8.     public Parameter addParameter(String key, Object value) {  
  9.         this.put(key, value);  
  10.         return this;  
  11.     }  
  12. }  
    /**
* 用来封装多个参数, 并实现连接操作
*
*/
protected static class Parameter extends HashMap<String, Object> {
private static final long serialVersionUID = -1756000414146772526L; public Parameter addParameter(String key, Object value) {
this.put(key, value);
return this;
}
}

然后在基类中加一个createParameter()方法用来给子类调用, 添加key-value的参数:

  1. /** 
  2.  * 用于支持连写 
  3.  * @param key 
  4.  * @param value 
  5.  * @return 
  6.  */  
  7. protected static Parameter createParameter(String key, Object value) {  
  8.     return new Parameter().addParameter(key, value);  
  9. }  
    /**
* 用于支持连写
* @param key
* @param value
* @return
*/
protected static Parameter createParameter(String key, Object value) {
return new Parameter().addParameter(key, value);
}

具体使用:

  1. public int update(String id, int quantity) throws DAOException {  
  2.     Parameter parameter = createParameter("id", id)  
  3.             .addParameter("quantity", quantity);  
  4.     return executeUpdate(getSqlId("update"), parameter);  
  5. }  
    public int update(String id, int quantity) throws DAOException {
Parameter parameter = createParameter("id", id)
.addParameter("quantity", quantity);
return executeUpdate(getSqlId("update"), parameter);
}

如果是原来的话, 需要这样写:

  1. public int update(String id, int quantity) throws DAOException {  
  2.     Map<String, Object> parameter = new HashMap<String, Object>();  
  3.             parameter.put("id", id);  
  4.             parameter.put("quantity", quantity);  
  5.     return executeUpdate(getSqlId("update"), parameter);  
  6. }  
    public int update(String id, int quantity) throws DAOException {
Map<String, Object> parameter = new HashMap<String, Object>();
parameter.put("id", id);
parameter.put("quantity", quantity);
return executeUpdate(getSqlId("update"), parameter);
}

其实也没什么, 只是有时候我这个人比较懒, 少打了几个字而已.

最新文章

  1. spring boot 调试 - 热部署
  2. Living one day at a time (update for a long time)
  3. WPF Step By Step 系列 - 开篇 &#183;
  4. VS合集/6.0/2005/2008/2010/2012/2013 绿色版精简版
  5. Codeforce 438D-The Child and Sequence 分类: Brush Mode 2014-10-06 20:20 102人阅读 评论(0) 收藏
  6. EasyUI-DataGrid之批量删除
  7. [Angular 2] Property Binding
  8. MS SQLSERVER通用存储过程分页
  9. 位记录——Windows 7已安装Sublime Text 3、cynwin、SublimeClang
  10. 在 InstantRails 环境下,安装使用 redMine
  11. JAVA printWriter中write()和println()区别
  12. React笔记:React基础(2)
  13. java web路径和spring读取配置文件
  14. windows 10 screenshot keyboard shortcut
  15. 解决idea创建Maven项目卡在running tmp archetypexxxtmp
  16. 随机指定范围内N个不重复的数
  17. golang 的 mysql 操作
  18. ScrollView嵌套ListView,禁止ListView的滚动,只让ScrollView可以滚动
  19. 转载 - java中接口的向上转型。和多态性
  20. EF Code First更新数据库时报错:provider: SQL Network Interfaces, error: 26

热门文章

  1. error while loading shared libraries: libmcrypt.so.4
  2. sql数据库删除表的外键约束(INSERT 语句与 FOREIGN KEY 约束&quot;XXX&quot;冲突。该冲突发生于数据库&quot;XXX&quot;,表&quot;XXX&quot;, column &#39;XXX)
  3. eclipse无法导入已有android项目
  4. cocos2d-x 不规则形状按钮的点击判定
  5. VS2010+PCL+openni配置
  6. JPA 系列教程5-双向一对多
  7. Debian 安装Nvidia显卡驱动
  8. sqlserver2008行锁
  9. css05 字体以及行间距
  10. hdu 3345 War Chess