mybatis-generator 的坑我都走了一遍_import java.util.Scanner

mybatis-generator 的坑我都走了一遍_import java.util.Scanner环境​ 使用springboot2,jdk1.8,idea在pom引入相关依赖<!–mybatise-generator–><plugin><groupId

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

环境

​ 使用springboot2,jdk1.8,idea

在pom引入相关依赖

<!--mybatise-generator-->
<plugin>
    <groupId>org.mybatis.generator</groupId>
    <artifactId>mybatis-generator-maven-plugin</artifactId>
    <version>1.3.2</version>
    <configuration>
        <!--在此处指定配置文件位置-->
        <configurationFile>src/main/resources/generatorConfig/generatorConfig.xml</configurationFile>
        <verbose>true</verbose>
        <overwrite>true</overwrite>
    </configuration>
    <!--mybatise-generator-->
    <dependencies>
        <!--在此处引入所需依赖-->
        <dependency>
            <groupId>org.mybatis.generator</groupId>
            <artifactId>mybatis-generator-core</artifactId>
            <version>1.3.2</version>
        </dependency>
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>5.1.44</version>
        </dependency>
    </dependencies>
</plugin>

注意:

mybatis-generator版本如果和mysql差距過大,可能在生成代码的过程中引起报错

在Resource中配置配置文件

<?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>
    <!--注意这里的targetRuntime="MyBatis3Simple",指定了不生成Example相关内容-->
    <context id="MysqlTables" targetRuntime="MyBatis3Simple">

        <commentGenerator>
            <property name="suppressDate" value="true"/>
            <!-- 是否去除自动生成的注释 true:是 : false:否 -->
            <property name="suppressAllComments" value="true"/>
        </commentGenerator>

        <!-- jdbc链接信息 -->
        <jdbcConnection driverClass="com.mysql.jdbc.Driver"
                        connectionURL="jdbc:mysql://localhost:3306/test?useUnicode=true&amp;characterEncoding=UTF-8"
                        userId="root" password="123456">
        </jdbcConnection>

        <javaTypeResolver>
            <property name="forceBigDecimals" value="false"/>
        </javaTypeResolver>

        <!-- 生成PO类的位置 -->
        <javaModelGenerator targetPackage="com.huang.po"
                            targetProject="src/main/java">
            <property name="enableSubPackages" value="true"/>
            <property name="trimStrings" value="true"/>
        </javaModelGenerator>

        <!-- mapper映射文件生成的位置 -->
        <sqlMapGenerator targetPackage="mapper"
                         targetProject="src/main/resources">
            <property name="enableSubPackages" value="true"/>
        </sqlMapGenerator>

        <!-- mapper接口生成的位置 -->
        <javaClientGenerator type="XMLMAPPER"
                             targetPackage="com.party.community.template"
                             targetProject="src/main/java">
            <property name="enableSubPackages" value="true"/>
        </javaClientGenerator>

        <!-- 指定要生成的表,主鍵,po类名 -->
        <table tableName="Admins" domainObjectName="Admins">
            <property name="useActualColumnNames" value="true"/>
            <generatedKey column="a_id" sqlStatement="MySql" identity="true"/>
        </table>

    </context>
</generatorConfiguration>

注意:

​ 1.存放生成代码的指定包或者文件夹可以不用提前建好,只要路径没错插件会顺便一起建好

​ 2.根指定路径的不同,部分生成代码可能会需要更改。比如映射配置文件,


​ namespace的生成是根据上面的配置而生成的,如果你在生成代码后还想要移动mapper的話,要记得修改对应路径

生成代码

mybatis-generator 的坑我都走了一遍_import java.util.Scanner

代开Maven菜单,点击Plugins里的mybatis-generator,即可自动生成

目录结构

mybatis-generator 的坑我都走了一遍_import java.util.Scanner

生成的代码

java代码

package com.party.community.po;

import org.springframework.stereotype.Component;

import java.util.Date;

@Component
public class User {
    private String u_idcard;

