使用逆向工程,帮我们更快的建立pojo类、mapper接口及xml映射文件等,无需手写,替代了一部分的mybatis功能。

一、导入MyGenarator逆向工程项目

二、修改xml配置文件



三、执行代码

生成与自己项目结构相同的文件

四、将文件拷贝至自己项目下

五、使用

1.查询

1.1 无条件查询

/**
* 1.查询所有学生信息
*/
@Test
public void getStudent(){
//查询所有,查询条件
List<Student> studentList = studentMapper.selectByExample(null);
System.out.println(studentList);
}

执行结果:

1.2 单条件查询

/**
* 2.根据姓名查学生信息
*/
@Test
public void getStuByName(){
//添加条件
StudentExample exp = new StudentExample();
exp.createCriteria().andSnameEqualTo("静静");
List<Student> studentList = studentMapper.selectByExample(exp);
System.out.println(studentList);
}

执行结果:

1.3 多条件查询

/**
* 3.根据姓名,sid查学生信息
*/
@Test
public void getStuByNameSid(){
//添加条件
StudentExample exp = new StudentExample();
exp.createCriteria().andSnameEqualTo("大林子").andSidEqualTo(3);
List<Student> studentList = studentMapper.selectByExample(exp);
System.out.println(studentList);
}

执行结果:

2. 删除

2.1 根据主键删除

/**
* 根据主键删除
*/
@Test
public void deleteByKey(){
int i = studentMapper.deleteByPrimaryKey(10);
System.out.println(i);
sqlSession.commit();
sqlSession.close();
}

执行结果:

2.2 根据自定义条件删除

/**
* 根据自定义条件删除
*/
@Test
public void delete(){
StudentExample exp = new StudentExample();
//添加姓名条件
exp.createCriteria().andSnameEqualTo("阿飞");
int i = studentMapper.deleteByExample(exp);
System.out.println(i);
sqlSession.commit();
sqlSession.close();
}

执行结果:

3. 新增

3.1 新增一条数据(所有列)

/**
* 增加学生信息
*/
@Test
public void add(){
Student student = new Student();
//sid是主键,自增,可以不写
student.setSname("章子");
student.setAge(20);
student.setCid(3);
int i = studentMapper.insert(student);
System.out.println(i);
sqlSession.commit();
sqlSession.close();
}

执行结果:

3.2 根据列名新增一条数据(其余默认)

@Test
public void add2(){
Student student = new Student();
student.setSname("关晓彤");
student.setAge(18);
int i = studentMapper.insertSelective(student);
System.out.println(i);
sqlSession.commit();
sqlSession.close();
}

执行结果:

  • 以上两者区别在于sql语句不同

4. 修改

4.1 根据条件修改信息(所有属性信息)

/**
* 根据条件修改
*/
@Test
public void update(){
Student student = new Student();
//主键不可省略(不可以修改为null)
student.setSid(15);
student.setAge(22);
StudentExample exp = new StudentExample();
exp.createCriteria().andSnameEqualTo("章子");
//将姓名为"章子"的信息修改为student
int i = studentMapper.updateByExample(student,exp);
System.out.println(i);
sqlSession.commit();
sqlSession.close();
}

执行结果:

  • 主键不可省略
  • 根据pojo类中所有的属性进行修改,没有定义的即修改为null

4.2 根据条件修改某列(修改固定列)

/**
* 根据条件修改某列
*/
@Test
public void update2(){
Student student = new Student();
student.setAge(22);
StudentExample exp = new StudentExample();
exp.createCriteria().andSnameEqualTo("老王");
//将姓名为"老王"的信息修改:修改年龄列
int i = studentMapper.updateByExampleSelective(student,exp);
System.out.println(i);
sqlSession.commit();
sqlSession.close();
}

执行结果:

4.3 根据主键修改信息(除主键外的所有属性信息)

/**
* 根据主键修改
*/
@Test
public void update3(){
Student student = new Student();
student.setSid(4);
student.setSname("岳岳");
//根据主键sid,修改这一条所有数据
int i = studentMapper.updateByPrimaryKey(student);
sqlSession.commit();
sqlSession.close();
}

执行结果:

4.4 根据主键修改某列(修改固定列)

/**
* 根据主键修改固定列
*/
@Test
public void update4(){
Student student = new Student();
student.setSid(8);
student.setCid(1);
//根据主键sid,修改固定列cid的值
int i = studentMapper.updateByPrimaryKeySelective(student);
System.out.println(i);
sqlSession.commit();
sqlSession.close();
}

执行结果:

