一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術(shù)|正則表達(dá)式|C/C++|IOS|C#|Swift|Android|VB|R語(yǔ)言|JavaScript|易語(yǔ)言|vb.net|

服務(wù)器之家 - 編程語(yǔ)言 - Java教程 - 史上最簡(jiǎn)單的MyBatis動(dòng)態(tài)SQL入門示例代碼

史上最簡(jiǎn)單的MyBatis動(dòng)態(tài)SQL入門示例代碼

2020-09-01 09:40sonng Java教程

動(dòng)態(tài)sql,可以根據(jù)用戶對(duì)字段選擇和輸入,動(dòng)態(tài)生成一條sql執(zhí)行。接下來通過本文給大家分享MyBatis動(dòng)態(tài)SQL入門示例代碼,一起看看吧

假如有如下的關(guān)于書籍基本信息的表:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
DROP DATABASE IF EXISTS `books`;
CREATE DATABASE `books`;
USE books;
DROP TABLE IF EXISTS `book`;
CREATE TABLE `book` (
 `id` int(11) NOT NULL AUTO_INCREMENT,
 `name` varchar(128) DEFAULT NULL,
 `author` varchar(64) DEFAULT NULL,
 `press` varchar(64) DEFAULT NULL,
 `douban` FLOAT DEFAULT NULL,
 `isbn` varchar(13) DEFAULT NULL,
 PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=5 DEFAULT CHARSET=utf8;
INSERT INTO `book` (`name`,`author`,`press`,`douban`,`isbn`) VALUES('Java編程思想 第4版','(美)Bruce Eckel著','機(jī)械工業(yè)出版社',9.1,'9787111213826');
INSERT INTO `book` (`name`,`author`,`press`,`douban`,`isbn`) VALUES('深入理解Java虛擬機(jī) JVM高級(jí)特性與最佳實(shí)踐','周志明著','機(jī)械工業(yè)出版社',8.8,'9787111421900');
INSERT INTO `book` (`name`,`author`,`press`,`douban`,`isbn`) VALUES('瘋狂Java講義 第3版','李剛著','電子工業(yè)出版社',7.8,'9787121236693');
INSERT INTO `book` (`name`,`author`,`press`,`douban`,`isbn`) VALUES('深入理解Java 7 核心技術(shù)與最佳實(shí)踐','成富著','機(jī)械工業(yè)出版社',6.9,'9787111380399');

用戶可能用書名、出版社、豆瓣評(píng)分、ISBN中的1~4個(gè)字段進(jìn)行查詢,如果用固定的sql語(yǔ)句,那么得寫C(4,1)+C(4,2)+C(4,3)+C(4,4)=4+6+4+1=15條sql和15個(gè)Dao方法

如果用動(dòng)態(tài)sql,一條語(yǔ)句即可完成,比如這樣:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
<select id="multipSearch" parameterType="map" resultType="net.sonng.entity.Book">
  SELECT * FROM book
  <where>
    <if test="name!=null">
      name LIKE #{name}
    </if>
    <if test="press!=null">
      AND press LIKE #{press}
    </if>
    <if test="douban!=null">
      AND douban>=#{douban}
    </if>
    <if test="isbn!=null">
      AND isbn=#{isbn}
    </if>
  </where>
</select>

動(dòng)態(tài)sql,可以根據(jù)用戶對(duì)字段選擇和輸入,動(dòng)態(tài)生成一條sql執(zhí)行

實(shí)體類Book,略。

BookDao,略

Controller略

Service如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
package net.sonng.service;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import javax.annotation.Resource;
import net.sonng.dao.BookDao;
import net.sonng.entity.Book;
import org.springframework.stereotype.Service;
@Service
public class TestService {
  @Resource
  private BookDao bookDao;
  public List<Book> multipSearch(String name,String press,String douban,String isbn){
    Map<String,String> map=new HashMap();
    if (name!=null && !name.equals("")) {
      map.put("name", "%"+name+"%");
    }
    if (press!=null && !press.equals("")) {
      map.put("press","%"+press+"%");
    }
    if (douban!=null && !douban.equals("")){
      map.put("douban", douban);
    }
    if (isbn!=null && !isbn.equals("")) {
      map.put("isbn", isbn);
    }
    return bookDao.multipSearch(map);
  }
}

測(cè)試類如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
package net.sonng.test;
import java.util.List;
import net.sonng.controller.TestController;
import net.sonng.entity.Book;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
public class Test {
  public static void main(String[] args){
    ApplicationContext ac=new ClassPathXmlApplicationContext("ac.xml");
    TestController tc=ac.getBean("testController",TestController.class);//下面的4種查詢語(yǔ)句,都可以一條動(dòng)態(tài)SQL執(zhí)行
    //List<Book> books=tc.multipSearch("Java", "", "", "");        //查詢到4條
    //List<Book> books=tc.multipSearch("Java", "機(jī)械", "", "");      //3條
    //List<Book> books=tc.multipSearch("Java", "機(jī)械", "8", "");      //2條
    List<Book> books=tc.multipSearch("Java" ,"機(jī)械", "8", "9787111213826");//1條
    for (Book book:books){
      System.out.println(book.getId());
      System.out.println(book.getName());
      System.out.println(book.getIsbn());
      System.out.println(book.getAuthor());
      System.out.println(book.getPress());
      System.out.println(book.getDouban());
      System.out.println("----------------------------------");
    }
  }
}

以上所述是小編給大家介紹的史上最簡(jiǎn)單的MyBatis動(dòng)態(tài)SQL入門示例代碼,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)服務(wù)器之家網(wǎng)站的支持!

原文鏈接:http://www.cnblogs.com/sonng/archive/2017/03/23/6604135.html

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 国内精品91东航翘臀女神在线 | 99久久国产亚洲综合精品 | 免费在线公开视频 | 午夜国产福利视频一区 | 国产精品手机视频一区二区 | 无限在线观看视频大全免费高清 | 国产成人精品777 | 国产精品手机视频一区二区 | 国产精品一区二区久久不卡 | 日本一本二本三区免费 | 1024免费观看完整版在线播放 | 风间由美在线 | 亚洲AV 中文字幕 国产 欧美 | 狠狠做五月深爱婷婷天天综合 | 国产精品天天看特色大片不卡 | 亚洲第一男人天堂 | 女同性互吃奶乳免费视频 | 荷兰精品女人性hd | 美女草b| 村上里沙40分钟在线观看 | aaa免费看 | 欧美男女爱爱视频 | 公妇仑乱在线观看 | 视频久久 | 精品久久久久久久久免费影院 | 天美传媒传媒免费观看 | 2019男人天堂| 国产传媒在线播放 | 亚洲国产第一 | 色综合色狠狠天天综合色 | 午夜福利视频极品国产83 | 美女脱了内裤打开腿让人桶网站o | www.羞羞答答 | 黑人破中国女人处 | 色婷婷天天综合在线 | 色橹| 朝鲜女人free性hu | 亚洲男人的天堂成人 | 精品国产乱码久久久久久软件 | 操黄| 全色黄大色黄大片爽一次 |