12-如何使用Genarator逆向工程
使用逆向工程,帮我们更快的建立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逆向工程的更多相关文章
- node.js & read argv
node.js & read argv https://nodejs.org/docs/latest/api/process.html https://flaviocopes.com/node ...
- python 各模块
01 关于本书 02 代码约定 03 关于例子 04 如何联系我们 1 核心模块 11 介绍 111 内建函数和异常 112 操作系统接口模块 113 类型支持模块 114 正则表达式 115 语言支 ...
- Python Standard Library
Python Standard Library "We'd like to pretend that 'Fredrik' is a role, but even hundreds of vo ...
- 在mybatis中写sql语句的一些体会
本文会使用一个案例,就mybatis的一些基础语法进行讲解.案例中使用到的数据库表和对象如下: article表:这个表存放的是文章的基础信息 -- ------------------------- ...
- 从 Java 代码逆向工程生成 UML 类图和序列图
from:http://blog.itpub.net/14780914/viewspace-588975/ 本文面向于那些软件架构师,设计师和开发人员,他们想使用 IBM® Rational® Sof ...
- PowerDesigner建模应用(一)逆向工程,配置数据源并导出PDM文件
物理数据模型(Physical Data Model)PDM,提供了系统初始设计所需要的基础元素,以及相关元素之间的关系:数据库的物理设计阶段必须在此基础上进行详细的后台设计,包括数据库的存储过程.操 ...
- powerdesigner逆向工程 oracle
我们已经有了数据库,希望使用powerdesigner工具生成pdm文件. 本文使用的版本是 15.0 1, File-->Reverse Engineer-->Database... ...
- Hibernate【查询、连接池、逆向工程】
前言 在Hibernate的第二篇中只是简单地说了Hibernate的几种查询方式....到目前为止,我们都是使用一些简单的主键查询阿...使用HQL查询所有的数据....本博文主要讲解Hiberna ...
- Java逆向工程SpringBoot + Mybatis Generator + MySQL
Java逆向工程SpringBoot+ Mybatis Generator + MySQL Meven pop.xml文件添加引用: <dependency> <groupId> ...
- java框架之MyBatis(2)-进阶&整合Spring&逆向工程
进阶内容 准备 jdbc.url=jdbc:mysql://192.168.208.192:3306/test?characterEncoding=utf-8 jdbc.driver=com.mysq ...
随机推荐
- Blender2.8 使用笔记
基本 视口 小键盘/: 隔离 Z:切换线框与实体显示 Ctrl+Alt+Q : 多视图切换 Shift+C:回原点 Shift+鼠标中键 视口平移 Ctrl+上下移动 视口放大缩小 导出FBX 几何数 ...
- git 产生冲突的处理方式
理解你操作图形化的时候, git 在什么? 了解你在做的文件的git状态? 1. 添加文件 git add . -A git commit -m "your commit here" ...
- Ant Design 抽屉(tabel)
效果图如下,因部分涉及到人员隐私,所以打码了,就是一些图片文字信息. 有不足的地方可以麻烦提出来的,一起学习的. <template> <a-drawer v-model:visib ...
- HTML——VSCODE配置笔记
# 使用VSCODE编辑前端代码 ### 1.问题一:无法根据!快速生成html标准代码 (1).首先看文件命名是否出错,即文件名后缀名.html (2).第一步没出错,就在新建文件的编辑状态下拨动C ...
- 树莓派4B的Node-Red编程(一)
一.树莓派烧写 二.Node-Red 环境搭建 (一)安装Node.js (二)安装Node-Red (三)启动服务:win+R输入CMD:输入Node-red. (四)进入浏览器127.0.0.1: ...
- ES6的Map和Set的了解和练习
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- linux清除日志和文件缓存
1.查找大文件,从根目录 find / -type f -size +800M 2.查看磁盘挂载情况及挂载目录 df -lh 3.查看内存使用情况 free -m 4.清除缓存 echo 3 > ...
- 【摘】python和它的super
python和它的super 如果用过python2,你一定见过下面这个奇怪的代码 class Mama(object): def says(self): print('i am mama') cla ...
- layui 点击显示与点击隐藏
主要有lay-filter属性,靠这个属性监听 <div class="layui-col-xs12 layui-col-sm4 layui-col-md4"> < ...
- js-label
js中的label就像一个对已有语句块的命名,函数有了函数名我们可以随时调用它,语句块有了语句名我们也可以随时调用它,将他运用到循环中可快速跳出 循环. var num = 0;for (var i ...