前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >MyBatis简单的增删改查以及简单的分页查询实现[通俗易懂]

MyBatis简单的增删改查以及简单的分页查询实现[通俗易懂]

作者头像
全栈程序员站长
发布2022-07-07 21:09:49
2350
发布2022-07-07 21:09:49
举报

大家好,又见面了,我是全栈君。

MyBatis简单的增删改查以及简单的分页查询实现

代码语言:javascript
复制
<?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>
代码语言:javascript
复制
<?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查询出来的结果映射到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>	<!-- 依据id查询 返回Goods类型  <typeAlias alias="goods" type="com.clark.model.Goods"></typeAlias>-->	<!--resultMap 和   resultType的使用差别-->	<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是指对查询后的结果进行升序排序 -->		<![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 參数类型为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 參数类型为Goods-->	<update id="updateGood" parameterType="goods">		update goods g 		set g.name = #{name},g.order_no =#{orderNo}		where g.id = #{id}	</update>	<!-- 删除Goods 參数类型为int-->	<delete id="deleteGood" parameterType="int">		delete from goods g 		where g.id = #{id}	</delete></mapper>
代码语言:javascript
复制
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()+"]";
	}
}
代码语言:javascript
复制
package com.clark.model;
//模拟的一个分页对象PageBean
public class PageBean {
	//開始数
	private Integer startNumber;
	//结束数
	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;
	}
}
代码语言:javascript
复制
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相应着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;
	}
}

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/116205.html原文链接:https://javaforall.cn

本文参与?腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2022年1月2,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客?前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与?腾讯云自媒体分享计划? ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
http://www.vxiaotou.com