MyBatis代码生成器以及拦截器

    xiaoxiao2022-07-03  113

    代码生成器拦截器(分页插件)

    一.代码生成器

    maven 导包

    <dependencies> <!-- https://mvnrepository.com/artifact/mysql/mysql-connector-java --> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>5.1.46</version> </dependency> <!-- https://mvnrepository.com/artifact/org.mybatis/mybatis --> <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis</artifactId> <version>3.2.1</version> </dependency> <dependency> <groupId>org.slf4j</groupId> <artifactId>slf4j-api</artifactId> <version>1.6.1</version> </dependency> <dependency> <groupId>org.slf4j</groupId> <artifactId>slf4j-log4j12</artifactId> <version>1.6.1</version> <scope>runtime</scope> </dependency> <dependency> <groupId>log4j</groupId> <artifactId>log4j</artifactId> <version>1.2.14</version> </dependency> <!-- https://mvnrepository.com/artifact/junit/junit --> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>4.12</version> <!--<scope>test</scope>--> </dependency> </dependencies> <build> <plugins> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-compiler-plugin</artifactId> <configuration> <source>1.8</source> <target>1.8</target> </configuration> </plugin> </plugins> </build>

    1.2 准备代码生成器插件

    POM.xml

    <build> <plugins> <!--代码生成器插件--> <plugin> <groupId>org.mybatis.generator</groupId> <artifactId>mybatis-generator-maven-plugin</artifactId> <version>1.3.2</version> <configuration> <!--自定义代码生成器的路径--> <!--<configurationFile>yourLocation/mybatis-generator-config.xml</configurationFile>--> <verbose>true</verbose> <overwrite>true</overwrite> </configuration> </plugin> </plugins> </build>

    1.3 generatorConfig.xml

    默认在资源夹根目录,必需叫这个名称

    <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE generatorConfiguration PUBLIC "-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN" "http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd"> <!-- 自动生成器的配置(根目录,不做过多介绍)--> <generatorConfiguration> <!-- classPathEntry:可以配置多个,也不配置 数据库驱动:这里找到相应的驱动jar包就可以了(注:不同数据库的jar不一样) location:里面的是路径(也可以直接写绝对路径 -> 如:E:\mybatis\mysql-connector-java-5.1.26-bin.jar) --> <classPathEntry location="G:\openSource\mysql-connector-java-5.1.26-bin.jar"/> <!-- context:用于生成一组对象的环境(至少配置1个,可以配置多个) id:表达唯一的名称 targetRuntime:用于指定生成的代码的运行环境(MyBatis3/MyBatis3Simple) MyBatis3:默认值【生成更完整的功能】 MyBatis3Simple:不会生成与Example(案例)相关的方法 --> <context id="DB2Tables" targetRuntime="MyBatis3Simple" > <!-- 用于配置如果生成注释信息(最多可以配置一下) suppressAllComments:阻止生成注释 ,默认为false suppressDate:阻止生成的注释 时间戳,默认为false addRemarkComments:注释是否添加数据库表的备注信息,默认为false --> <commentGenerator> <property name="suppressDate" value="true"/> <property name="suppressAllComments" value="true"/> </commentGenerator> <!-- 这个应该比较清楚,配置连接数据库的基本信息 --> <jdbcConnection driverClass="com.mysql.jdbc.Driver" connectionURL="jdbc:mysql:///mybatis" userId="root" password="admin"> </jdbcConnection> <!-- 用于指定JDBC类型和Java类型如何转换,最多可以配置一个 forceBigDecimals:控制是否强制将DECIMAL和NUMERIC类型的JDBC字段转换成Java类型的 BigDecimal 默认为false,一般不需要配置 --> <javaTypeResolver> <property name="forceBigDecimals" value="false"/> </javaTypeResolver> <!-- javaModelGenerator:用来控制生成的实体类 targetPackage:生成Model类存放位置(包名) targetProject:指定目标项目路径(根目录) 对应的子属性: trimStrings:判断是否对数据库查询结果进行trim操作(默认false) --> <javaModelGenerator targetPackage="wltyx.nyybw._02_generator.domain" targetProject="src/main/java"> <property name="trimStrings" value="true"/> </javaModelGenerator> <!-- sqlMapGenerator:生成映射文件存放位置(Mapper.xml文件) targetPackage:生成SQL映射文件(XML文件)在哪个包中 targetProject:指定目标项目路径(根目录) --> <sqlMapGenerator targetPackage="wltyx.nyybw._02_generator.mapper" targetProject="src/main/resources"> </sqlMapGenerator> <!-- javaClientGenerator:Java客户端生成器(生成Dao/Mapper的接口) 该 标签可选(最多配置一个),如果不配置,就不会生成Mapper接口 type:选择客户端代码生成器 MyBatis3 ANNOTATEDMAPPER:基于注解的Mapper接口,不会有对应的XML映射文件 MIXEDMAPPER:XML和注解混合形式 XMLMAPPER:所有方法都在XML中(接口调用依赖XML) MyBatis3Simple ANNOTATEDMAPPER:基于注解的Mapper接口,不会有对应的XML映射文件 XMLMAPPER:所有方法都在XML中(接口调用依赖XML) targetPackage:生成Mapper接口存放的包名 targetProject:指定目标项目路径 --> <javaClientGenerator type="XMLMAPPER" targetPackage="wltyx.nyybw._02_generator.mapper" targetProject="src/main/java"> <property name="enableSubPackages" value="true"/> </javaClientGenerator> <!-- table:生成对应表及类名 tableName:对应表名(注:%代表所有) domainObjectName:对应的类名 generatedKey:主键自增的id字段(针对当前 数据库配置MySQL) --> <table tableName="employee" domainObjectName="Employee"> <generatedKey column="id" sqlStatement="MySql" /> </table> <!-- <table tableName="%" enableCountByExample="false" enableUpdateByExample="false" enableDeleteByExample="false" enableSelectByExample="false" selectByExampleQueryId="false" > </table> --> </context> </generatorConfiguration>

    二.MyBatis拦截器

    只需要知道语法就可以了用于增强功能

    2.1 实现接口

    2.1.1 拦截器中的方法

    intercept:拦截的核心方法(在这里面实现相应的功能)plugin:必需 return Plugin.wrap(o, this); 代表对于签名(在类上面的注解中)的拦截setProperties:获取拦截器配置的参数

    2.1.2 签名

    type:对应的类(Executor.class,ResultSetHandler.class,ParameterHandler.class,StatementHandler.class) 但是一般只用 Executor.class

    method:type类中的方法名,我们一般只用 Executor.class中的update(增删改)与query(查询)

    args:参数(方法中的参数类型)

    //我要拦截增删改的功能 @Intercepts( //签名 @Signature( type= Executor.class, method = "query", args = {MappedStatement.class, Object.class, RowBounds.class, ResultHandler.class} ) ) public class HelloInterceptor implements Interceptor { /** * 拦截器的核心方法(要做的事情是在这里完成的) * @param invocation */ @Override public Object intercept(Invocation invocation) throws Throwable { System.out.println("方法:"+invocation.getMethod()); System.out.println("对象:"+invocation.getTarget()); System.out.println("参数:"+invocation.getArgs()); //执行相应的方法 Object result = invocation.proceed(); return result; } /** * 对哪些【签名】进行拦截(放行) * 哪些操作(修改与查询)会经过咱们的拦截方法:intercept * @param o * @return */ @Override public Object plugin(Object o) { return Plugin.wrap(o, this); // return o; } /* <Interceptor> <param key="dbType" value="Oracle"></pram> </Interceptor> */ //接收参数 @Override public void setProperties(Properties properties) { String dbType = properties.getProperty("dbType"); System.out.println(dbType); } }

    2.2 拦截器的配置

    在mybatis-config.xml中进行配置 <!--插件配置(拦截器配置)--> <plugins> <plugin interceptor="wltyx.nyybw._02_generator.interceptor.HelloInterceptor"> <property name="dbType" value="mySql" /> </plugin> </plugins>

    2.3 分页插件

    分页插件就是一个拦截器

    2.3.1 引入这个插件

    <!-- 分页插件 --> <dependency> <groupId>com.github.pagehelper</groupId> <artifactId>pagehelper</artifactId> <version>5.0.0</version> </dependency>

    2.3.3 插件配置

    在mybatis-config.xml中进行配置 <plugins> <!--配置分页插件--> <plugin interceptor="com.github.pagehelper.PageInterceptor" /> </plugins> 集成spring的配置 <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"> <!-- 注意其他配置 --> <property name="plugins"> <array> <bean class="com.github.pagehelper.PageInterceptor"></bean> </array> </property> </bean>

    2.3.3 使用分页插件

    PageHelper.startPage(1, 10); @Test public void testPage() throws Exception{ //分页 pageNum:第几页 pageSize:每页条数 PageHelper.startPage(1, 10); SqlSession session = MyBatisUtil.openSession(); EmployeeMapper mapper = session.getMapper(EmployeeMapper.class); List<Employee> employees = mapper.selectAll(); Page page = (Page) employees; System.out.println("第几页:"+page.getPageNum()); //第几页 System.out.println("总页数:"+page.getPages()); //总页数 System.out.println("总条数:"+page.getTotal()); //总页数 System.out.println("结果:"+page.getResult()); page.getResult().forEach(e -> System.out.println(e)); }

    三.SSM集成

    SpringMVC,Spring,MyBatis

    3.1 Spring与MyBatis集成

    db.properites jdbc.driverClassName=com.mysql.jdbc.Driver jdbc.url=jdbc:mysql:///mybatis jdbc.username=root jdbc.password=admin applicationContext.xml <?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:context="http://www.springframework.org/schema/context" xmlns:tx="http://www.springframework.org/schema/tx" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation=" http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx.xsd "> <!-- db.properties -> datasource -> SqlSessionFactory ->mapper(接口,xml)->service->controller Spring集成MyBatis (MyBatis操作数据库的对象交给Spring管理) 1.需要把SqlSessionFactory让Spring来管理 2.数据源(四大金刚) 3.别名的问题 4.可以找到mapper.xml --> <context:component-scan base-package="wltyx.nyybw.ssm.service" /> <!--引入外部的db.properties--> <context:property-placeholder location="classpath:db.properties" /> <!--配置dbcp连接池--> <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close"> <property name="driverClassName" value="${jdbc.driverClassName}" /> <property name="url" value="${jdbc.url}" /> <property name="username" value="${jdbc.username}" /> <property name="password" value="${jdbc.password}" /> </bean> <!-- 还记得以前JPA是怎么搞的? EntityManagerFactoryBean 猜:MyBatis:是否有一个SqlSessionFactoryBean的对象 --> <bean id="sessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"> <!--配置数据源--> <property name="dataSource" ref="dataSource" /> <!--配置别名--> <property name="typeAliasesPackage" value="wltyx.nyybw.ssm.domain" /> <!--扫描 mapper.xml--> <property name="mapperLocations" value="classpath:cn/itsource/ssm/mapper/*.xml" /> </bean> <!--配置对应的MapperBean:只能配置一个Mapper,太多的话就很麻烦--> <!-- <bean id="departmentMapper" class="org.mybatis.spring.mapper.MapperFactoryBean"> <property name="sqlSessionFactory" ref="sessionFactory" /> <property name="mapperInterface" value="wltyx.nyybw.ssm.mapper.DepartmentMapper" /> </bean> --> <!--一劳永逸的配置Mapper的方案--> <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer"> <!--扫描的包的配置--> <property name="basePackage" value="wltyx.nyybw.ssm.mapper" /> <property name="sqlSessionFactoryBeanName" value="sessionFactory" /> </bean> <!--配置一个事务对象--> <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager"> <property name="dataSource" ref="dataSource" /> </bean> <!--事务的注解支持--> <tx:annotation-driven transaction-manager="transactionManager" /> </beans>

    3.2 Spring与SpringMVC

    applicationContext-mvc.xml <?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:context="http://www.springframework.org/schema/context" xmlns:mvc="http://www.springframework.org/schema/mvc" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation=" http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc.xsd "> <!--扫描相应的controller--> <context:component-scan base-package="wltyx.nyybw.ssm.controller" /> <!--静态资源放行--> <mvc:default-servlet-handler /> <!--springMVC的注解支持--> <mvc:annotation-driven /> <!--视图解析器--> <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver"> <property name="prefix" value="/WEB-INF/views/" /> <property name="suffix" value=".jsp" /> </bean> <!-- 如果我们是在SpringMVC中来引入Spring的xml,那么普通的集成运行没有问题 但是到后期和其它的一些框架集成就无法成功(比如说shiro) --> <!--<import resource="classpath:applicationContext.xml" />--> </beans> web.xml <!--启动Spring的配置--> <context-param> <param-name>contextConfigLocation</param-name> <param-value>classpath:applicationContext.xml</param-value> </context-param> <listener> <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class> </listener> <!--启动SpringMVC的配置--> <servlet> <servlet-name>springmvc</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> <load-on-startup>1</load-on-startup> <init-param> <param-name>contextConfigLocation</param-name> <param-value>classpath:applicationContext-mvc.xml</param-value> </init-param> </servlet> <servlet-mapping> <servlet-name>springmvc</servlet-name> <url-pattern>/</url-pattern> </servlet-mapping> 注意:不要在mvc的配置文件中去引入spring的核心配置文件(有些框【shiro】架就无法使用)
    最新回复(0)