您现在的位置是:首页 > 个人日记个人日记
mybatis-10-自动代码生成
2019-02-03 18:34:32【个人日记】603人已围观
简介不用再写简单的sql语句了,解放双手
自动代码生成
项目结构

==红色则为自动生成==
当生成好了记得在mybatis-config.xml里配置映射文件
配置文件generatorConfig.xml
<?xml version="1.0" encoding="UTF-8"?><!DOCTYPE generatorConfigurationPUBLIC "-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN""http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd"><generatorConfiguration><!--导入属性配置--><properties resource="jdbc.properties"></properties><context id="mysql" targetRuntime="MyBatis3"><!-- 注释 --><commentGenerator><property name="suppressAllComments" value="true"/><!-- 是否取消注释 --><property name="suppressDate" value="true"/><!-- 是否生成注释代时间戳 --></commentGenerator><!--jdbc的数据库连接 --><jdbcConnectiondriverClass="${driverClassName}"connectionURL="${url}"userId="${username}"password="${password}"></jdbcConnection><!-- 非必需,类型处理器,在数据库类型和java类型之间的转换控制--><javaTypeResolver><property name="forceBigDecimals" value="false"/></javaTypeResolver><!-- Model模型生成器,用来生成含有主键key的类,记录类 以及查询Example类targetPackage 指定生成的model生成所在的包名targetProject 指定在该项目下所在的路径--><javaModelGenerator targetPackage="com.huangxin.order.model"targetProject="src/main/java"></javaModelGenerator><!--Mapper映射文件生成所在的目录 为每一个数据库的表生成对应的SqlMap文件 --><sqlMapGenerator targetPackage="mapper"targetProject="src/main/resources"></sqlMapGenerator><!-- 客户端代码,生成易于使用的针对Model对象和XML配置文件 的代码type="ANNOTATEDMAPPER",生成Java Model 和基于注解的Mapper对象type="MIXEDMAPPER",生成基于注解的Java Model 和相应的Mapper对象type="XMLMAPPER",生成SQLMap XML文件和独立的Mapper接口--><javaClientGenerator targetPackage="com.huangxin.order.mapper"targetProject="src/main/java" type="XMLMAPPER"><property name="enableSubPackages" value="true"/></javaClientGenerator><!-- 数据表名及实体类名称 --><table tableName="user" domainObjectName="User"enableCountByExample="false" enableUpdateByExample="false"enableDeleteByExample="false" enableSelectByExample="false"selectByExampleQueryId="false"></table></context></generatorConfiguration>
这是比较简洁的版本,网上可以搜索到各种配置以及说明
==注意信息填写,一定要对应==
需要的==自动生成的插件==
配置pom.xml文件,导入插件
<?xml version="1.0" encoding="UTF-8"?><project xmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><groupId>mybatis-06</groupId><artifactId>mybatis06</artifactId><version>1.0-SNAPSHOT</version><dependencies><!--log记录--><dependency><groupId>log4j</groupId><artifactId>log4j</artifactId><version>1.2.17</version></dependency><!--MySQL驱动--><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>5.1.46</version></dependency><!-- ibatis.jar --><dependency><groupId>org.mybatis</groupId><artifactId>mybatis</artifactId><version>3.4.6</version></dependency><!-- junit.jar --><dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>4.12</version><scope>test</scope></dependency><!-- mybatis-generator自动生成代码插件 --><dependency><groupId>org.mybatis.generator</groupId><artifactId>mybatis-generator-core</artifactId><version>1.3.6</version></dependency></dependencies><!-- 在build中加入以下插件 --><build><plugins><plugin><groupId>org.mybatis.generator</groupId><artifactId>mybatis-generator-maven-plugin</artifactId><version>1.3.6</version><configuration><!--这是自动代码生成器的配置文件路径--><configurationFile>${basedir}/src/main/resources/generator/generatorConfig.xml</configurationFile><verbose>true</verbose><overwrite>true</overwrite></configuration><dependencies><dependency><!--依赖的sql版本--><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>5.1.46</version><scope>runtime</scope></dependency></dependencies></plugin></plugins></build></project>
==注意配置文件的路径==
Mapper.xml文件
<?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"><mapper namespace="com.huangxin.order.mapper.UserMapper"><resultMap id="BaseResultMap" type="com.huangxin.order.model.User"><id column="id" jdbcType="INTEGER" property="id"/><result column="user_name" jdbcType="VARCHAR" property="userName"/><result column="user_telephone" jdbcType="VARCHAR" property="userTelephone"/><result column="user_sex" jdbcType="VARCHAR" property="userSex"/></resultMap><sql id="Base_Column_List">id, user_name, user_telephone, user_sex</sql><select id="selectByPrimaryKey" parameterType="java.lang.Integer" resultMap="BaseResultMap">select<include refid="Base_Column_List"/>from userwhere id = #{id,jdbcType=INTEGER}</select><delete id="deleteByPrimaryKey" parameterType="java.lang.Integer">delete from userwhere id = #{id,jdbcType=INTEGER}</delete><insert id="insert" parameterType="com.huangxin.order.model.User">insert into user (id, user_name, user_telephone,user_sex)values (#{id,jdbcType=INTEGER}, #{userName,jdbcType=VARCHAR}, #{userTelephone,jdbcType=VARCHAR},#{userSex,jdbcType=VARCHAR})</insert><insert id="insertSelective" parameterType="com.huangxin.order.model.User">insert into user<trim prefix="(" suffix=")" suffixOverrides=","><if test="id != null">id,</if><if test="userName != null">user_name,</if><if test="userTelephone != null">user_telephone,</if><if test="userSex != null">user_sex,</if></trim><trim prefix="values (" suffix=")" suffixOverrides=","><if test="id != null">#{id,jdbcType=INTEGER},</if><if test="userName != null">#{userName,jdbcType=VARCHAR},</if><if test="userTelephone != null">#{userTelephone,jdbcType=VARCHAR},</if><if test="userSex != null">#{userSex,jdbcType=VARCHAR},</if></trim></insert><update id="updateByPrimaryKeySelective" parameterType="com.huangxin.order.model.User">update user<set><if test="userName != null">user_name = #{userName,jdbcType=VARCHAR},</if><if test="userTelephone != null">user_telephone = #{userTelephone,jdbcType=VARCHAR},</if><if test="userSex != null">user_sex = #{userSex,jdbcType=VARCHAR},</if></set>where id = #{id,jdbcType=INTEGER}</update><update id="updateByPrimaryKey" parameterType="com.huangxin.order.model.User">update userset user_name = #{userName,jdbcType=VARCHAR},user_telephone = #{userTelephone,jdbcType=VARCHAR},user_sex = #{userSex,jdbcType=VARCHAR}where id = #{id,jdbcType=INTEGER}</update></mapper>
==因为是机器自动生成的,所以看起来比较凌乱,如需加东西可以再次配置==
Tags: JavaWeb
上一篇: spring-02-配置细节
相关文章
随机图文
评论区
2025-11-09 04:27:24
站长
没有登录功能是为了方便大家留言,但留言接口现在被恶意攻击,将关闭留言接口,如有疑问,请联系我的QQ 1538933906/同微信
