MyBatis编写映射文件实现增删改操作 附说明即源码

1.看一下我们接口

package cn.bdqn.mybatis.dao;

import org.apache.ibatis.annotations.Select;

import cn.bdqn.mybatis.been.Emp;
/**
 * 这个接口不用写实现类,是用来给empMapper.xml进行动态绑定的
 * @author Administrator
 *
 */
public interface EmpMapper {

	public Emp getEmpById(Integer id);
	public void addEmp(Emp emp);
	/**
	 * MyBatis允许增删改直接定义一下类型返回值
	 * int long boolean 以及相应的包装类,
	 * 在接口中定义方法的时候,直接定义相应的返回值即可,无其他操作
	 * @param emp
	 * @return
	 */
	public boolean updateEmp(Emp emp);
	public void deleteEmpById(Integer id);
}

  

2.编写mapper

<?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">
<!--namespace:名称空间 -->
<mapper namespace="cn.bdqn.mybatis.dao.EmpMapper">
	<!-- id,唯一标识 resultType:返回值类型,bean的全限定名称 #{id},从传递过来的参数中取出id值,相当于换位符 public
		Emp getEmpById(Integer id); -->
	<select id="getEmpById" resultType="cn.bdqn.mybatis.been.Emp"
		databaseId="mysql">
		select * from emp where id = #{id}
	</select>
	<select id="getEmpById" resultType="cn.bdqn.mybatis.been.Emp"
		databaseId="oracle">
		select * from emp where id = #{id}
	</select>
	<!-- public void addEmp(Emp emp); insert标签: id:对应我们javaBean的方法名 parameterType
		可以省略,如果要写就是javaBean的全限定名称 insert into emp(last_name,gender,email) values(#{last_name},#{gender},#{email})
		结尾不需要分号,values值的#{对应的javaBean的属性名} -->
	<insert id="addEmp" parameterType="cn.bdqn.mybatis.been.Emp">
		insert into emp(last_name,email,gender)
		values(#{last_name},#{email},#{gender})
	</insert>
	<!-- update标签: public void updateEmp(Emp emp); id:对应我们javaBean的方法名 parameterType
		可以省略,如果要写就是javaBean的全限定名称 update emp set last_name=#{last_name},email=#{email},gender=#{gender}
		while id=#{id} 结尾不需要分号,#{}相当于占位符,等于我们传过来的值 -->
	<update id="updateEmp">
		update emp set last_name=#{last_name},email=#{email},gender=#{gender}	where
		id=#{id}
	</update>
	<!-- delet标签: public void deleteEmpById(Integer id); -->
	<delete id="deleteEmpById">
		delete from emp where id=#{id}
	</delete>

</mapper>

  3.编写测试类

package cn.bdqn.mybatis.test;

import java.io.IOException;
import java.io.InputStream;

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 cn.bdqn.mybatis.been.Emp;
import cn.bdqn.mybatis.dao.EmpMapper;

public class MyBatisTest_02 {
	public static void main(String[] args) throws IOException {
		//获取SqlSessionFactory实例
		String resource="mybatis-config.xml";
		InputStream is = Resources.getResourceAsStream(resource);
		 SqlSessionFactory build = new SqlSessionFactoryBuilder().build(is);
		 //获取到的sqlsession不会自动提交
		 SqlSession openSession = build.openSession();
		 try{
			 //测试添加
			 EmpMapper mapper = openSession.getMapper(EmpMapper.class);
		 /*	 Emp emp = new Emp(null,"liyuanfeng","[email protected]","1");
			 mapper.addEmp(emp);*/
			 //测试修改
			 Emp emp = new Emp(1,"liyuanfeng","[email protected]","1");
			 mapper.updateEmp(emp);

			 //进行手动提交
			 openSession.commit();
		 }finally{
			 openSession.close();
		 }

	}

}

  

时间: 2024-12-26 07:31:10

MyBatis编写映射文件实现增删改操作 附说明即源码的相关文章

MyBatis学习(二)、SQL语句映射文件(2)增删改查、参数、缓存

二.SQL语句映射文件(2)增删改查.参数.缓存 2.2 select 一个select 元素非常简单.例如: Xml代码   <!-- 查询学生,根据id --> <select id="getStudent" parameterType="String" resultMap="studentResultMap"> SELECT ST.STUDENT_ID, ST.STUDENT_NAME, ST.STUDENT_SEX

二、SQL语句映射文件(2)增删改查、参数、缓存

2.2 select 一个select 元素非常简单.例如: Xml代码   <!-- 查询学生,根据id --> <select id="getStudent" parameterType="String" resultMap="studentResultMap"> SELECT ST.STUDENT_ID, ST.STUDENT_NAME, ST.STUDENT_SEX, ST.STUDENT_BIRTHDAY, ST

使用异或运算对数据及文件进行加密处理,附软件及源码

前几天写了一篇文章是在C语言中使用异或运算交换两个任意类型变量,其基础为使用^交换两个整数的算法: a ^= b; b ^= a; a ^= b; 如果你看明白这个算法,就会发现这样的规律:一个数异或另一个数两次后,该数保持不变.即: c = a^b; c = c^b; c == a; 这一规律就是使用异或运算对数据及文件进行加密处理的基本原理. 那就先贴下加密算法的代码: bool XorEncrypt(void* bufPtr, unsigned int bufSize, const cha

Mybatis使用之简单的增删改查

Mybatis使用之简单的增删改查 一:简介 主要记录最简单的数据的增删改查.下一章会有各个操作详细一点的配置说明.以Author表为例(见上一博客).Author表没有关联任何其他表.也没有特殊字段. 二:映射规则 2.1.映射文件中的sql方法与对应的XxxMapper接口中的方法映射规则: a)映射文件的namespace的值是XxxMapper接口的全限定名.即包名+接口名称 b)映射文件中表示增删改查的标签(select.insert.delete.update)的id的值是接口中方法

Mybatis实现简单的数据库增删改查操作

Mybatis实现简单的数据库增删改查操作 框架:mybatis(3.5.2) 数据库:mysql 工具:idea 1.新建一个maven项目,在pom文件中添加mybatis依赖及MySQL依赖 <!-- mybatis核心依赖 --> <!-- https://mvnrepository.com/artifact/org.mybatis/mybatis --> <dependency> <groupId>org.mybatis</groupId&g

Mybatis简单的入门之增删改查

一般的步骤如下 1.添加Mybatis所需要的包,和连接数据库所需的包 2.配置mybatis-config.xml文件 3.配置与pojo对应的映射文件 mybatis-config,xml <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN" "http:/

mybatis中映射文件和实体类的关联性

mybatis的映射文件写法多种多样,不同的写法和用法,在实际开发过程中所消耗的开发时间.维护时间有很大差别,今天我就把我认为比较简单的一种映射文件写法记录下来,供大家修改建议,争取找到一个最优写法~~: 以User对象和UserMap.xml为例讲解,代码如下: User为用户实体类(仅作为讲解,可以只关注引用类型变量,get/set方法省略): import com.google.common.collect.Lists; import com.gukeer.common.persisten

SpringBoot + MyBatis 实现对员工的增删改查

SpringBoot + MyBatis 实现对员工的增删改查 一.使用idea新建SpringBoot项目 File-->New-->Project-->Spring Assistant-->Next-->修改报名,项目名等信息-->Next-->在web中选中web,在SQL中选中MySQL.JDBS.MyBatis-->Next-->Finish 二.修改pom.xml文件[之前的操作已经导入了springboot.mysql.jdbc.myba

【2017-05-02】winform弹出警告框是否进行增删改操作、记事本制作、对话框控件和输出输入流

一.winform弹出警告框是否进行增删改操作 第一个参数是弹出窗体显示的内容,第二个参数是标题,第三个参数是该弹窗包含确定和取消按钮. 返回的是一个枚举类接收一下. 再进行判断,如果点的是确定按钮,再进行下一步的增删改操作. 二.记事本的制作 1.菜单工具栏MenuStrip-插入标准项 2.TextBox -显示部分 小箭头 MultiLine 选中多行 Dock属性占满. 3.功能 - 撤销 - 剪切 - 粘贴 - 复制 - 删除 - 全选 - 时间 - 查找 单独做一个窗体点击打开 把主