mybaist利用databaseId解决oracle与mysql因sql语句写法不同导致的兼容问题

mybatis实现分页、批量插入等操作时,mysql跟oracle的sql写法不同,可以通过databaseId来识别不同数据库,写不同的sql

1、spring配置文件中增加

    <bean id="vendorProperties" class="org.springframework.beans.factory.config.PropertiesFactoryBean">
        <property name="properties">
            <props>
                <prop key="Oracle">oracle</prop> <!-- 取别名,名称可任意,并不是上面配置的oralce数据源bean的id -->
                <prop key="MySQL">mysql</prop>  <!-- 取别名,名称可任意,并不是上面配置的mysql数据源的bean的id-->
            </props>
        </property>
    </bean>

    <bean id="databaseIdProvider" class="org.apache.ibatis.mapping.VendorDatabaseIdProvider">
        <property name="properties" ref="vendorProperties" />
    </bean>
2、sqlSessionFactory中增加<property name="databaseIdProvider" ref="databaseIdProvider" />
3、mybatis mapper中增加databaseId="oracle"或者databaseId="mysql"
示例:
<insert id="addBillObjAttributeByList" parameterType="java.util.List" databaseId="oracle">
        insert into pap_bcr_candidateprop
        (
        pk,
        pk_bcr_obj,
        en_prop_name,
        display_name,
        elem_type,
        mapping_entity,
        create_date
        )
        <foreach close=")" collection="list" item="item" open="(" separator="union all">
            select
            #{item.pk, jdbcType=VARCHAR},
            #{item.pkBcrObj, jdbcType=VARCHAR},
            #{item.enPropName, jdbcType=VARCHAR},
            #{item.displayName, jdbcType=VARCHAR},
            #{item.elemType, jdbcType=VARCHAR},
            #{item.mappingEntity, jdbcType=VARCHAR},
            #{item.createDate, jdbcType=TIMESTAMP}
            from dual
        </foreach>
    </insert>


<insert   id="addBillObjAttributeByList"   parameterType="java.util.List" databaseId="mysql">
        insert into pap_bcr_candidateprop
        (
        pk,
        pk_bcr_obj,
        en_prop_name,
        display_name,
        elem_type,
        mapping_entity,
        create_date
        )
        values
        <foreach collection="list" item="attribute" index= "index" separator =",">
            (
            #{attribute.pk, jdbcType=VARCHAR},
            #{attribute.pkBcrObj, jdbcType=VARCHAR},
            #{attribute.enPropName, jdbcType=VARCHAR},
            #{attribute.displayName, jdbcType=VARCHAR},
            #{attribute.elemType, jdbcType=VARCHAR},
            #{attribute.mappingEntity, jdbcType=VARCHAR},
            #{attribute.createDate, jdbcType=TIMESTAMP}
            )
        </foreach>

    </insert>
    这样mybatis会根据数据库的不同自动读取相应数据库下的sql语句。

  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
当一个SQL映射文件中有多个`databaseId`属性的SQL语句时,MyBatis会根据当前的数据库类型,自动选择对应的SQL语句执行。具体的实现逻辑如下: 1. MyBatis在初始化时,会通过`DatabaseIdProvider`接口获取当前数据库的`databaseId`,并保存到`Environment`对象中。 2. 当执行SQL语句时,MyBatis会读取SQL语句的`databaseId`属性,并与当前的`Environment`对象中的`databaseId`进行比对。 3. 如果两者相同,则执行该SQL语句;否则忽略该SQL语句。 例如,如果当前数据库的`databaseId`为`mysql`,而SQL映射文件中有以下两个SQL语句: ```xml <select id="getUser" resultType="User" databaseId="mysql"> SELECT * FROM user_mysql </select> <select id="getUser" resultType="User" databaseId="oracle"> SELECT * FROM user_oracle </select> ``` 则MyBatis会执行第一个SQL语句,因为它的`databaseId`属性与当前数据库的`databaseId`相同。而第二个SQL语句会被忽略,因为它的`databaseId`属性与当前数据库的`databaseId`不同。 需要注意的是,如果当前的`Environment`对象中没有设置`databaseId`,则MyBatis会默认执行所有没有`databaseId`属性的SQL语句,而忽略所有设置了`databaseId`属性的SQL语句。 如果您有多个`databaseId`属性的SQL语句,并且在执行时遇到问题,可以检查当前的`Environment`对象中是否正确设置了`databaseId`,或者提供更多的配置信息和错误日志,我会尽力帮助解决问题

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值