12-如何使用Genarator逆向工程的更多相关文章

  1. node.js & read argv

    node.js & read argv https://nodejs.org/docs/latest/api/process.html https://flaviocopes.com/node ...

  2. python 各模块

    01 关于本书 02 代码约定 03 关于例子 04 如何联系我们 1 核心模块 11 介绍 111 内建函数和异常 112 操作系统接口模块 113 类型支持模块 114 正则表达式 115 语言支 ...

  3. Python Standard Library

    Python Standard Library "We'd like to pretend that 'Fredrik' is a role, but even hundreds of vo ...

  4. 在mybatis中写sql语句的一些体会

    本文会使用一个案例,就mybatis的一些基础语法进行讲解.案例中使用到的数据库表和对象如下: article表:这个表存放的是文章的基础信息 -- ------------------------- ...

  5. 从 Java 代码逆向工程生成 UML 类图和序列图

    from:http://blog.itpub.net/14780914/viewspace-588975/ 本文面向于那些软件架构师,设计师和开发人员,他们想使用 IBM® Rational® Sof ...

  6. PowerDesigner建模应用(一)逆向工程,配置数据源并导出PDM文件

    物理数据模型(Physical Data Model)PDM,提供了系统初始设计所需要的基础元素,以及相关元素之间的关系:数据库的物理设计阶段必须在此基础上进行详细的后台设计,包括数据库的存储过程.操 ...

  7. powerdesigner逆向工程 oracle

    我们已经有了数据库,希望使用powerdesigner工具生成pdm文件. 本文使用的版本是 15.0 1,  File-->Reverse Engineer-->Database... ...

  8. Hibernate【查询、连接池、逆向工程】

    前言 在Hibernate的第二篇中只是简单地说了Hibernate的几种查询方式....到目前为止,我们都是使用一些简单的主键查询阿...使用HQL查询所有的数据....本博文主要讲解Hiberna ...

  9. Java逆向工程SpringBoot + Mybatis Generator + MySQL

    Java逆向工程SpringBoot+ Mybatis Generator + MySQL Meven pop.xml文件添加引用: <dependency> <groupId> ...

  10. java框架之MyBatis(2)-进阶&整合Spring&逆向工程

    进阶内容 准备 jdbc.url=jdbc:mysql://192.168.208.192:3306/test?characterEncoding=utf-8 jdbc.driver=com.mysq ...

随机推荐

  1. PAT-basic-1024 科学计数法 java

    一.题目 科学计数法是科学家用来表示很大或很小的数字的一种方便的方法,其满足正则表达式 [+-][1-9].[0-9]+E[+-][0-9]+,即数字的整数部分只有 1 位,小数部分至少有 1 位,该 ...

  2. Access-Control-Allow-Origin php跨域报错

    Access-Control-Allow-Origin php跨域 解决办法: 1.PHP中echo:header(""Access-Control-Allow-Origin: * ...

  3. Window下载并安装WinSCP客户端

    winSCP官方网站:https://winscp.net/eng/docs/lang:chs. 环境 操作系统:Window 10 企业版LTSC;内存:8GB;操作类型:64位. 步骤 1. 打开 ...

  4. mongoDB日常操作03

    MongoDB中导出csv文件1.找到mongoDB的安装目录,bin目录2.通过控制台进入bin目录  例: cd E:\java\mongoDB\bin\3.测试mongo.exe能否运行  例: ...

  5. linux用户账户与组账户,文件权限及归属管理

    Linux是一个多用户, 多任务多进程的服务器操作系统 用户角色:超级用户(管理员),普通用户,程序用户 用户账号管理用户账号概述用户:使用者在计算机内部的身份标识 用户账号的常见分类:超级用户: r ...

  6. HCIA-ICT实战基础09-远程接入安全管理

    HCIA-ICT实战基础-远程接入安全管理 目录 AAA概述 AAA配置实现 telnet原理与配置 Stelnet(华为ssh的另一种称呼)配置 1 AAA概述 1.1 基本概念 AAA是Authe ...

  7. redis数据类型常用方法

    一.String set:添加String类型数据 get:获取String类型数据 del:删除数据 append:在原基础上追加数据,假如原来k1值是v1,执行append k1 ddd,那么值就 ...

  8. DevOps Gitlab环境部署

    DevOps 介绍 目录 DevOps 介绍 一.DevOps 介绍 1.1.1 DevOps 介绍 1.1.2 CI/CD简介 1.1.2 Gitlab安装与使用 一.DevOps 介绍 1.1.1 ...

  9. 【摘】python和它的内置类型子类化

    python和它的内置类型子类化 看个好玩的东西 class Folder(list): def __init__(self, name): self.name = name def dir(self ...

  10. Debug --> 箱线图

    箱线图主要用于反映原始数据分布的特征,还可以进行多组数据分布特征的比较. 箱形图最大的优点就是不受异常值的影响,能够准确稳定地描绘出数据的离散分布情况,同时也利于数据的清洗. 在箱图中,最上方和最下方 ...