mybatis-config.xml 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN" "http://mybatis.org/dtd/mybatis-3-config.dtd">
  3. <configuration>
  4. <!-- 全局参数 -->
  5. <settings>
  6. <!-- 使全局的映射器启用或禁用缓存。 -->
  7. <setting name="cacheEnabled" value="true"/>
  8. <!-- 全局启用或禁用延迟加载。当禁用时,所有关联对象都会即时加载。 -->
  9. <setting name="lazyLoadingEnabled" value="true"/>
  10. <!-- 当启用时,有延迟加载属性的对象在被调用时将会完全加载任意属性。否则,每种属性将会按需要加载。 -->
  11. <setting name="aggressiveLazyLoading" value="true"/>
  12. <!-- 是否允许单条sql 返回多个数据集 (取决于驱动的兼容性) default:true -->
  13. <setting name="multipleResultSetsEnabled" value="true"/>
  14. <!-- 是否可以使用列的别名 (取决于驱动的兼容性) default:true -->
  15. <setting name="useColumnLabel" value="true"/>
  16. <!-- 允许JDBC 生成主键。需要驱动器支持。如果设为了true,这个设置将强制使用被生成的主键,有一些驱动器不兼容不过仍然可以执行。 default:false -->
  17. <setting name="useGeneratedKeys" value="false"/>
  18. <!-- 指定 MyBatis 如何自动映射 数据基表的列 NONE:不隐射 PARTIAL:部分 FULL:全部 -->
  19. <setting name="autoMappingBehavior" value="PARTIAL"/>
  20. <!-- 这是默认的执行类型 (SIMPLE: 简单; REUSE: 执行器可能重复使用prepared statements语句;BATCH: 执行器可以重复执行语句和批量更新) -->
  21. <setting name="defaultExecutorType" value="SIMPLE"/>
  22. <!-- 使用驼峰命名法转换字段。 -->
  23. <setting name="mapUnderscoreToCamelCase" value="true"/>
  24. <!-- 设置本地缓存范围 session:就会有数据的共享 statement:语句范围 (这样就不会有数据的共享 ) defalut:session -->
  25. <setting name="localCacheScope" value="SESSION"/>
  26. <!-- 设置但JDBC类型为空时,某些驱动程序 要指定值,default:OTHER,插入空值时不需要指定类型 -->
  27. <setting name="jdbcTypeForNull" value="NULL"/>
  28. </settings>
  29. <plugins>
  30. <!-- com.github.pagehelper为PageHelper类所在包名 -->
  31. <plugin interceptor="com.github.pagehelper.PageHelper">
  32. <!-- 4.0.0以后版本可以不设置该参数
  33. <property name="dialect" value="mysql"/>-->
  34. <!-- 该参数默认为false -->
  35. <!-- 设置为true时,会将RowBounds第一个参数offset当成pageNum页码使用 -->
  36. <!-- 和startPage中的pageNum效果一样-->
  37. <property name="offsetAsPageNum" value="true"/>
  38. <!-- 该参数默认为false -->
  39. <!-- 设置为true时,使用RowBounds分页会进行count查询 -->
  40. <property name="rowBoundsWithCount" value="false"/>
  41. <!-- 设置为true时,如果pageSize=0或者RowBounds.limit = 0就会查询出全部的结果 -->
  42. <!-- (相当于没有执行分页查询,但是返回结果仍然是Page类型)-->
  43. <property name="pageSizeZero" value="true"/>
  44. <!-- 3.3.0版本可用 - 分页参数合理化,默认false禁用 -->
  45. <!-- 启用合理化时,如果pageNum<1会查询第一页,如果pageNum>pages会查询最后一页 -->
  46. <!-- 禁用合理化时,如果pageNum<1或pageNum>pages会返回空数据 -->
  47. <property name="reasonable" value="false"/>
  48. <!-- 3.5.0版本可用 - 为了支持startPage(Object params)方法 -->
  49. <!-- 增加了一个`params`参数来配置参数映射,用于从Map或ServletRequest中取值 -->
  50. <!-- 可以配置pageNum,pageSize,count,pageSizeZero,reasonable,orderBy,不配置映射的用默认值 -->
  51. <!-- 不理解该含义的前提下,不要随便复制该配置 -->
  52. <property name="params" value="pageNum=pageHelperStart;pageSize=pageHelperRows;"/>
  53. <!-- 支持通过Mapper接口参数来传递分页参数 -->
  54. <property name="supportMethodsArguments" value="false"/>
  55. <!-- always总是返回PageInfo类型,check检查返回类型是否为PageInfo,none返回Page -->
  56. <property name="returnPageInfo" value="none"/>
  57. </plugin>
  58. </plugins>
  59. </configuration>