Mybatis Mapper动态代理方式 typeAliases 别名的…
2018-07-06 01:25:04来源:博客园 阅读 ()
目录结构及配置文件与原始dao方法相比更简便
只需一个UserMapper的接口,放在一起的配置文件,配置文件中namespace的地址确定jdk动态代理的对象
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> <!-- namespace:命名空间,用于隔离sql --> <!-- 使用动态代理开发DAO,1. namespace必须和Mapper接口类路径一致 --> <mapper namespace="com.swift.dao.UserMapper"> <!-- 根据用户id查询用户 --> <!-- 2. id必须和Mapper接口方法名一致 --> <!-- 3. parameterType必须和接口方法参数类型一致 --> <!-- 4. resultType必须和接口方法返回值类型一致 --> <select id="queryUserByUsername" parameterType="String" resultType="com.swift.pojo.User"> select * from user where username = #{username} </select> </mapper>
Mybatis配置文件的映射部分更加简便
<?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN" "http://mybatis.org/dtd/mybatis-3-config.dtd"> <!-- 配置 --> <configuration> <properties resource="db.properties"></properties> <environments default="development"> <!-- 开发用数据源 --> <environment id="development"> <transactionManager type="JDBC" /> <dataSource type="POOLED"> <property name="driver" value="${jdbc.driver}" /> <property name="url" value="${jdbc.url}" /> <property name="username" value="${jdbc.username}" /> <property name="password" value="${jdbc.password}" /> </dataSource> </environment> </environments> <!-- 加载sql映射文件 --> <mappers> <!-- 当把sql映射文件移到和接口文件(jdk代理的方式,无需实现类了)一个包下使用相同文件名(接口改名叫UserMapper.java不叫UserDao了),就可以使用class属性替换resource属性 --> <!-- <mapper resource="mapper/UserMapper.xml" /> --> <!-- <mapper class="com.swift.dao.UserMapper"/> --> <!-- 如果有很多相同名字的接口和映射都放在这个包中,那给个包名就可以加载映射了 --> <package name="com.swift.dao"/> </mappers> </configuration>
上边的配置文件和映射文件与以往的ssh框架类似
但还要搞懂Alias 别名
如果没留心这个,往往会让你晕晕的感觉,不明白谁是谁了,但一旦注意了,还是觉得蛮方便的
可以单个定义别名
<typeAlias alias="user" type="com.swift.pojo.User" />
就像给人其了小名,小名其实还是他,以后叫小名就行了
还可以用包批量定义别名
<package name="com.swift.dao" />
<package name="com.swift.pojo" />
那么这些包下的接口或类就都可以使用小名了(就是类名可以小写了,或者无所谓大小写)
但注意不要动 动态代理的那个类名,出BuilderException,造不出代理对象
新的配置文件
<?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN" "http://mybatis.org/dtd/mybatis-3-config.dtd"> <!-- 配置 --> <configuration> <properties resource="db.properties"></properties> <typeAliases> <!-- 单个别名定义 --> <!-- <typeAlias alias="user" type="com.swift.pojo.User" /> --> <!-- 批量别名定义,扫描整个包下的类,别名为类名(大小写不敏感) --> <package name="com.swift.dao" /> <package name="com.swift.pojo" /> </typeAliases> <environments default="development"> <!-- 开发用数据源 --> <environment id="development"> <transactionManager type="JDBC" /> <dataSource type="POOLED"> <property name="driver" value="${jdbc.driver}" /> <property name="url" value="${jdbc.url}" /> <property name="username" value="${jdbc.username}" /> <property name="password" value="${jdbc.password}" /> </dataSource> </environment> </environments> <!-- 加载sql映射文件 --> <mappers> <!-- 当把sql映射文件移到和接口文件(jdk代理的方式,无需实现类了)一个包下使用相同文件名(接口改名叫UserMapper.java不叫UserDao了),就可以使用class属性替换resource属性 --> <!-- <mapper resource="mapper/UserMapper.xml" /> --> <!-- <mapper class="com.swift.dao.UserMapper"/> --> <!-- 如果有很多相同名字的接口和映射都放在这个包中,那给个包名就可以加载映射了 --> <package name="com.swift.dao"/> </mappers> </configuration>
配置文件属性的位置是固定的,因为约束,不能变动
映射文件如下:
不知道一定会懵的
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
上一篇:浅谈Java中的final关键字
- MyBatis中的$和#,用不好,准备走人! 2020-06-11
- SpringBoot 2.3 整合最新版 ShardingJdbc + Druid + MyBatis 2020-06-11
- Spring Boot 2.3.0 新特性Redis 拓扑动态感应 2020-06-11
- SpringBoot通过web页面动态控制定时任务的启动、停止、创建 2020-06-09
- Spring Cloud Gateway 扩展支持动态限流 2020-06-08
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash