国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

首頁 php教程 PHP開發(fā) 優(yōu)雅的使用mybatis

優(yōu)雅的使用mybatis

Nov 22, 2016 pm 01:34 PM
mybatis

mybatis初期使用比較麻煩,需要各種設(shè)定檔、實(shí)體類別、dao層映射關(guān)聯(lián)、還有一大推其它配置。當(dāng)然mybatis也發(fā)現(xiàn)了這種弊端,初期開發(fā)了generator可以根據(jù)表結(jié)果自動(dòng)生產(chǎn)實(shí)體類、設(shè)定檔和dao層程式碼,可以減輕一部分開發(fā)量;後期也進(jìn)行了大量的優(yōu)化可以使用註解了,自動(dòng)管理dao層和設(shè)定檔等,發(fā)展到最頂端就是今天要講的這種模式了,mybatis-spring-boot-starter就是springboot+mybatis可以完全註解不用設(shè)定文件,也可以簡單設(shè)定輕鬆上手。

現(xiàn)在想想spring boot 就是牛鼻呀,任何東西只要關(guān)聯(lián)到spring boot都是化繁為簡。

mybatis-spring-boot-starter

官方說明:MyBatis Spring-Boot-Starter will help you use MyBatis with Spring Boot
其實(shí)就是myBatis看spring boot這麼火熱也開發(fā)出一套解決方案來湊熱鬧一湊確實(shí)解決了許多問題,使用起來確實(shí)順暢了許多。 mybatis-spring-boot-starter主要有兩種解決方案,一種是使用註解解決一切問題,一種是簡化後的老傳統(tǒng)。

當(dāng)然任何模式都需要先引入mybatis-spring-boot-starter的pom檔,現(xiàn)在最新版本是1.1.1

<dependency>
    <groupId>org.mybatis.spring.boot</groupId>
    <artifactId>mybatis-spring-boot-starter</artifactId>
    <version>1.1.1</version></dependency>

好了下來分別介紹兩種開發(fā)模式

無設(shè)定檔使用註解搞定。

1 新增相關(guān)maven檔案

<dependencies>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-test</artifactId>
        <scope>test</scope>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
    <dependency>
        <groupId>org.mybatis.spring.boot</groupId>
        <artifactId>mybatis-spring-boot-starter</artifactId>
        <version>1.1.1</version>
    </dependency>
     <dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
    </dependency>
     <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-devtools</artifactId>
        <optional>true</optional>
    </dependency></dependencies>

完整的pom套件這裡就不貼了,大家直接看源碼

2、application.properties?新增相關(guān)設(shè)定

mybatis.type-aliases-package=com.neo.entity

spring.datasource.driverClassName = com.mysql.jdbc.Driver
spring.datasource.url = jdbc:mysql://localhost:3306/test1?useUnicode=true&characterEncoding=utf-8spring.datasource.username = root
spring.datasource.password = root

springbootoot會(huì)自動(dòng)載入spring.datasource.來源就會(huì)自動(dòng)注入到sqlSessionFactory中,sqlSessionFactory會(huì)自動(dòng)注入到Mapper中,對(duì)了你一切都不用管了,直接拿起來使用就行了。

在啟動(dòng)類別中加入對(duì)mapper套件掃描@MapperScan

@SpringBootApplication@MapperScan("com.neo.mapper")public class Application {    
public static void main(String[] args) {
        SpringApplication.run(Application.class, args);
    }
}

或直接在Mapper類別中加入註解@Mapper,建議使用上面那種,不然每個(gè)mapper加個(gè)註解也挺麻煩的

3、開發(fā)Mapper

第三步是最關(guān)鍵的一塊,sql生產(chǎn)都在這裡

public interface UserMapper {

    @Select("SELECT * FROM users")
    @Results({
        @Result(property = "userSex",  column = "user_sex", javaType = UserSexEnum.class),
        @Result(property = "nickName", column = "nick_name")
    })
    List<UserEntity> getAll();

    @Select("SELECT * FROM users WHERE id = #{id}")
    @Results({
        @Result(property = "userSex",  column = "user_sex", javaType = UserSexEnum.class),
        @Result(property = "nickName", column = "nick_name")
    })
    UserEntity getOne(Long id);

    @Insert("INSERT INTO users(userName,passWord,user_sex) VALUES(#{userName}, #{passWord}, #{userSex})")
    void insert(UserEntity user);

    @Update("UPDATE users SET userName=#{userName},nick_name=#{nickName} WHERE id =#{id}")
    void update(UserEntity user);

    @Delete("DELETE FROM users WHERE id =#{id}")
    void delete(Long id);

}

注意,使用#符號(hào)和$符號(hào)的不同:

// This example creates a prepared statement, something like select * from teacher where name = ?;
@Select("Select * from teacher where name = #{name}")
Teacher selectTeachForGivenName(@Param("name") String name);

// This example creates n inlined statement, something like select * from teacher where name = &#39;someName&#39;;
@Select("Select * from teacher where name = &#39;${name}&#39;)
Teacher selectTeachForGivenName(@Param("name") String name);

4、使用

上面三步就基本完成了相關(guān)dao層開發(fā),使用的時(shí)候當(dāng)作普通的類注入進(jìn)入就可以了

@RunWith(SpringRunner.class)@SpringBootTestpublic class UserMapperTest {    @Autowired
    private UserMapper UserMapper;    @Test
    public void testInsert() throws Exception {
        UserMapper.insert(new UserEntity("aa", "a123456", UserSexEnum.MAN));
        UserMapper.insert(new UserEntity("bb", "b123456", UserSexEnum.WOMAN));
        UserMapper.insert(new UserEntity("cc", "b123456", UserSexEnum.WOMAN));

        Assert.assertEquals(3, UserMapper.getAll().size());
    }    @Test
    public void testQuery() throws Exception {
        List<UserEntity> users = UserMapper.getAll();
        System.out.println(users.toString());
    }    @Test
    public void testUpdate() throws Exception {
        UserEntity user = UserMapper.getOne(3l);
        System.out.println(user.toString());
        user.setNickName("neo");
        UserMapper.update(user);
        Assert.assertTrue(("neo".equals(UserMapper.getOne(3l).getNickName())));
    }
}

極簡xml版本

極簡xml版本保持映射文件的老傳統(tǒng),優(yōu)化主要體現(xiàn)在不需要實(shí)現(xiàn)dao的是實(shí)現(xiàn)層,系統(tǒng)會(huì)自動(dòng)根據(jù)方法名稱在映射檔中找對(duì)應(yīng)的sql.

1、配置

pom文件和上個(gè)版本一樣,只是application.properties新增以下配置

mybatis.config-locations=classpath:mybatis/mybatis-config.xm

mybatis.config-locations=classpath:mybatis/mybatis-config.xml
mybatis.mapper-locations=classpath:mybatis/mapper/*.xml

指定了mybatis基礎(chǔ)配置文件和實(shí)體類映射文件的地址

mybatis-config.xml 配置

<configuration>
    <typeAliases>
        <typeAlias alias="Integer" type="java.lang.Integer" />
        <typeAlias alias="Long" type="java.lang.Long" />
        <typeAlias alias="HashMap" type="java.util.HashMap" />
        <typeAlias alias="LinkedHashMap" type="java.util.LinkedHashMap" />
        <typeAlias alias="ArrayList" type="java.util.ArrayList" />
        <typeAlias alias="LinkedList" type="java.util.LinkedList" />
    </typeAliases></configuration>

這里也可以添加一些mybatis基礎(chǔ)的配置

2、添加User的映射文件

<mapper namespace="com.neo.mapper.UserMapper" >
    <resultMap id="BaseResultMap" type="com.neo.entity.UserEntity" >
        <id column="id" property="id" jdbcType="BIGINT" />
        <result column="userName" property="userName" jdbcType="VARCHAR" />
        <result column="passWord" property="passWord" jdbcType="VARCHAR" />
        <result column="user_sex" property="userSex" javaType="com.neo.enums.UserSexEnum"/>
        <result column="nick_name" property="nickName" jdbcType="VARCHAR" />
    </resultMap>

    <sql id="Base_Column_List" >
        id, userName, passWord, user_sex, nick_name    </sql>

    <select id="getAll" resultMap="BaseResultMap"  >
       SELECT 
       <include refid="Base_Column_List" />
       FROM users    </select>

    <select id="getOne" parameterType="java.lang.Long" resultMap="BaseResultMap" >
        SELECT 
       <include refid="Base_Column_List" />
       FROM users
       WHERE id = #{id}
    </select>

    <insert id="insert" parameterType="com.neo.entity.UserEntity" >
       INSERT INTO 
               users
               (userName,passWord,user_sex) 
           VALUES
               (#{userName}, #{passWord}, #{userSex})    </insert>

    <update id="update" parameterType="com.neo.entity.UserEntity" >
       UPDATE 
               users 
       SET 
           <if test="userName != null">userName = #{userName},</if>
           <if test="passWord != null">passWord = #{passWord},</if>
           nick_name = #{nickName}
       WHERE 
               id = #{id}
    </update>

    <delete id="delete" parameterType="java.lang.Long" >
       DELETE FROM
                users 
       WHERE 
                id =#{id}
    </delete></mapper>

其實(shí)就是把上個(gè)版本中mapper的sql搬到了這里的xml中了

3、編寫Dao層的代碼

public interface UserMapper {

    List<UserEntity> getAll();

    UserEntity getOne(Long id);

    void insert(UserEntity user);

    void update(UserEntity user);

    void delete(Long id);

}

對(duì)比上一步這里全部只剩了接口方法

如何選擇

兩種模式各有特點(diǎn),注解版適合簡單快速的模式,其實(shí)像現(xiàn)在流行的這種微服務(wù)模式,一個(gè)微服務(wù)就會(huì)對(duì)應(yīng)一個(gè)自已的數(shù)據(jù)庫,多表連接查詢的需求會(huì)大大的降低,會(huì)越來越適合這種模式。

老傳統(tǒng)模式比適合大型項(xiàng)目,可以靈活的動(dòng)態(tài)生成SQL,方便調(diào)整SQL,也有痛痛快快,洋洋灑灑的寫SQL的感覺。


本網(wǎng)站聲明
本文內(nèi)容由網(wǎng)友自願(yuàn)投稿,版權(quán)歸原作者所有。本站不承擔(dān)相應(yīng)的法律責(zé)任。如發(fā)現(xiàn)涉嫌抄襲或侵權(quán)的內(nèi)容,請(qǐng)聯(lián)絡(luò)admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費(fèi)脫衣圖片

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅(qū)動(dòng)的應(yīng)用程序,用於創(chuàng)建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費(fèi)的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費(fèi)的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強(qiáng)大的PHP整合開發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

視覺化網(wǎng)頁開發(fā)工具

SublimeText3 Mac版

SublimeText3 Mac版

神級(jí)程式碼編輯軟體(SublimeText3)

iBatis和MyBatis:哪個(gè)比較適合你? iBatis和MyBatis:哪個(gè)比較適合你? Feb 19, 2024 pm 04:38 PM

iBatis與MyBatis:你該選擇哪一個(gè)?簡介:隨著Java語言的快速發(fā)展,許多持久化框架也應(yīng)運(yùn)而生。 iBatis和MyBatis是兩個(gè)備受歡迎的持久化框架,它們都提供了一個(gè)簡單而高效的資料存取解決方案。本文將介紹iBatis和MyBatis的特點(diǎn)和優(yōu)勢,並給出一些具體的程式碼範(fàn)例,幫助你選擇合適的框架。 iBatis簡介:iBatis是一個(gè)開源的持久化框架

比較分析JPA和MyBatis的功能和性能 比較分析JPA和MyBatis的功能和性能 Feb 19, 2024 pm 05:43 PM

JPA和MyBatis:功能與效能比較分析引言:在Java開發(fā)中,持久化框架扮演著非常重要的角色。常見的持久化框架包括JPA(JavaPersistenceAPI)和MyBatis。本文將對(duì)這兩個(gè)框架的功能和效能進(jìn)行比較分析,並提供具體的程式碼範(fàn)例。一、功能對(duì)比:JPA:JPA是JavaEE的一部分,提供了一個(gè)物件導(dǎo)向的資料持久化解決方案。它透過註解或X

詳解MyBatis動(dòng)態(tài)SQL標(biāo)籤中的Set標(biāo)籤功能 詳解MyBatis動(dòng)態(tài)SQL標(biāo)籤中的Set標(biāo)籤功能 Feb 26, 2024 pm 07:48 PM

MyBatis動(dòng)態(tài)SQL標(biāo)籤解讀:Set標(biāo)籤用法詳解MyBatis是一個(gè)優(yōu)秀的持久層框架,它提供了豐富的動(dòng)態(tài)SQL標(biāo)籤,可以靈活地建構(gòu)資料庫操作語句。其中,Set標(biāo)籤是用來產(chǎn)生UPDATE語句中SET子句的標(biāo)籤,在更新作業(yè)中非常常用。本文將詳細(xì)解讀MyBatis中Set標(biāo)籤的用法,以及透過具體的程式碼範(fàn)例來示範(fàn)其功能。什麼是Set標(biāo)籤Set標(biāo)籤用於MyBati

實(shí)作MyBatis中批次刪除操作的多種方式 實(shí)作MyBatis中批次刪除操作的多種方式 Feb 19, 2024 pm 07:31 PM

MyBatis中實(shí)現(xiàn)批量刪除語句的幾種方式,需要具體程式碼範(fàn)例近年來,由於資料量的不斷增加,批量操作成為了資料庫操作的一個(gè)重要環(huán)節(jié)之一。在實(shí)際開發(fā)中,我們經(jīng)常需要批量刪除資料庫中的記錄。本文將重點(diǎn)介紹在MyBatis中實(shí)作批量刪除語句的幾種方式,並提供相應(yīng)的程式碼範(fàn)例。使用foreach標(biāo)籤實(shí)作批量刪除MyBatis提供了foreach標(biāo)籤,可以方便地遍歷一個(gè)集

MyBatis快取機(jī)制詳解:一文讀懂快取儲(chǔ)存原理 MyBatis快取機(jī)制詳解:一文讀懂快取儲(chǔ)存原理 Feb 23, 2024 pm 04:09 PM

MyBatis快取機(jī)制詳解:一文讀懂快取儲(chǔ)存原理引言在使用MyBatis進(jìn)行資料庫存取時(shí),快取是一個(gè)非常重要的機(jī)制,能夠有效減少對(duì)資料庫的訪問,提高系統(tǒng)效能。本文將詳細(xì)介紹MyBatis的快取機(jī)制,包括快取的分類、儲(chǔ)存原理和具體的程式碼範(fàn)例。一、快取的分類MyBatis的快取主要分為一級(jí)快取和二級(jí)快取兩種。一級(jí)緩存一級(jí)緩存是SqlSession級(jí)別的緩存,當(dāng)在

iBatis與MyBatis的異同比較:主流ORM框架的對(duì)比 iBatis與MyBatis的異同比較:主流ORM框架的對(duì)比 Feb 19, 2024 pm 07:08 PM

iBatis和MyBatis是兩個(gè)主流的ORM(Object-RelationalMapping)框架,它們?cè)谠O(shè)計(jì)和使用上有著許多相似之處,也存在一些細(xì)微的差別。本文將詳細(xì)比較iBatis和MyBatis的異同,並透過具體的程式碼範(fàn)例來說明它們的特點(diǎn)。一、iBatis與MyBatis的歷史與背景iBatis是ApacheSoftwareFoundat

MyBatis Generator配置參數(shù)解讀及最佳實(shí)踐 MyBatis Generator配置參數(shù)解讀及最佳實(shí)踐 Feb 23, 2024 am 09:51 AM

MyBatisGenerator是MyBatis官方提供的程式碼產(chǎn)生工具,可以幫助開發(fā)人員快速產(chǎn)生符合資料庫表結(jié)構(gòu)的JavaBean、Mapper介面以及XML映射檔。在使用MyBatisGenerator進(jìn)行程式碼產(chǎn)生的過程中,配置參數(shù)的設(shè)定是至關(guān)重要的。本文將從配置參數(shù)的角度出發(fā),深入探討MyBatisGenerator的

深入理解MyBatis中的批次Insert實(shí)作原理 深入理解MyBatis中的批次Insert實(shí)作原理 Feb 21, 2024 pm 04:42 PM

MyBatis是一款流行的Java持久層框架,廣泛應(yīng)用於各種Java專案。其中,批次插入是常見的操作,可以有效提升資料庫操作的效能。本文將深入探討MyBatis中批量的Insert實(shí)作原理,並結(jié)合具體的程式碼範(fàn)例進(jìn)行詳細(xì)解析。 MyBatis中的批次Insert在MyBatis中,批量Insert操作通常使用動(dòng)態(tài)SQL來實(shí)作。透過建構(gòu)一條包含多個(gè)插入值的S

See all articles