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 ...
随机推荐
- vue v-for 使用
html <div> <el-button @click="addListItem" type="primary" style="p ...
- MySQL 打开慢查询 主从同步状态
MySql 打开慢查询 set global log_output='FILE'; SET GLOBAL slow_query_log = ON; SET GLOBAL long_query_time ...
- Pytest全局用例共用之conftest.py详解
本文转自:https://blog.csdn.net/qq_36502272/article/details/102975467 一.'conftest特点: 1.可以跨.py文件调用,有多个.py文 ...
- Navicat连接Oracle时报错ORA-28547:完美解决
1. 先用你的IDEA或者别人的连接到oracle数据库(为了查询版本) 1.1 查询版本SQL:select * from v$version; 2. 引入对应的oci.dll文件 链接:https ...
- java jdk8安装之后java -version失败
将此目录下的(C:\Program Files (x86)\Common Files\Oracle\Java\javapath_target_86850671)三个.exe文件删除即可!
- CSRF跨站点请求伪造(Cross Site Request Forgery)攻击
CSRF跨站点请求伪造(Cross Site Request Forgery)和XSS攻击一样,有巨大的危害性,就是攻击者盗用了用户的身份,以用户的身份发送恶意请求,但是对服务器来说这个请求是合理的, ...
- adaptsegnet 论文分析比较好的
https://blog.csdn.net/weixin_43795588/article/details/118058775 常用的语义分割一般是由两部分组成:一部分是特征提取器,比如可以用Resn ...
- python实现学生信息管理系统——界面版
前言(写于2022年5月17日) 这篇博客是我两年前大二时写的,一直放在草稿箱里,还没写完,现在快毕业了,突然翻出来了.虽然博客没写完,但早就写好了代码,可运行的exe文件以及文档.现在上传到gite ...
- Leetcode——二分法bisect_left,bisect_right
!前提--列表有序 case 1 如果列表中没有元素x,那么bisect_left(ls, x)和bisec_right(ls, x)返回相同的值,该值是x在ls中"合适的插入点索引,使得数 ...
- react常见bug - 查询条件变化,但page未重置为1
问题1.多次触发请求,且存在潜在的竞态问题 const [page, setPage] = useState(1); const [keyword, setKeyword] = useState('' ...