当前位置:网站首页>tkmapper的crud示例:
tkmapper的crud示例:
2022-08-04 02:43:00 【小刘-鱼皮】
tkmapper的demo示例:
1.创建项目:
- 目录结构:
2.导入依赖
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>8.0.20</version>
</dependency>
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>2.2.0</version>
</dependency>
<!--tk的依赖-->
<dependency>
<groupId>tk.mybatis</groupId>
<artifactId>mapper-spring-boot-starter</artifactId>
<version>2.1.5</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
</dependency>
3.添加配置:
server:
port: 8080
servlet:
context-path: /
#连接数据库的信息
spring:
datasource:
driver-class-name: com.mysql.cj.jdbc.Driver
url: jdbc:mysql://localhost:3306/users?serverTimezone=UTC&useUnicode=true&characterEncoding=UTF-8
username: root
password: root
mybatis:
# 扫描映射文件
mapper-locations: classpath:mapper/*.xml
# 配置别名扫描的包
type-aliases-package: com.example.tkmapper.model
configuration:
# 开启驼峰映射配置
map-underscore-to-camel-case: true
3.1 数据库表
/* Navicat Premium Data Transfer Source Server : localhost Source Server Type : MySQL Source Server Version : 80028 Source Host : localhost:3306 Source Schema : users Target Server Type : MySQL Target Server Version : 80028 File Encoding : 65001 Date: 26/07/2022 22:34:56 */
SET NAMES utf8mb4;
SET FOREIGN_KEY_CHECKS = 0;
-- ----------------------------
-- Table structure for category
-- ----------------------------
DROP TABLE IF EXISTS `category`;
CREATE TABLE `category` (
`category_id` int(0) NOT NULL AUTO_INCREMENT,
`category_name` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL,
`category_level` int(0) NULL DEFAULT NULL,
`parent_id` int(0) NULL DEFAULT NULL,
`category_icon` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL,
`category_slogan` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL,
`category_pic` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL,
`category_bg_color` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL,
PRIMARY KEY (`category_id`) USING BTREE
) ENGINE = InnoDB CHARACTER SET = utf8mb4 COLLATE = utf8mb4_0900_ai_ci ROW_FORMAT = Dynamic;
-- ----------------------------
-- Records of category
-- ----------------------------
INSERT INTO `category` VALUES (2, '测试类别4', 1, 0, '04.png', 'heihei', 'aaa.jpg', 'black');
-- ----------------------------
-- Table structure for users
-- ----------------------------
DROP TABLE IF EXISTS `users`;
CREATE TABLE `users` (
`user_id` int(0) NOT NULL AUTO_INCREMENT COMMENT '主键id 用户id',
`username` varchar(32) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL COMMENT '用户名 用户名',
`password` varchar(64) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL COMMENT '密码 密码',
`nickname` varchar(32) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '昵称 昵称',
`realname` varchar(128) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '真实姓名 真实姓名',
`user_img` varchar(1024) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL COMMENT '头像 头像',
`user_mobile` varchar(32) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '手机号 手机号',
`user_email` varchar(32) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '邮箱地址 邮箱地址',
`user_sex` char(1) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '性别 M(男) or F(女)',
`user_birth` date NULL DEFAULT NULL COMMENT '生日 生日',
`user_regtime` datetime(0) NOT NULL COMMENT '注册时间 创建时间',
`user_modtime` datetime(0) NOT NULL COMMENT '更新时间 更新时间',
PRIMARY KEY (`user_id`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 2 CHARACTER SET = utf8 COLLATE = utf8_general_ci COMMENT = '用户 ' ROW_FORMAT = Compact;
-- ----------------------------
-- Records of users
-- ----------------------------
INSERT INTO `users` VALUES (2, 'aaaa', '1111', NULL, NULL, 'img/default.png', NULL, NULL, NULL, NULL, '2022-07-26 13:54:40', '2022-07-26 13:54:40');
INSERT INTO `users` VALUES (3, 'zhangsan', '11', 'liulq', 'liu', 'zhsj.com', '18423386237', '[email protected],com', '1', '2022-07-26', '2022-07-26 13:55:05', '2022-07-26 13:55:05');
SET FOREIGN_KEY_CHECKS = 1;
3.2 创建model、service、controler、mapper
package com.example.tkmapper.mapper;
import com.example.tkmapper.model.Category;
import tk.mybatis.mapper.common.Mapper;
import tk.mybatis.mapper.common.MySqlMapper;
public interface CategoryMapper extends Mapper<Category>, MySqlMapper<Category> {
}
package com.example.tkmapper.mapper;
import com.example.tkmapper.model.Users;
import tk.mybatis.mapper.common.Mapper;
import tk.mybatis.mapper.common.MySqlMapper;
public interface UserMapper extends Mapper<Users>, MySqlMapper<Users> {
}
package com.example.tkmapper.model;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import javax.persistence.Column;
import javax.persistence.Id;
@Data
@NoArgsConstructor
@AllArgsConstructor
public class Category {
@Id
private Integer categoryId;
private String categoryName;
private Integer categoryLevel;
private Integer parentId;
private String categoryIcon;
private String categorySlogan;
private String categoryPic;
private String categoryBgColor;
}
package com.example.tkmapper.model;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import lombok.ToString;
import javax.persistence.Id;
import javax.persistence.Table;
import java.util.Date;
@Data
@NoArgsConstructor
@AllArgsConstructor
@ToString
@Table(name="users")// 表名和数据库名不一致无法映射
public class Users {
private int userId;
private String username;
private String password;
private String nickname;
private String realname;
private String userImg;
private String userMobile;
private String userEmail;
private String userSex;
private Date userBirth;
private Date userRegtime;
private Date userModtime;
}
package com.example.tkmapper;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import tk.mybatis.spring.annotation.MapperScan;
@SpringBootApplication
@MapperScan("com.example.tkmapper.mapper")//扫描mapper层
public class TkmapperApplication {
public static void main(String[] args) {
SpringApplication.run(TkmapperApplication.class, args);
}
}
4.测试 crud
package com.example.tkmapper;
import com.example.tkmapper.mapper.CategoryMapper;
import com.example.tkmapper.mapper.UserMapper;
import com.example.tkmapper.model.Category;
import com.example.tkmapper.model.Users;
import org.apache.ibatis.session.RowBounds;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import tk.mybatis.mapper.entity.Example;
import java.util.Date;
import java.util.List;
import static org.junit.jupiter.api.Assertions.assertEquals;
@SpringBootTest
class TkmapperApplicationTests {
@Autowired
private UserMapper userMapper;
@Autowired
private CategoryMapper categoryMapper;
/** * @Description: 新增 * @Param: * @return: * @Author: liulq * @date: 2022/7/26 */
@Test
public void testInsert() {
Users users = new Users();
users.setUsername("zhangsan");
users.setPassword("11");
users.setNickname("liulq");
users.setRealname("liu");
users.setUserImg("zhsj.com");
users.setUserMobile("18423386237");
users.setUserEmail("[email protected],com");
users.setUserSex("1");
users.setUserBirth(new Date());
users.setUserRegtime(new Date());
users.setUserModtime(new Date());
int insert = this.userMapper.insert(users);
if (insert > 0) {
System.out.println("成功");
}
}
/** * @Description: 增加 * @Param: * @return: * @Author: liulq * @date: 2022/7/26 */
@Test
public void insert() {
Category category = new Category(0, "测试类别3", 1, 0, "03.png", "xixi", "aaa.jpg", "black");
//注意如果要主键回填一定要在对应的实体类的主键上添加@Id
int i = this.categoryMapper.insertUseGeneratedKeys(category);
assertEquals(1, i);
}
/** * @Description: 修改 * @Param: * @return: * @Author: liulq * @date: 2022/7/26 */
@Test
public void update() {
Category category = new Category(2,"测试类别4",1,0,"04.png","heihei","aaa.jpg","black");
int i = this.categoryMapper.updateByPrimaryKey(category);
// 根据自定义条件修改,Example example就是封装条件的
// int i1 = categoryDAO.updateByExample( Example example);
assertEquals(1,i);
}
/** * @Description: 删除 * @Param: * @return: * @Author: liulq * @date: 2022/7/26 */
@Test
public void deleted() {
//根据主键字段进行删除,方法参数必须包含完整的主键属性
int i = this.categoryMapper.deleteByPrimaryKey(1);
}
/** * @Description: 查询列表 * @Param: * @return: * @Author: liulq * @date: 2022/7/26 */
@Test
public void list() {
//查询全部结果
List<Category> categories = this.categoryMapper.selectAll();
for (int i = 0; i < categories.size(); i++) {
System.out.println(categories);
}
}
/** * @Description: 根据id查询 * @Param: * @return: * @Author: liulq * @date: 2022/7/26 */
@Test
public void selectById() {
Category category = this.categoryMapper.selectByPrimaryKey(2);
System.out.println(category);
}
/** * @Description: 分页查询 * @Param: * @return: * @Author: liulq * @date: 2022/7/26 */
@Test
public void page() {
//设页码
int pageNum = 2;
//设页数
int pageSize = 10;
//当前页
int start = (pageNum - 1) * pageSize;
RowBounds rowBounds = new RowBounds(start,pageSize);
List<Category> categories = this.categoryMapper.selectByRowBounds(new Category(), rowBounds);
for (Category category: categories) {
System.out.println(category);
}
//查询总记录数
int i = this.categoryMapper.selectCount(new Category());
System.out.println(i);
}
/** *@Description: 条件查询 *@Param: *@return: *@Author: liulq *@date: 2022/7/26 */
@Test
public void selectQuery(){
//1.创建一个Example封装 类别Category查询条件
Example example = new Example(Category.class);
Example.Criteria criteria = example.createCriteria();
criteria.andEqualTo("categoryLevel",1);
criteria.orLike("categoryName","%干%");
List<Category> categories = this.categoryMapper.selectByExample(example);
for (Category category: categories) {
System.out.println(category);
}
}
/** *@Description: 带条件分页 *@Param: *@return: *@Author: liulq *@date: 2022/7/26 */
@Test
public void selectPage(){
//带条件分页
//条件
Example example = new Example(Category.class);
Example.Criteria criteria = example.createCriteria();
criteria.andEqualTo("categoryLevel",1);
//分页
int pageNum = 2;
int pageSize = 3;
int start = (pageNum-1)*pageSize;
RowBounds rowBounds = new RowBounds(start,pageSize);
List<Category> categories = this.categoryMapper.selectByExampleAndRowBounds(example,rowBounds);
for (Category category: categories) {
System.out.println(category);
}
//查询总记录数(满足条件)
int i = this.categoryMapper.selectCountByExample(example);
System.out.println(i);
}
}
5 条件查询api
ok,不完善的地方请看官方文档
https://mapperhelper.github.io/docs/
边栏推荐
猜你喜欢
JVM内存和垃圾回收-07.堆
Dong mingzhu live cold face away, when employees frequency low-level mistakes, no one can understand their products
【指针内功修炼】深度剖析指针笔试题(三)
Zabbix设置邮件告警+企业微信告警
Example 041: Methods and variables of a class
Presto中broadcast join和partition join执行计划的处理过程
出海季,互联网出海锦囊之本地化
一文看懂推荐系统:召回05:矩阵补充、最近邻查找,工业界基本不用了,但是有助于理解双塔模型
MySQL高级-读写分离-分库分表
Deep Learning (3) Classification Theory Part
随机推荐
Dong mingzhu live cold face away, when employees frequency low-level mistakes, no one can understand their products
ant-design的Select组件采用自定义后缀图标(suffixIcon属性)时,点击该自定义图标没有反应,不会展示下拉菜单的问题
[Original] Start the XPS/OXPS reader that comes with Windows 10
Ant - the design of the Select component using a custom icon (suffixIcon attribute) suffixes, click on the custom ICONS have no reaction, will not display the drop-down menu
【云原生】DevOps(六):Jenkins流水线
In the season of going overseas, the localization of Internet tips for going overseas
unsafe.Pointer, pointer, reference in golang
Day13 Postman的使用
各位大佬好,麻烦问一下flink cdc oracle写入doris的时候,发现cpu异常,一下下跑
priority_queue元素为指针时,重载运算符失效
2022广东省安全员A证第三批(主要负责人)考试题库及模拟考试
JVM内存和垃圾回收-07.堆
架构实战营模块三作业
Rongyun "Audio and Video Architecture Practice" technical session [complete PPT included]
STM8S105K4T6------串口发送和接收
sqoop ETL工具
activiti流程执行过程中,数据库表的使用关系
C语言--环形缓存区
ssh服务详解
在更一般意义上验算移位距离和假设