本篇文章我们来分析一下databaseIdProvider标签.
mybatis可以根据不同的数据库厂商执行不同的语句,这种多厂商的支持是基于映射语句中的databaseId属性.mybatis会加载不带databaseId属性和带有匹配当前数据库databaseId属性的所有语句.如果同时找到带有databaseId和不带databaseId的相同语句,则后者会被舍弃.
用法为:
<databaseIdProvider type="DB_VENDOR" />
这里的DB_VENDOR会通过DatabaseMetaData的getDatabaseProductName()方法返回的字符串进行设置databaseId. 由于通常情况下这个字符串都非常长而且相同产品的不同版本会返回不同的值,所以最好通过设置属性别名来使其变短,如下:
<databaseIdProvider type="DB_VENDOR">
<property name="SQL Server" value="sqlserver"/>
<property name="DB2"