博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
ibatis 动态传入表名
阅读量:6306 次
发布时间:2019-06-22

本文共 1850 字,大约阅读时间需要 6 分钟。

hot3.png

项目中需要根据不同的表名和列名生成不同的select语句,我想ibatis这里也应该是用预编译的形式存储????

不太了解具体原理,反正我知道在用oci库的时候,是可以的;用sprinf("sql","xx","xx"),一下,就可以了。oci库肯定是用预编译的形式干的!

于是,我上网查了查,感觉类似的问题有,可没给出一个完整的例子。想了一想,既然你能动态传入map,map里面存储了相应的查询值,那你

ibatis肯定也能传入其他元数据信息吧。测试了一下,可以!OK,搞定了:)

不多说了,代码如下

[java]
  1. Java code :   
  2. // just a releation to the table stored in db  
  3. public class Test {  
  4.     public String name;  
  5.     public Timestamp date;  
  6.     public int id;  
  7. }  
  8. public class TestInsert {  
  9.    // logger class you can replace it to System.out.println  
  10.    static Log logger = LogFactory.getLog(TestInsert.class);  
  11.   
  12.    public static void main(String[] args) {  
  13.        /* 
  14.         * Test test = new Test(); test.date = new 
  15.         * Timestamp(System.currentTimeMillis()); test.name = "fffff"; try {
     
  16.         * long num = (Long) EntityManager.getSqlMapper().insertArgs( 
  17.         * "insertOperation", "fffff", new 
  18.         * Timestamp(System.currentTimeMillis())); logger.info("ID is " + num); 
  19.         * } catch (SQLException e) { e.printStackTrace(); } 
  20.         */  
  21.        // try the dynamic table dealation  
  22.        HashMap<String, Object> map = new HashMap<String, Object>();  
  23.        // set the query value   
  24.        map.put("ID", "dizhuang");  
  25.        // set the col1 to be selected  
  26.        map.put("col1", "*");  
  27.          // set the table name  
  28.        map.put("tablePrefix", "testsocevent");  
  29.        // set the col name which you use  
  30.          map.put("col2", "NAME");  
  31.        // map.put("ID", 1000);  
  32.        // map.put("id", "1005");  
  33.        try {  
  34.            // why args is error?  
  35.            Test test = (Test) EntityManager.getSqlMapper().queryForObject(  
  36.                "getTest", map);  
  37.            logger.info("id : " + test.id);  
  38.            logger.info("time :" + test.date);  
  39.            logger.info("name : " + test.name);  
  40.        } catch (SQLException e) {  
  41.            logger.error(e.getMessage(), e);  
  42.            // e.printStackTrace();  
  43.        }  
  44.    }  
  45.   
  46. // ibatis sql  
  47. <select id="getTest" parameterClass="java.util.HashMap"  
  48.   resultClass="com.neusoft.soc.eventcenter.test.Test"  
  49.   remapResults="true">  
  50.   SELECT  
  51.       $col1$  
  52.   FROM  
  53.       $tablePrefix$  
  54.   WHERE  
  55.     $col2$ = #ID#  
  56.  </select> 

转载于:https://my.oschina.net/u/1398304/blog/372613

你可能感兴趣的文章
高性能 Lua 技巧(译)
查看>>
区分指针、变量名、指针所指向的内存
查看>>
异步编程的世界
查看>>
最近话题火爆的四件事你知道不?
查看>>
SpringBoot整合MyBatis
查看>>
云计算产业如何率先推行信用管理?
查看>>
Android 类库书签更新(一)
查看>>
Unity3D Input按键系统
查看>>
简单的一条SQL,不简单的做事思维 NOT IN 、NOT EXISTS、LEFT JOIN用法差别 ...
查看>>
DataWorks:任务未运行自助排查
查看>>
ionic/cordova热部署
查看>>
「镁客早报」特斯拉裁员,马斯克解释没有办法;微软推出Azure DevOps赏金计划...
查看>>
Flink入坑指南第五章 - 语法糖 view
查看>>
centos 7.4 使用 pgxc_ctl 安装与使用
查看>>
Redis 单key值过大 优化方式
查看>>
【数据库】表分区
查看>>
nutz-sqltpl 1.3.4.RELEASE 发布,在 Nutz 项目中“解决 Java 拼接 SQL”问题
查看>>
城市 | 800个地铁站数据透析的京沪白领图鉴:隐形土豪、无产中产阶级和猪猪女孩...
查看>>
前端脚本!网站图片素材中文转英文
查看>>
linux的常用易忘命令
查看>>