Mybatis

作者: 霄霄霄霄 | 来源:发表于2017-06-01 19:55 被阅读0次

    什么是 MyBatis ?

           MyBatis 是支持定制化 SQL、存储过程以及高级映射的优秀的持久层框架。MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集。MyBatis 可以对配置和原生Map使用简单的 XML 或注解,将接口和 Java 的 POJOs(Plain Old Java Objects,普通的 Java对象)映射成数据库中的记录。

    特点:

           与JDBC相近的持久化框架,运行效率高;提供灵活的查询方式,但需要自己写SQL语句;不会自动进行级联操作,需要使用SQL手动进行;需要考虑入参和出参的类型及其对应关系。

    基础使用:

    导入mybatis和mysql-connector-java依赖。

    配置mybatis:

           该配置可在官网上找到,中文版!!很容易上手。

    <environments>:可有多个子<environment>,default指向某一子<environment>。

    <environment>:配置数据库连接。

    <transcationManager>:事务管理器配置。

    <dataSource>:配置数据库连接。

    <mappers>:配置JavaBean映射文件所在位置。

    JavaBean文件映射配置:

    UserDTO的JavaBean UserDTO的映射文件

    <mapper>:namespace属性值不可少,用于识别不同的数据库操作。

    <select>:查询方法,parameterType是入参的类型,ResultMap是最终的查询结果。

    <resultMap>:配置返回结果的属性。

    <id/>:表的主键属性。

    <result>:表的非主键属性。

    <association>:一对多关联表的属性。其中column为调用的查询方法的入参,javaType是关联表的Bean对象。select是对应的关联表的查询方法,组成为对应JavaBean映射文件的namespace+ "." +<select>的id属性值,详见下图。

    BlogDTO的JavaBean BlogDTO的映射文件

    此例中user与blog是一对一关系、与photo是一对多关系;blog与content、photo为一对多关系;content与photo是一对多关系。此处<collection>表示为对应的JavaBean的集合。

    ContentDTO的映射文件

    由于不需要反向查询,因而注释了该属性。

    ContentDTO的映射文件

    由于content是一个集合,而photo也是一个集合,类似于多对多,此处的查询方法使用的是联合查询,否则会报错。

    此处的注释是另一种实现,该方式将在下面进行介绍。

    PhotoDTO的映射配置 PhotoDTO的映射文件

    测试类:

    测试类代码

    首先获取类加载器的输入流从配置文件中读取mybatis配置,然后获取session(获取session时的参数表示采用自动提交事务的方式,不推荐!)。

    调用selectOne方法,第一个参数为对应JavaBean的namespace值 + "." + <select>的id值,第二个参数为其一参数方法的入参。

    xml配置的另一方式:

             将全部配置写在同一个映射文件中:

    由此其余映射文件可不需配置。

    开启缓存:

    默认开启一级缓存,若需要开启二级缓存,只需在对应的映射文件中加入<cache/>标签。

    相关文章

      网友评论

          本文标题:Mybatis

          本文链接:https://www.haomeiwen.com/subject/pqgefxtx.html