详解Mybatis Generator的具体使用教程

网友投稿 946 2022-11-01

详解Mybatis Generator的具体使用教程

详解Mybatis Generator的具体使用教程

目录1、相关文件2、使用方法

Mybatis属于半自动ORM,在使用这个框架中,工作量最大的就是书写Mapping的映射文件,由于手动书写很容易出错,我们可以利用Mybatis-Generator来帮我们自动生成文件。

1、相关文件

关于Mybatis-Generator的-可以到这个地址:https://github.com/mybatis/generator/releases

由于我使用的是mysql数据库,这里需要在准备一个连接mysql数据库的驱动jar包

以下是相关文件截图:

和Hibernate逆向生成一样,这里也需要一个配置文件:

generatorConfig.xml

PUBLIC "-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN"

"http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd">

需要修改文件配置的地方我都已经把注释标注出来了,这里的相关路径(如数据库驱动包,生成对应的相关文件位置可以自定义)不能带有中文。

上面配置文件中的:

tableName和domainObjectName为必选项,分别代表数据库表名和生成的实力类名,其余的可以自定义去选择(一般情况下均为false)。

生成语句文件:

java -jar mybatis-generator-core-1.3.2.jar -configfile generatorConfig.xml -overwrite

2、使用方法

在该目录按住Shift键,右键鼠标选择"在此处打开命令窗口",复制粘贴生成语句的文件代码即可。

看下效果图:

生成相关代码:

Message.java

package lcw.model;

public class Messgae {

private Integer id;

private String title;

private String describe;

private String content;

public Integer getId() {

return id;

}

public void setId(Integer id) {

this.id = id;

}

public String getTitle() {

return title;

}

public void setTitle(String title) {

this.title = title == null ? null : title.trim();

}

public String getDescribe() {

return describe;

}

public void setDescribe(String describe) {

this.describe = describe == null ? null : describe.trim();

}

public String getContent() {

return content;

}

public void setContent(String content) {

this.content = content == null ? null : content.trim();

}

}

MessgaeMapper.xml

id, title, describe, content

select

from message

where id = #{id,jdbcType=INTEGER}

delete from message

where id = #{id,jdbcType=INTEGER}

insert into message (id, title, describe,

content)

values (#{id,jdbcType=INTEGER}, #{title,jdbcType=VARCHAR}, #{describe,jdbcType=VARCHAR},

#{content,jdbcType=VARCHAR})

inserthttp:// into message

id,

title,

describe,

content,

#{id,jdbcType=INTEGER},

#{title,jdbcType=VARCHAR},

#{describe,jdbcType=VARCHAR},

#{content,jdbcType=VARCHAR},

update message

title = #{title,jdbcType=VARCHAR},

describe = #{describe,jdbcType=VARCHAR},

content = #{content,jdbcType=VARCHAR},

where id = #{id,jdbcType=INTEGER}

update message

set title = #{title,jdbcType=VARCHAR},

describe = #{describe,jdbcType=VARCHAR},

content = #{content,jdbcType=VARCHAR}

where id = #{id,jdbcType=INTEGER}

MessgaeMapper.java

package lcw.dao;

import lcw.model.Messgae;

public interface MessgaeMapper {

int deleteByPrimaryKey(Integer id);

int insert(Messgae record);

int insertSelective(Messgae record);

Messgae selectByPrimaryKey(Integer id);

int updateByPrimaryKeySelective(Messgae record);

int updateByPrimaryKey(Messgae record);

}

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:revel:一个高生产力,全栈的Go语言Web开发框架
下一篇:Vivid: 为 Apple Core Image 框架提供的一系列效果和工具
相关文章

 发表评论

暂时没有评论,来抢沙发吧~