    private String u_unsername;

    private String u_tel;

    private String u_pwd;

    private String u_avator;

    private String u_sex;

    private Date u_birthday;

    private String u_history;

    private String u_remark;

    public String getU_idcard() {
        return u_idcard;
    }

    public void setU_idcard(String u_idcard) {
        this.u_idcard = u_idcard == null ? null : u_idcard.trim();
    }

    public String getU_unsername() {
        return u_unsername;
    }

    public void setU_unsername(String u_unsername) {
        this.u_unsername = u_unsername == null ? null : u_unsername.trim();
    }

    public String getU_tel() {
        return u_tel;
    }

    public void setU_tel(String u_tel) {
        this.u_tel = u_tel == null ? null : u_tel.trim();
    }

    public String getU_pwd() {
        return u_pwd;
    }

    public void setU_pwd(String u_pwd) {
        this.u_pwd = u_pwd == null ? null : u_pwd.trim();
    }

    public String getU_avator() {
        return u_avator;
    }

    public void setU_avator(String u_avator) {
        this.u_avator = u_avator == null ? null : u_avator.trim();
    }

    public String getU_sex() {
        return u_sex;
    }

    public void setU_sex(String u_sex) {
        this.u_sex = u_sex == null ? null : u_sex.trim();
    }

    public Date getU_birthday() {
        return u_birthday;
    }

    public void setU_birthday(Date u_birthday) {
        this.u_birthday = u_birthday;
    }

    public String getU_history() {
        return u_history;
    }

    public void setU_history(String u_history) {
        this.u_history = u_history == null ? null : u_history.trim();
    }

    public String getU_remark() {
        return u_remark;
    }

    public void setU_remark(String u_remark) {
        this.u_remark = u_remark == null ? null : u_remark.trim();
    }
}

生成的po,已写好get和set方法

package com.party.community.mapper;

import com.party.community.po.User;
import java.util.List;

public interface UserMapper {
    int deleteByPrimaryKey(String u_idcard);

    int insert(User record);

    User selectByPrimaryKey(String u_idcard);

    List<User> selectAll();

    int updateByPrimaryKey(User record);

