欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Mybatis實(shí)現(xiàn)增刪改查及分頁查詢的方法

 更新時間:2016年01月18日 11:03:14   投稿:mrr  
MyBatis是支持普通SQL查詢,存儲過程和高級映射的優(yōu)秀持 久層框架,通過本文給大家介紹Mybatis實(shí)現(xiàn)增刪改查及分頁查詢的方法,感興趣的朋友一起學(xué)習(xí)吧

MyBatis的前身就是iBatis。是一個數(shù)據(jù)持久層(ORM)框架。 MyBatis是支持普通SQL查詢,存儲過程和高級映射的優(yōu)秀持 久層框架。MyBatis消除了幾乎所有的JDBC 代碼和參數(shù)的手工 設(shè)置以及結(jié)果集的檢索。MyBatis使用簡單的XML或注解用于 配置和原始映射,將接口和Java 的POJOs(Plan Old Java Objects,普通的Java 對象)映射成數(shù)據(jù)庫中的記錄。每個 MyBatis應(yīng)用程序主要都是使用SqlSessionFactory實(shí)例的,一個 SqlSessionFactory實(shí)例可以通過SqlSessionFactoryBuilder獲得。

具體代碼如下所示:

<?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> 
<typeAliases> 
<!-- give a alias for model --> 
<typeAlias alias="goods" type="com.clark.model.Goods"></typeAlias> 
</typeAliases> 
<environments default="development"> 
<environment id="development"> 
<transactionManager type="JDBC" /> 
<dataSource type="POOLED"> 
<property name="driver" value="oracle.jdbc.driver.OracleDriver" /> 
<property name="url" value="jdbc:oracle:thin:@172.30.0.125:1521:oradb01" /> 
<property name="username" value="settlement" /> 
<property name="password" value="settlement" /> 
</dataSource> 
</environment> 
</environments> 
<mappers> 
<mapper resource="com/clark/model/goodsMapper.xml" /> 
</mappers> 
</configuration>
<?xml version="1.0" encoding="UTF-8"?> 
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" 
"http://mybatis.org/dtd/mybatis-3-mapper.dtd"> 
<mapper namespace="clark"> 
<!-- 將db查詢出來的結(jié)果映射到Model--Goods --> 
<resultMap type="com.clark.model.Goods" id="t_good"> 
<id column="id" property="id"/> 
<result column="cate_id" property="cateId"/> 
<result column="name" property="name"/> 
<result column="price" property="price"/> 
<result column="description" property="description"/> 
<result column="order_no" property="orderNo"/> 
<result column="update_time" property="updateTime"/> 
</resultMap> 
<!-- 根據(jù)id查詢 返回Goods類型 <typeAlias alias="goods" type="com.clark.model.Goods"></typeAlias>--> 
<!--resultMap 和 resultType的使用區(qū)別--> 
<select id="selectGoodById" parameterType="int" resultType="goods"> 
select id,cate_id,name,price,description,order_no,update_time 
from goods where id = #{id} 
</select> 
<!-- 查詢所有Goods 返回resultMap類型--> 
<select id="selectAllGoods" resultMap="t_good"> 
select id,cate_id,name,price,description,order_no,update_time from goods 
</select> 
<!-- 指定parameterType=map 其中map的形式為Map<String,PageBean> map--> 
<select id="selectGoodsByPage" resultMap="t_good" parameterType="map"> 
<!-- order by id asc是指對查詢后的結(jié)果進(jìn)行升序排序 --> 
<![CDATA[ 
select * from 
(select g.*,rownum rn from (select * from goods) g where 1=1 and rownum <= #{pageBean.endNumber}) 
where rn >= #{pageBean.startNumber}
order by id asc
]]> 
</select> 
<!-- 新增Goods 參數(shù)類型為Goods--> 
<insert id="insertGood" parameterType="goods"> 
insert into goods(id,cate_id,name,price,description,order_no,update_time) 
values(#{id},#{cateId},#{name},#{price},#{description},#{orderNo},#{updateTime}) 
</insert> 
<!-- 更新Goods 參數(shù)類型為Goods--> 
<update id="updateGood" parameterType="goods"> 
update goods g 
set g.name = #{name},g.order_no =#{orderNo} 
where g.id = #{id} 
</update> 
<!-- 刪除Goods 參數(shù)類型為int--> 
<delete id="deleteGood" parameterType="int"> 
delete from goods g 
where g.id = #{id} 
</delete> 
</mapper>
package com.clark.model; 
import java.util.Date; 
public class Goods { 
private Integer id; 
private Integer cateId; 
private String name; 
private double price; 
private String description; 
private Integer orderNo; 
private Date updateTime; 
public Goods(){ 
} 
public Goods(Integer id, Integer cateId, String name, double price, 
String description, Integer orderNo, Date updateTime) { 
super(); 
this.id = id; 
this.cateId = cateId; 
this.name = name; 
this.price = price; 
this.description = description; 
this.orderNo = orderNo; 
this.updateTime = updateTime; 
} 
public Integer getId() { 
return id; 
} 
public void setId(Integer id) { 
this.id = id; 
} 
public Integer getCateId() { 
return cateId; 
} 
public void setCateId(Integer cateId) { 
this.cateId = cateId; 
} 
public String getName() { 
return name; 
} 
public void setName(String name) { 
this.name = name; 
} 
public double getPrice() { 
return price; 
} 
public void setPrice(double price) { 
this.price = price; 
} 
public String getDescription() { 
return description; 
} 
public void setDescription(String description) { 
this.description = description; 
} 
public Integer getOrderNo() { 
return orderNo; 
} 
public void setOrderNo(Integer orderNo) { 
this.orderNo = orderNo; 
} 
public Date getTimeStamp() { 
return updateTime; 
} 
public void setTimeStamp(Date updateTime) { 
this.updateTime = updateTime; 
} 
@Override 
public String toString() { 
return "[goods include:Id="+this.getId()+",name="+this.getName()+ 
",orderNo="+this.getOrderNo()+",cateId="+this.getCateId()+ 
",updateTime="+this.getTimeStamp()+"]"; 
} 
}

package com.clark.model; 
//模擬的一個分頁對象PageBean 
public class PageBean { 
//開始數(shù) 
private Integer startNumber; 
//結(jié)束數(shù) 
private Integer endNumber; 
public PageBean(){ 
} 
public PageBean(Integer startNumber, Integer endNumber) { 
super(); 
this.startNumber = startNumber; 
this.endNumber = endNumber; 
} 
public Integer getStartNumber() { 
return startNumber; 
} 
public void setStartNumber(Integer startNumber) { 
this.startNumber = startNumber; 
} 
public Integer getEndNumber() { 
return endNumber; 
} 
public void setEndNumber(Integer endNumber) { 
this.endNumber = endNumber; 
} 
}
package com.clark.mybatis; 
import java.io.IOException; 
import java.io.Reader; 
import java.util.HashMap; 
import java.util.List; 
import java.util.Map; 
import org.apache.ibatis.io.Resources; 
import org.apache.ibatis.session.SqlSession; 
import org.apache.ibatis.session.SqlSessionFactory; 
import org.apache.ibatis.session.SqlSessionFactoryBuilder; 
import com.clark.model.Goods; 
import com.clark.model.PageBean; 
public class TestGoods { 
public static void main(String[] args) throws IOException { 
String resource = "configuration.xml"; 
Reader reader = null; 
SqlSessionFactory sessionFactory = null; 
SqlSession session = null; 
try { 
reader = Resources.getResourceAsReader(resource); 
sessionFactory = new SqlSessionFactoryBuilder().build(reader); 
session = sessionFactory.openSession(); 
PageBean pageBean = new PageBean(8, 20); 
Map<String,PageBean> map = new HashMap<String, PageBean>(); 
map.put("pageBean", pageBean); 
List<Goods> gs = findGoodsByPage(session,map); 
for (Goods goods2 : gs) { 
System.out.println(goods2.toString()); 
} 
} catch (IOException e) { 
e.printStackTrace(); 
}finally{ 
session.close(); 
reader.close(); 
} 
} 
//find by id 
public static Goods findGoodById(SqlSession session,Integer id){ 
//clark對應(yīng)著goodMapper.xml配置文件中的namespace name="clark" 
Goods goods = (Goods)session.selectOne("clark.selectGoodById", id); 
return goods; 
} 
//find all 
public static List<Goods> findAllGoods(SqlSession session){ 
List<Goods> goods = session.selectList("clark.selectAllGoods"); 
return goods; 
} 
public static List<Goods> findGoodsByPage(SqlSession session,Map<String,PageBean> map){ 
List<Goods> goods = session.selectList("clark.selectGoodsByPage",map); 
return goods; 
} 
//insert a goods 
public static int insertGoods(SqlSession session,Goods goods){ 
int result = session.insert("clark.insertGood", goods); 
session.commit(); 
return result; 
} 
//update goods 
public static int updateGoods(SqlSession session,Goods goods){ 
int result = session.update("clark.updateGood", goods); 
session.commit(); 
return result; 
} 
//delete goods 
public static int deleteGood(SqlSession session,Integer id){ 
int result = session.delete("clark.deleteGood", id); 
session.commit(); 
return result; 
} 
}

關(guān)于Mybatis實(shí)現(xiàn)增刪改查及分頁查詢的方法的相關(guān)知識,就給大家介紹到這里,后續(xù)還會持續(xù)給大家更新,謝謝大家一直以來對腳本之家網(wǎng)站的支持。

相關(guān)文章

  • Java之map的常見用法講解與五種循環(huán)遍歷實(shí)例代碼理解

    Java之map的常見用法講解與五種循環(huán)遍歷實(shí)例代碼理解

    map是一組鍵值對的組合,通俗理解類似一種特殊的數(shù)組,a[key]=val,只不過數(shù)組元素的下標(biāo)是任意一種類型,而且數(shù)組的元素的值也是任意一種類型。有點(diǎn)類似python中的字典。通過"鍵"來取值,類似生活中的字典,已知索引,來查看對應(yīng)的信息
    2021-09-09
  • SpringBoot項(xiàng)目運(yùn)行jar包啟動的步驟流程解析

    SpringBoot項(xiàng)目運(yùn)行jar包啟動的步驟流程解析

    這篇文章主要介紹了SpringBoot項(xiàng)目運(yùn)行jar包啟動的步驟流程,本文分步驟通過圖文并茂的形式給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2020-07-07
  • spring mvc中@PathVariable / 帶斜杠方式獲取

    spring mvc中@PathVariable / 帶斜杠方式獲取

    這篇文章主要介紹了spring mvc中@PathVariable / 帶斜杠方式獲取,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-08-08
  • Java日期與時間類原理解析

    Java日期與時間類原理解析

    這篇文章主要介紹了Java日期與時間類原理解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-01-01
  • 淺談web服務(wù)器項(xiàng)目中request請求和response的相關(guān)響應(yīng)處理

    淺談web服務(wù)器項(xiàng)目中request請求和response的相關(guān)響應(yīng)處理

    這篇文章主要介紹了淺談web服務(wù)器項(xiàng)目中request請求和response的相關(guān)響應(yīng)處理,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-07-07
  • Java經(jīng)典設(shè)計(jì)模式之觀察者模式原理與用法詳解

    Java經(jīng)典設(shè)計(jì)模式之觀察者模式原理與用法詳解

    這篇文章主要介紹了Java經(jīng)典設(shè)計(jì)模式之觀察者模式,簡單分析了觀察者模式的概念、原理并結(jié)合實(shí)例形式給出了java觀察者模式的具體用法與相關(guān)注意事項(xiàng),需要的朋友可以參考下
    2017-08-08
  • Spring Aop注解實(shí)現(xiàn)

    Spring Aop注解實(shí)現(xiàn)

    本文我們通過Spring AOP和Java的自定義注解來實(shí)現(xiàn)日志的插入功能,非常不錯,具有一定的參考借鑒價值,需要的朋友一起看看吧,希望對你有所幫助
    2021-07-07
  • Spring Boot 驗(yàn)證碼的生成和驗(yàn)證詳解

    Spring Boot 驗(yàn)證碼的生成和驗(yàn)證詳解

    我們在做用戶登錄的時候,為了安全性考慮,會增加驗(yàn)證碼的功能,下面這篇文章主要給大家介紹了關(guān)于Spring Boot中驗(yàn)證碼的生成和驗(yàn)證的相關(guān)資料,文中給出了詳細(xì)的示例代碼供大家參考學(xué)習(xí),需要的朋友們下面來一起看看吧。
    2017-06-06
  • java 如何遠(yuǎn)程控制tomcat啟動關(guān)機(jī)

    java 如何遠(yuǎn)程控制tomcat啟動關(guān)機(jī)

    這篇文章主要介紹了java 遠(yuǎn)程控制tomcat啟動關(guān)機(jī)的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-04-04
  • 解析SpringBoot中@Autowire注解的實(shí)現(xiàn)原理

    解析SpringBoot中@Autowire注解的實(shí)現(xiàn)原理

    在開發(fā)Java項(xiàng)目時,依賴注入是一種常見的實(shí)現(xiàn)方式,SpringBoot框架通過@Autowired注解來實(shí)現(xiàn)依賴注入的功能,本文將介紹SpringBoot中 Autowired注解實(shí)現(xiàn)的原理
    2023-06-06

最新評論