MyBatis框架實(shí)現(xiàn)一個(gè)簡(jiǎn)單的數(shù)據(jù)查詢操作
基于在前面幾章我們已經(jīng)學(xué)習(xí)了對(duì)MyBatis進(jìn)行環(huán)境配置,并利用SqlSessionFactory核心接口生成了sqlSession對(duì)象對(duì)數(shù)據(jù)庫進(jìn)行交互,執(zhí)行增刪改查操作。這里我們就先來學(xué)習(xí)如何對(duì)數(shù)據(jù)進(jìn)行查詢的操作,具體查詢操作有以下幾個(gè)步驟
- 創(chuàng)建實(shí)體類
- 創(chuàng)建Mapper XML
- 編寫<select>SQL標(biāo)簽
- 開啟駝峰命名映射
- 新增<mapper>
- SqlSession執(zhí)行select語言
首先,我們需要有可供查詢信息的數(shù)據(jù)表并被導(dǎo)入到我們IDEA開發(fā)工具中,這里我導(dǎo)入了一個(gè)有關(guān)奶粉售賣信息的商品表

其中t-goods商品表內(nèi)容如下

我們要做的操作是按照商品編號(hào)從大到小倒序排列,并且將結(jié)果的前十條提取出來 步驟演示:
第一步.創(chuàng)建實(shí)體類
創(chuàng)建一個(gè)com.mybatis.entity.Goods包,創(chuàng)建命名為Goods代表商品的類,內(nèi)容如下:
public class Goods{
private Integer goodsId;//商品編號(hào)
private String title;//標(biāo)題
private String subTitle;//子標(biāo)題
private Float originalCost;//原始價(jià)格
private Float currentPrice;//當(dāng)前價(jià)格
private Float discount;//折扣率
private Integer isFreeDelivery;//是否包郵,1-包郵 0-不包郵
private Integer categoryId;//分類編號(hào)
}然后選中以上代碼塊快捷鍵Alt+Insert生成getter/setter方法
public Integer getGoodsId() {
return goodsId;
}
public void setGoodsId(Integer goodsId) {
this.goodsId = goodsId;
}
public String getTitle() {
return title;
}
public void setTitle(String title) {
this.title = title;
}
public String getSubTitle() {
return subTitle;
}
public void setSubTitle(String subTitle) {
this.subTitle = subTitle;
}
public Float getOriginalCost() {
return originalCost;
}
public void setOriginalCost(Float originalCost) {
this.originalCost = originalCost;
}
public Float getCurrentPrice() {
return currentPrice;
}
public void setCurrentPrice(Float currentPrice) {
this.currentPrice = currentPrice;
}
public Float getDiscount() {
return discount;
}
public void setDiscount(Float discount) {
this.discount = discount;
}
public Integer getIsFreeDelivery() {
return isFreeDelivery;
}
public void setIsFreeDelivery(Integer isFreeDelivery) {
this.isFreeDelivery = isFreeDelivery;
}
public Integer getCategoryId() {
return categoryId;
}
public void setCategoryId(Integer categoryId) {
this.categoryId = categoryId;
}
}
第二步.創(chuàng)建Mapper XML文件
在resources目錄下創(chuàng)建名為mappers的包,創(chuàng)建goods.xml文件,此文件用意是說明實(shí)體類與表之間的映射關(guān)系

第三步.編寫<select>SQL標(biāo)簽
在goods.xml中聲明 文件內(nèi)容:
//xml標(biāo)準(zhǔn)聲明部分
<?xml version="1.0" encoding ="UTF-8"?>
//Mybatis的DTD部分
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
//MyBatis映射部分 namespace:命名空間
<mapper namespace="goods">
<select id="selectAll" resultType="com.mybatis.entity.Goods">
select * from t_goods order by goods_id desc limit 10
//按照商品編號(hào)從大到小倒序排列,并且將結(jié)果的前十條提取出來
</select>
</mapper>
//resultType="com.mybatis.entity.Goods"指定了該查詢操作執(zhí)行后返回結(jié)果的類型,這里將返回的結(jié)果映射成com.mybatis.entity.Goods類型的對(duì)象第四步.新增<mapper>
然后在mybatis-config.xml中對(duì)它聲明
<mappers>
<mapper resource="mappers/goods.xml"/>
</mappers>第五步.開啟駝峰命名映射
<settings> <!--goods_id ==> goodsId 駝峰命名轉(zhuǎn)換 --> <setting name="mapUnderscoreToCamelCase" value="true"/> </settings>
第六步.SqlSession執(zhí)行select語言
打開MyBatisTestor測(cè)試用例類,執(zhí)行g(shù)oods類中書寫的SQ語句,并且得到對(duì)應(yīng)的結(jié)果
@Test
public void testSelectAll(){
SqlSession session = null;
try{
session = MyBatisUtils.openSession();
List<Goods> List = session.selectList("goods.selectALL");
//打印表結(jié)果
for(Goods g: list){
System.out.printin(g.getTitle());
}
}catch(Exception e){
throw e;
}finally{
MyBatisUtils.closeSession(session);
}
}演示查詢結(jié)果:

到此這篇關(guān)于MyBatis框架實(shí)現(xiàn)一個(gè)簡(jiǎn)單的數(shù)據(jù)查詢操作的文章就介紹到這了,更多相關(guān)MyBatis 數(shù)據(jù)查詢操作內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
解析Java的Jackson庫中Streaming API的使用
這篇文章主要介紹了解析Java的Jackson庫中Streaming API的使用,Jackson被用于Java對(duì)象和JSON的互相轉(zhuǎn)換,需要的朋友可以參考下2016-01-01
SpringBoot項(xiàng)目中Druid自動(dòng)登錄功能實(shí)現(xiàn)
Druid是Java語言中最好的數(shù)據(jù)庫連接池,Druid能夠提供強(qiáng)大的監(jiān)控和擴(kuò)展功能,這篇文章主要介紹了SpringBoot項(xiàng)目中Druid自動(dòng)登錄功能實(shí)現(xiàn),需要的朋友可以參考下2024-08-08
Springboot GET和POST請(qǐng)求參數(shù)獲取方式小結(jié)
Spring Boot GET和POST請(qǐng)求參數(shù)獲取是開發(fā)人員經(jīng)常需要解決的問題,本文主要介紹了Springboot GET和POST請(qǐng)求參數(shù)獲取方式小結(jié),具有一定的參考價(jià)值,感興趣的可以了解一下2023-09-09
springboot2自動(dòng)加載sql文件的實(shí)現(xiàn)
本文主要介紹了springboot2自動(dòng)加載sql文件的實(shí)現(xiàn),通過配置文件或注解的方式,我們可以輕松地將SQL語句映射到數(shù)據(jù)庫中,實(shí)現(xiàn)自動(dòng)加載,感興趣的可以了解一下2023-11-11
springboot實(shí)現(xiàn)excel表格導(dǎo)出幾種常見方法
在日常的開發(fā)中避免不了操作Excel,下面這篇文章主要給大家介紹了關(guān)于springboot實(shí)現(xiàn)excel表格導(dǎo)出的幾種常見方法,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-11-11
Spring?Retry實(shí)現(xiàn)重試機(jī)制的示例詳解
這篇文章主要為大家詳細(xì)介紹了Spring-Retry的用法以及實(shí)現(xiàn)原理是怎么樣的,文中的示例代碼講解詳細(xì),具有一定的參考價(jià)值,需要的可以了解一下2023-07-07