    User selectByPhone(String phone);

}

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.party.community.mapper.UserMapper" >
  <resultMap id="BaseResultMap" type="com.party.community.po.User" >
    <id column="u_idcard" property="u_idcard" jdbcType="VARCHAR" />
    <result column="u_unsername" property="u_unsername" jdbcType="VARCHAR" />
    <result column="u_tel" property="u_tel" jdbcType="VARCHAR" />
    <result column="u_pwd" property="u_pwd" jdbcType="VARCHAR" />
    <result column="u_avator" property="u_avator" jdbcType="VARCHAR" />
    <result column="u_sex" property="u_sex" jdbcType="VARCHAR" />
    <result column="u_birthday" property="u_birthday" jdbcType="TIMESTAMP" />
    <result column="u_history" property="u_history" jdbcType="VARCHAR" />
    <result column="u_remark" property="u_remark" jdbcType="VARCHAR" />
  </resultMap>
  <delete id="deleteByPrimaryKey" parameterType="java.lang.String" >
    delete from user
    where u_idcard = #{u_idcard,jdbcType=VARCHAR}
  </delete>
  <insert id="insert" parameterType="com.party.community.po.User" >
    <selectKey resultType="java.lang.String" keyProperty="u_idcard" order="AFTER" >
      SELECT LAST_INSERT_ID()
    </selectKey>
    insert into user (u_unsername, u_tel, u_pwd, 
      u_avator, u_sex, u_birthday, 
      u_history, u_remark)
    values (#{u_unsername,jdbcType=VARCHAR}, #{u_tel,jdbcType=VARCHAR}, #{u_pwd,jdbcType=VARCHAR}, 
      #{u_avator,jdbcType=VARCHAR}, #{u_sex,jdbcType=VARCHAR}, #{u_birthday,jdbcType=TIMESTAMP}, 
      #{u_history,jdbcType=VARCHAR}, #{u_remark,jdbcType=VARCHAR})
  </insert>
  <update id="updateByPrimaryKey" parameterType="com.party.community.po.User" >
    update user
    set u_unsername = #{u_unsername,jdbcType=VARCHAR},
      u_tel = #{u_tel,jdbcType=VARCHAR},
      u_pwd = #{u_pwd,jdbcType=VARCHAR},
      u_avator = #{u_avator,jdbcType=VARCHAR},
      u_sex = #{u_sex,jdbcType=VARCHAR},
      u_birthday = #{u_birthday,jdbcType=TIMESTAMP},
      u_history = #{u_history,jdbcType=VARCHAR},
      u_remark = #{u_remark,jdbcType=VARCHAR}
    where u_idcard = #{u_idcard,jdbcType=VARCHAR}
  </update>
  <select id="selectByPrimaryKey" resultMap="BaseResultMap" parameterType="java.lang.String" >
    select u_idcard, u_unsername, u_tel, u_pwd, u_avator, u_sex, u_birthday, u_history, 
    u_remark
    from user
    where u_idcard = #{u_idcard,jdbcType=VARCHAR}
  </select>
  <select id="selectAll" resultMap="BaseResultMap" >
    select u_idcard, u_unsername, u_tel, u_pwd, u_avator, u_sex, u_birthday, u_history, 
    u_remark
    from user
  </select>
  <select id="selectByPhone" resultType="User">
    select *
    from user
    where u_tel = #{phone}
  </select>


</mapper>

生成的mapper和映射文件,已经生成了基本的增删改查和根据主键查找的方法

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/170839.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • leetcode – Populating Next Right Pointers in Each Node II

    leetcode – Populating Next Right Pointers in Each Node II

  • 疫后本地生活踏入拐点,全面升级的饿了么助力身边经济

    疫后本地生活踏入拐点,全面升级的饿了么助力身边经济7月10日饿了么宣布全面升级,从餐饮外卖平台转变为解决用户身边一切即时需求的生活服务平台,并将在未来大力布局“身边经济”,打造应有尽有的生活圈。眼下,整个经济正在迎来疫情后的反弹复苏,以餐饮、生鲜、零售为代表的消费行业加速反弹,饿了么在此时宣布全面升级,可谓顺势而为,在笔者看来,此次全面升级,有两大看点。在后疫情时代,饿了么从餐饮外卖平台转型同城生活服务,也将对整个本地生活服务会产生深刻的影响。看点1:饿了么为什么在此时宣布全面升级?在零售的战场上,时机和火候往往决定一切。饿了么此次..

  • PAT乙级1013

    PAT乙级1013实现#include&lt;iostream&gt;#include&lt;cmath&gt;usingnamespacestd;boolisPrime(intnum){ inti; for(i=2;i&lt;=sqrt(num);i++) { if(num%i==0) returnfalse; } returntrue;…

  • pycharm中十个常用的快捷键「建议收藏」

    pycharm中十个常用的快捷键「建议收藏」1、ctrl+shift+A:万能命令行2、shift两次:查看资源文件3、ctrl+D:复制当前光标所在行4、ctrl+R:快速替换(一般不用)5、ctrl+/:用于注释或取消注释6、shift+tab:取消缩进(tab:缩进)7、Alt+Shift+上下键:选中代码移动8、…

  • php_network_getaddresses: getaddrinfo failed 原因

    php_network_getaddresses: getaddrinfo failed 原因

  • HashMap底层实现原理_hadoop原理

    HashMap底层实现原理_hadoop原理Note:文章的内容基于JDK1.7进行分析,1.8做的改动文章末尾进行讲解。大家可以看一下:https://www.imooc.com/article/267756一、先来熟悉一下我们常用的HashMap1、概述HashMap基于Map接口实现,元素以键值对的方式存储,并且允许使用null建和null 值, 因为key不允许重复,因此只能有一个键为null,另外HashMap不…

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号