丨Fanny丨Cri 2020-05-17
<dependencies> <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis</artifactId> <version>3.5.4</version> </dependency> <!--导入驱动程序--> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>8.0.19</version> </dependency> <!--导入log4j--> <dependency> <groupId>log4j</groupId> <artifactId>log4j</artifactId> <version>1.2.12</version> </dependency> <!--导入slf,他是log4j的接口层--> <dependency> <groupId>org.slf4j</groupId> <artifactId>slf4j-api</artifactId> <version>2.0.0-alpha1</version> </dependency> <dependency> <groupId>org.slf4j</groupId> <artifactId>slf4j-log4j12</artifactId> <version>2.0.0-alpha1</version> </dependency> <!--导入junit测试包--> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>4.13</version> </dependency> </dependencies> <!-- 上面一种方式虽然使用了mubaits的配置,但还是要写很多冗余代码 比如sql会话工厂每次都要创建,然后每次我们都要手动开启事务,回滚,关闭sqlsession等。 这种情况该如何解决呢 --> <build> <plugins> <plugin> <!--使用插件,让项目使用java8编译等--> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-compiler-plugin</artifactId> <version>3.1</version> <configuration> <source>1.8</source> <target>1.8</target> <encoding>1.8</encoding> </configuration> </plugin> </plugins> <!--为了保证包目录下的配置文件在编译后能够发布到执行目录,需要指定编译后生成的文件内容 --> <resources> <resource> <directory>src/main/java</directory> <includes> <include>**/*.xml</include> </includes> </resource> <resource> <directory>src/main/resources</directory> </resource> </resources> </build>
以后不用写接口的实现类,mybatis根据配置文件和对应接口的映射文件自动生成代理类。
映射文件与dao接口放在同一个包下,然后只需要在全局配置文件中指定接口所在的包即可,这样很方便,因为dao包中可能包含多个接口。 <mappers> <!--使用mapper代理时,我们只需要指定dao所在接口的包即可 只要在此包下面的接口和对应的配置文件就会被相互关联,并且mapper配置文件的 文件名尽量和dao接口保持一致(这是在全局配置文件中配置) --> <package name="com.zero.dao"/> </mappers>
namespace属性值对应mapper节点中所有语句对应的dao层接口的全限定类名。
使用mapper代理的时候语句节点中的参数、返回值类型和id要和接口中的方法的参数,方法的返回值类型、方法名一致。
<resources> <resource> <directory>src/main/java</directory> <includes> <include>**/*.xml</include> </includes> </resource> <resource> <directory>src/main/resources</directory> </resource> </resources>
对于经常要用的jojo类,避免在映射文件中重复书写且全限定类名,我们在全局配置文件中添加pojo类的别名,在映射文件中需要填写此pojo类的别名的地方 都可以使用此别名。 <typeAliases> <typeAlias type="com.zero.pojo.User" alias="user"></typeAlias> <typeAlias type="com.zero.dao.UserMapper" alias="userMapper"></typeAlias> </typeAliases>
如果您把字符 "<" 放在 XML 元素中,会发生错误,这是因为解析器会把它当作新元素的开始。这样会产生 XML 错误: 为了避免这个错误,用实体引用来代替 "<" 字符,如下:在 XML 中,有 5 个预定义的实体引用:在mybatis中,只有< 和&是非法的,使用实体引用来替代他
一般是对于字符串来说的,可以用${属性名}或者是${value}(如果是简单类型的话,比如int,String,${value}是固定写法)。 也可以使用concat,连接参数和%。 例如concat(‘%‘ , #{username} ,‘%‘),多个参数的模糊查询, 可以根据参数的顺序来进行选择 <select id="selectUserCount" parameterType="user" resultType="user">/*<*/ select id,username,userTime from user where id < 1 or username like concat(‘%‘,#{username},‘%‘) or userTime > #{userTime} </select> <!--多个参数的查询--> <select id="selectUserByOtherParams" resultType="user">/*这里也可以用param1和para2*/ select id,username,userTime from user where username like concat(‘%‘,#{param1},‘%‘) or username like concat(‘%‘,#{param2},‘%‘) </select>`