初学ibatis过程

最近有时间,学习一下ibatis框架,现将学习过程写入Blog中,这是二十几年来第一次写Blog,写得不好忘各位仁兄见谅:

ibatis相对于hibernate要简单得多,不管是学习成本还是使用过程,只要你会SQL就能很快使用它,能达到优化的程度就是另一回事了,ibatis的优点,相对hibernate的,主要就是性能了,因为它需要程序员写SQL语句,下面开始了:
    我是写一个swing程序,功能主要是动态连接不同种数据库,得到其连接信息的所有数据库名及一个数据库中的表信息,导出InsertSQL语句及导出Java的VO类;
   <?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE sqlMapConfig PUBLIC "-//iBATIS.com//DTD SQL Map Config 2.0//EN" "sql-map-config-2.dtd">

<sqlMapConfig>
    <settings
        cacheModelsEnabled="true"
        enhancementEnabled="true"
        lazyLoadingEnabled="true"
        maxRequests="32"
        maxSessions="10"
        maxTransactions="5"
        useStatementNamespaces="false"
    />
    <transactionManager type="JDBC" >
        <dataSource type="DBCP">
            <property name="JDBC.Driver" value="${driver}"/>
            <property name="JDBC.ConnectionURL" value="${url}"/>
            <property name="JDBC.Username" value="${user}"/>
            <property name="JDBC.Password" value="${pass}"/>
        </dataSource>
    </transactionManager>
    <sqlMap resource="zl/db/sqlmap/sqlserver/xml/SysdatabasesVO.xml"/>
    <sqlMap resource="zl/db/sqlmap/sqlserver/xml/SysobjectsVO.xml"/>
    <sqlMap resource="zl/db/sqlmap/sqlserver/xml/YYDBTableColInfoVO.xml"/>
</sqlMapConfig>
上面是ibatis的sqlMapConfig.xml文件,通过这个文件得到SqlMapClient操作数据库就用这个类,大家看到上面配置文件的粗体红色标识的“DBCP”,这里设为此类型,是因为我是本机应用程序根据界面信息得到连接数据库信息:
      
        Properties props = new Properties();
        props.put("driver", driver);
        props.put("url",    dbd.getURL());
        props.put("user",   this.infovo.getDbUser());
        props.put("pass",   this.infovo.getDbPass());

        String resource = "zl/db/sqlmap/config/xml/sqlMapConfig.xml";
        Reader reader = Resources.getResourceAsReader(resource);      
      
        SqlMapClient sqlMap = SqlMapClientBuilder.buildSqlMapClient(reader,props);
      
        reader.close();
上面红体字部分就是将数据库连接信息存入Properties对象中,蓝体字中做参数传入,就会得到相应的数据库操作类SqlMapClient。
在这里提一点,如果是连接SQLServer2000数据库,其URL一定要加入一个参数SelectMethod=Cursor,不要然就一直报错,原因在网上搜就能找到,这个错误耽误了我半天时间。
jdbc:microsoft:sqlserver://127.0.0.1:1433;SelectMethod=Cursor;databasename=Northow

下面是一个sqlMap配置文件:
<?xml version="1.0" encoding="UTF-8"?>

<!DOCTYPE sqlMap    
    PUBLIC "-//ibatis.apache.org//DTD SQL Map 2.0//EN"    
    "sql-map-2.dtd">

<sqlMap>
  
    将"zl.db.sqlserver_table.vo.SysobjectsVO"类取一个别名;
    <typeAlias  alias="SysobjectsVO" type="zl.db.sqlserver_table.vo.SysobjectsVO"/>
  
    <select id="getDBTableNames" parameterClass="java.util.Map" resultClass="SysobjectsVO">
        <![CDATA[SELECT name FROM sysobjects]]>
        <dynamic prepend="WHERE">
            <isNotNull prepend="AND" property="xtype">
                <![CDATA[xtype=#xtype#]]>
            </isNotNull>
            <isNotNull prepend="AND" property="status">
                <![CDATA[status>=#status#]]>
            </isNotNull>
        </dynamic>
    </select>
</sqlMap>
sqlMap.queryForList("getDBTableNames", parameter);parameter是一个HashMap(其Key就是property值)用于传入参数是取所有表还是只要用户表。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值