日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

MyBatis Plus 入門使用詳細教程

瀏覽:165日期:2023-10-23 07:33:54

一、MyBatis Plus 介紹

MyBatis Plus 是國內人員開發的 MyBatis 增強工具,在 MyBatis 的基礎上只做增強不做改變,為簡化開發、提高效率而生。

MyBatis Plus 的核心功能有:支持通用的 CRUD、代碼生成器與條件構造器。

通用 CRUD:定義好 Mapper 接口后,只需要繼承 BaseMapper<T> 接口即可獲得通用的增刪改查功能,無需編寫任何接口方法與配置文件條件構造器:通過 EntityWrapper<T> (實體包裝類),可以用于拼接 SQL 語句,并且支持排序、分組查詢等復雜的 SQL代碼生成器:支持一系列的策略配置與全局配置,比 MyBatis 的代碼生成更好用

BaseMapper<T> 接口中通用的 CRUD 方法:

MyBatis Plus 入門使用詳細教程

二、MyBatis Plus 集成 Spring

數據表結構

DROP TABLE IF EXISTS `tbl_employee`;CREATE TABLE `tbl_employee` ( `id` int(11) NOT NULL AUTO_INCREMENT, `last_name` varchar(50) DEFAULT NULL, `email` varchar(50) DEFAULT NULL, `gender` char(1) DEFAULT NULL, `age` int(11) DEFAULT NULL, PRIMARY KEY (`id`)) ENGINE=InnoDB AUTO_INCREMENT=8 DEFAULT CHARSET=utf8;

pom 文件

<dependencies> <!-- MP --> <dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus</artifactId> <version>2.3</version> </dependency> <!-- 測試 --> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>4.12</version> </dependency> <!-- 數據源 --> <dependency> <groupId>com.alibaba</groupId> <artifactId>druid</artifactId> <version>1.1.10</version> </dependency> <!-- 數據庫驅動 --> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>5.1.39</version> </dependency> <!-- Spring 相關 --> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-context</artifactId> <version>4.3.9.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-orm</artifactId> <version>4.3.9.RELEASE</version> </dependency> </dependencies>

MyBatis 全局配置文件 mybatis-config.xml

<?xml version='1.0' encoding='UTF-8' ?><!DOCTYPE configuration PUBLIC '-//mybatis.org//DTD Config 3.0//EN' 'http://mybatis.org/dtd/mybatis-3-config.dtd'><!-- 不作任何配置 --><configuration />

數據源 db.properties

jdbc.url=jdbc:mysql://localhost:3306/mpjdbc.username=rootjdbc.password=1234

Spring 配置文件 applicationContext.xml

<!-- 數據源 --> <context:property-placeholder location='classpath:db.properties'/> <bean class='com.alibaba.druid.pool.DruidDataSource'> <property name='url' value='${jdbc.url}'></property> <property name='username' value='${jdbc.username}'></property> <property name='password' value='${jdbc.password}'></property> </bean> <!-- MP 提供的 MybatisSqlSessionFactoryBean --> <bean class='com.baomidou.mybatisplus.spring.MybatisSqlSessionFactoryBean'> <!-- 數據源 --> <property name='dataSource' ref='dataSource'></property> <!-- mybatis 全局配置文件 --> <property name='configLocation' value='classpath:mybatis-config.xml'></property> <!-- 別名處理 --> <property name='typeAliasesPackage' value='com.jas.bean'></property> <!-- 注入全局MP策略配置 --> <property name='globalConfig' ref='globalConfiguration'></property> <!-- 插件注冊 --> <property name='plugins'> <list> <!-- 注冊分頁插件 --> <bean /> <!-- 注入 SQL 性能分析插件,建議在開發環境中使用,可以在控制臺查看 SQL 執行日志 --> <bean class='com.baomidou.mybatisplus.plugins.PerformanceInterceptor'> <property name='maxTime' value='1000' /> <!--SQL 是否格式化 默認false--> <property name='format' value='true' /> </bean> </list> </property> </bean> <!-- 定義 MybatisPlus 的全局策略配置--> <bean class='com.baomidou.mybatisplus.entity.GlobalConfiguration'> <!-- 在 2.3 版本以后,dbColumnUnderline 默認值是 true --> <property name='dbColumnUnderline' value='true'></property> <!-- 全局的主鍵策略 --> <property name='idType' value='0'></property> <!-- 全局的表前綴策略配置 --> <property name='tablePrefix' value='tbl_'></property> </bean> <!-- 配置mybatis 掃描mapper接口的路徑 --> <bean class='org.mybatis.spring.mapper.MapperScannerConfigurer'> <property name='basePackage' value='com.jas.mapper'></property> </bean>

