浏览 3602 次
精华帖 (0) :: 良好帖 (2) :: 新手帖 (0) :: 隐藏帖 (0)
|
|
---|---|
作者 | 正文 |
发表时间:2008-07-02
动态构造sql示例: String xsql = "select * from user where 1=1 /~ and username = {username} ~/ /~ and password = {password} ~/ /~ and age = [age] ~/ /~ and sex = [sex] ~/" Map filters = new HashMap(); filters.put("username", "badqiu"); filters.put("age", "12"); filters.put("sex", ""); XsqlFilterResult result = xsqlBuilder.applyFilters(xsql,filters); 构造生成的结果result.getXsql()将会等于 select * from user where 1=1 and username={username} and age=12 被过滤删除的段: /~ and password = {password} ~/这一段由于在filters中password不存在而没有被构造出来 /~ and sex = [sex] ~/由于sex的值为空串也没有被构造出来 最后result.acceptedFilters值 Map acceptedFilters = result.getAcceptedFilters(); 会等于: {username=badqiu} 相关符号介绍: /~ segment... ~/ 为一个条件代码块 {key} 过滤器中起标记作用的key,作为后面可以替换为sql的?,或是hql的:username标记 [key] 将直接替换为key value 数据类型转换示例: select * from user where and 1=1 /~ age={age?int} ~/ 将会将Map filters中key=age的值转换为int类型 项目地址:http://code.google.com/p/rapid-xsqlbuilder/ 下载地址:http://rapid-xsqlbuilder.googlecode.com/files/xsqlbuilder-1.0.zip 声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |
发表时间:2008-07-03
不错,这个很便利
|
|
返回顶楼 | |