日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

mybatisgenerator使用_如何优雅地使用MyBatisplus

發(fā)布時間:2025/3/19 编程问答 32 豆豆
生活随笔 收集整理的這篇文章主要介紹了 mybatisgenerator使用_如何优雅地使用MyBatisplus 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

mybatis

Mybatis 是一款優(yōu)秀的持久層框架,它支持定制化 SQL、存儲過程以及高級映射。MyBatis 避免了幾乎所有的 JDBC 代碼和手動設(shè)置參數(shù)以及獲取結(jié)果集。MyBatis 可以使用簡單的 XML 或注解來配置和映射原生信息,將接口和 Java 的 POJOs(Plain Old Java Objects,普通的 Java對象)映射成數(shù)據(jù)庫中的記錄。

但mybatis有個比較頭疼的一個問題是sql工作量很大,尤其是字段多的時候。雖然說單表的增刪改查操作可以通過mybatis generator工具來生成(或者自己寫模板工具生成),但項目開發(fā)的過程中總免不了要新添加新字段,這些工具就沒多大作用,所以要么把新字段寫到原來的所有增刪改查的sql中,要么刪了重新生成。這是個痛苦的過程,特別是當(dāng)你重復(fù)了很多次之后。

mybatis-plus

而mybatis-plus這樣一個框架,一種集mybatis與hibernate的優(yōu)點一起的框架。它提供了hibernate的單表CRUD操作的方便同時,又保留了mybatis的特性。

先來看看官方怎么解釋mybatis-plus的:

Mybatis-Plus(簡稱MP)是一個Mybatis的增強(qiáng)工具,在 Mybatis 的基礎(chǔ)上只做增強(qiáng)不做改變,為簡化開發(fā)、提高效率而生。

快速使用步驟:

1.添加pom文件依賴

org.apache.velocity

velocity

1.7

com.baomidou

mybatis-plus

2.0.1

注意:mybatis-plus會自動維護(hù)mybatis以及mybatis-spring的依賴,所以不需要引入后兩者,避免發(fā)生版本沖突.

2.修改配置文件

將mybatis的sqlSessionFactory替換成mybatis-plus的即可,mybatis-plus只做了一些功能的擴(kuò)展:

<bean id="sqlSessionFactory" class="com.baomidou.mybatisplus.spring.MybatisSqlSessionFactoryBean">
<property name="dataSource" ref="dataSource"/>

<property name="mapperLocations" value="classpath:mybatis/*/*.xml"/>
<property name="configLocation" value="classpath:mybatis/mybatis-config.xml"/>
<property name="typeAliasesPackage" value="com.baomidou.springmvc.model.*"/>
<property name="plugins">
<array>

<bean id="paginationInterceptor" class="com.baomidou.mybatisplus.plugins.PaginationInterceptor">
<property name="dialectType" value="mysql"/>
bean>
array>
property>

<property name="globalConfig" ref="globalConfig" />
bean>

在上面的配置中,除了mybatis的常規(guī)配置,多了一個分頁插件的配置和全局配置,mybatis-plus提供了很方便的使用分頁的插件,還有一個全局配置如下:

<bean id="globalConfig" class="com.baomidou.mybatisplus.entity.GlobalConfiguration">

<property name="idType" value="2" />




<property name="dbColumnUnderline" value="true" />
bean>

至此,配置工作就算大功告成了,接下來通過一個簡單的例子來感受一下它的使用.

1.新建一個User表:

@TableName("user")
public class User implements Serializable {
/** 用戶ID */
private Long id;
/** 用戶名 */
private String name;
/** 用戶年齡 */
private Integer age;
@TableField(exist = false)
private String state;
}

這里有兩個注解需要注意,第一是@tableName("user"),它是指定與數(shù)據(jù)庫表的關(guān)聯(lián),這里的注解意味著你的數(shù)據(jù)庫里應(yīng)該有一個名為user的表與之對應(yīng),并且數(shù)據(jù)表的列名應(yīng)該就是User類的屬性,對于User類中有而user表中沒有的屬性需要加第二個注解@TableField(exist = false),表示排除User類中的屬性.

2.新建Dao層接口UserMapper:

/**
* User 表數(shù)據(jù)庫控制層接口
*/
public interface UserMapper extends BaseMapper<User> {
@Select("selectUserList")
List selectUserList(Pagination page,String state);
}

dao接口需要實現(xiàn)Basemapper,這樣就能夠使用封裝好的很多通用方法,另外也可以自己編寫方法,@select注解引用自第三步的UserMapper文件

3.新建UserMapper配置文件:

xml version="1.0" encoding="UTF-8"?><mapper namespace="com.baomidou.springmvc.mapper.system.UserMapper"><sql id="Base_Column_List">
id, name, agesql><select id="selectUserList" resultType="User">
SELECT * FROM sys_user WHERE state=#{state}select>mapper>

4.新建service層類UserService:

/**
*
* User 表數(shù)據(jù)服務(wù)層接口實現(xiàn)類
*
*/
@Service
public class UserService extends ServiceImpl, User>{
public Page<User> selectUserPage(Page<User> page, String state) {
page.setRecords(baseMapper.selectUserList(page,state));return page;
}
}

UserService繼承了ServiceImpl類,mybatis-plus通過這種方式為我們注入了UserMapper,這樣可以使用service層默認(rèn)為我們提供的很多方法,也可以調(diào)用我們自己在dao層編寫的操作數(shù)據(jù)庫的方法.Page類是mybatis-plus提供分頁功能的一個model,繼承了Pagination,這樣我們也不需要自己再編寫一個Page類,直接使用即可.

5,新建controller層UserController

@Controller
public class UserController extends BaseController {
@Autowired
private IUserService userService;
@ResponseBody
@RequestMapping("/page")
public Object selectPage(Model model){
Page page=new Page(1,10);
page = userService.selectUserPage(page, "NORMAL");
return page;
}

以上就完成了一個基本的功能,下面來看一下它的條件構(gòu)建器.

mybatis-plus的條件構(gòu)建器

首先看一個條件構(gòu)建器實例的簡單實用.

public void test(){
EntityWrapper ew=new EntityWrapper();
ew.setEntity(new User());
String name="wang";
Integer age=16;
ew.where("name = {0}",name).andNew("age > {0}",age).orderBy("age");
List list = userService.selectList(ew); Page page2 = userService.selectPage(page, ew);
}

總結(jié)

以上是生活随笔為你收集整理的mybatisgenerator使用_如何优雅地使用MyBatisplus的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。