三、快速體驗 MyBatis Plus

實體類 Employee

@TableName(value = 'tbl_employee')public class Employee { @TableId(value = 'id', type = IdType.AUTO) private Integer id; @TableField(value = 'last_name') private String lastName; private String email; private Integer gender; private Integer age; public Employee() { super(); } public Employee(Integer id, String lastName, String email, Integer gender, Integer age) { this.id = id; this.lastName = lastName; this.email = email; this.gender = gender; this.age = age; } // 省略 set、get 與 toString() 方法

mapper 接口

/*** 不定義任何接口方法*/public interface EmployeeMapper extends BaseMapper<Employee> {}

在測試類中生成測試的 mapper 對象

private ApplicationContext context = new ClassPathXmlApplicationContext('classpath:applicationContext.xml'); private EmployeeMapper employeeMapper = context.getBean('employeeMapper', EmployeeMapper.class);

簡單查詢測試

@Test public void getEmpByIdTest() { Employee employee = employeeMapper.selectById(1); System.out.println(employee); }

分頁查詢測試

@Test public void getEmpByPage() { Page<?> page = new Page<>(1, 5); List<Employee> list = employeeMapper.selectPage(page, null); System.out.println('總記錄數:' + page.getTotal()); System.out.println('總頁數' + page.getPages()); System.out.println(list); }

條件構造器測試

@Test public void getEmpByName() { EntityWrapper<Employee> wrapper = new EntityWrapper<>(); // ’last_name’ 與 ’age’ 對應數據庫中的字段 wrapper.like('last_name', '張'); wrapper.eq('age', 20); List<Employee> list = employeeMapper.selectList(wrapper); System.out.println(list); }

控制臺輸出的 SQL 分析日志

MyBatis Plus 入門使用詳細教程

上面幾個例子中,并沒有在 EmployeeMapper 接口中定義任何方法,也沒有在配置文件中編寫 SQL 語句,而是通過繼承 BaseMapper<T> 接口獲得通用的的增刪改查方法,復雜的 SQL 也可以使用條件構造器拼接。

通過這兩種方式已經能夠滿足很多的開發需求了,不過復雜的業務需求還是要編寫 SQL 語句的,流程和 MyBatis 一樣。

PS:完整的代碼(mybatis-plus-demo 目錄)傳到了 GitHub,包括 SQL 表結構與數據文件,點我前往~

總結

標簽: Mybatis 數據庫
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
深夜福利一区| 国产精品腿扒开做爽爽爽挤奶网站| 亚洲视频二区| 国产偷自视频区视频一区二区| 欧美不卡视频| 欧美精选一区二区三区| 欧美在线影院| 国产高清一区二区| 亚洲一区二区毛片| 亚洲免费激情| 丝袜脚交一区二区| 亚洲ab电影| 国产图片一区| 免费观看亚洲天堂| 日韩欧美综合| 国产精品久一| 福利一区在线| 蜜臀av免费一区二区三区| 一本色道精品久久一区二区三区| 美女久久一区| 少妇高潮一区二区三区99| 国产乱码精品一区二区三区亚洲人| 91成人在线网站| 久久99蜜桃| 日本成人精品| 精品国产亚洲一区二区三区| 日韩不卡一区| 久久久精品五月天| 99久久精品国产亚洲精品| 久久亚洲风情| 国产精品中文字幕制服诱惑| 国产 日韩 欧美 综合 一区| 免费av一区二区三区四区| 日韩影院免费视频| 欧美日本一区| 中文字幕一区久| 国产农村妇女精品一区二区| 亚洲综合日本| 国产精品亚洲人成在99www| 精品国产不卡| 亚洲午夜视频| 亚洲精品黄色| 国内自拍视频一区二区三区| 久久中文字幕二区| 亚洲一区二区三区久久久| 欧美日韩一区二区三区四区在线观看| 国产精品久久久一区二区| 日韩精品1区| 中文字幕免费一区二区| 久久久国产精品网站| 久久久国产精品一区二区中文| 蜜臀久久99精品久久久久宅男| 亚洲毛片网站| 国产一区精品福利| 麻豆精品91| 欧美中文日韩| 狠狠久久伊人中文字幕| 国产精品毛片一区二区三区| 国产亚洲一区| 免费观看久久av| 国产亚洲精品精品国产亚洲综合| 欧美13videosex性极品| 日韩精品福利一区二区三区| 新版的欧美在线视频| 亚洲精品国产精品粉嫩| 青青青免费在线视频| 亚洲综合专区| 精品三级久久久| 国产色综合网| 精品国产欧美日韩| 美国三级日本三级久久99 | 国产精品啊啊啊| 欧美粗暴jizz性欧美20| 国产欧美高清| 亚洲专区一区| av综合电影网站| 国产亚洲欧美日韩精品一区二区三区 | 国产成人精品999在线观看| 亚洲欧美日韩高清在线| 久久精品国产精品亚洲毛片| 免费欧美一区| 精品国产不卡| 日韩二区三区在线观看| 欧美亚洲在线日韩| 久久不卡国产精品一区二区| 亚洲欧美日韩国产综合精品二区| 福利视频一区| 欧美一级一区| 性色一区二区| 丝袜美腿诱惑一区二区三区| 国产伦精品一区二区三区视频| 亚洲欧美视频| 久久一区二区三区电影| 欧美三级第一页| 美女精品在线| 91精品啪在线观看国产18| 麻豆一区二区三区| 日本成人在线网站| 老鸭窝毛片一区二区三区| 久久三级视频| 岛国av在线播放| 久久99久久久精品欧美| 午夜电影一区| 亚洲精品中文字幕乱码| 精精国产xxxx视频在线野外| 国产成人精品999在线观看| 久久国产免费看| 日本成人中文字幕| 中文字幕av亚洲精品一部二部| 亚洲激情不卡| 日本欧美不卡| 波多视频一区| 中文字幕高清在线播放| 国产福利资源一区| 久久精品99国产精品日本| 综合亚洲色图| 久久成人一区| 在线观看免费一区二区| 91精品亚洲| 99精品视频在线观看免费播放| 日产精品一区二区| 国产精品videossex久久发布| 欧美日韩精品一区二区三区视频 | 亚洲精品123区| 亚洲黑丝一区二区| 久久国产欧美| 久久福利在线| 欧美日韩精品免费观看视频完整| 播放一区二区| xxxxx性欧美特大| 在线人成日本视频| 激情视频网站在线播放色| 国产一区二区三区日韩精品 | 在线精品一区二区| 久久国产高清| 亚州av一区| 日韩精品乱码av一区二区| 日本亚洲欧美天堂免费| 日韩高清一区| 国产精品17p| 电影91久久久| 都市激情国产精品| 久久久久国产精品一区二区| 伊人久久在线| 欧美日韩激情| 亚洲一区二区三区久久久| 亚洲人www| 欧美日韩视频免费看| 91成人在线| 精品视频久久| 激情黄产视频在线免费观看| 91精品精品| 丝袜a∨在线一区二区三区不卡| 无码日韩精品一区二区免费| 国产情侣久久| 国产成人调教视频在线观看| 丰满少妇一区| 久久在线免费| 亚洲精品激情| 久久av电影| 婷婷综合六月| 三级在线观看一区二区| 人人爱人人干婷婷丁香亚洲| 国产精品欧美一区二区三区不卡| 精品国产91| 一区二区视频欧美| 三级久久三级久久久| 国产高清日韩| 99精品视频在线| 中文字幕亚洲在线观看| 久久av影院| 亚洲第一区色| 亚洲三级国产| 久久精品国产999大香线蕉| 一本大道色婷婷在线| 免费欧美日韩| 美女视频一区在线观看| 久久久久中文| 久久国产成人| 免费一区二区三区在线视频| 久久中文字幕二区| 日本不卡高清| 日韩黄色大片网站| 美国三级日本三级久久99| 久久成人福利| 999在线观看精品免费不卡网站| 中文字幕日韩亚洲| 精品中文字幕一区二区三区四区| 亚洲午夜精品久久久久久app| 日本伊人久久| 中文字幕色婷婷在线视频| 99热免费精品| 国产精品主播在线观看| 日本精品影院| 18国产精品| 欧美成人精品| 精品亚洲成人| 亚洲精选91| 国模 一区 二区 三区| 国产免费播放一区二区|