MyBatis 04

上一节讲到了获得sqlsession,那么这一节我么讲利用sqlsession来完成一些数据的操作(增删改查)。

<?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="com.demo.entity.emp">
    <!-- 全部查找 -->
    <select id="findAll" resultType="com.demo.entity.emp">
        select *from emp
    </select>
    <!-- 模糊查找 -->
    <select id="findLikeName"
        parameterType="int"
        resultType="com.demo.entity.emp">
        select*from emp where name like #{name}
    </select>
    <!-- 精确查找 -->
    <select id="findById"
        parameterType="int"
        resultType="com.demo.entity.emp">
        select*from emp where id = #{id}
    </select>
    <!-- 插入操作 -->
    <insert id="save" 
    parameterType="com.demo.entity.emp">
        insert into emp(name,salary,age) 
        values(#{name},#{salary},#{age})
    </insert>

    <!-- 删除操作 -->
    <delete id="delete" parameterType="int">
        delete form emp where id=#{eid}
    </delete>

    <!-- 更新操作 -->
    <update id="update" parameterType="com.demo.entity.emp">
        update emp set salary=#{salary}
        where id=#{id}
    </update>  
</mapper>

以上是对sql语句的定义。 

parameterType=”int” 这个属性是对参数类型的定义,MyBatis提供了一套简单的定义,有:int,string,double等,都是小写开头。如果不用MyBatis提供的定义,那么参数定义里必须填写参数的具体类型(包名.类名,例如:java.lang.String)。

这里的参数表示和我们的jdbc有些区别,不是用?表示位置参数,而是用#{XXX}替代。 

当参数只有一个时候,#{xxx}里面的占位符可以随意填写。但是像插入操作有三个参数,就要填写实体类中的域名。

<!-- 插入操作 -->
    <insert id="save" 
    parameterType="com.demo.entity.emp">
        insert into emp(name,salary,age) 
        values(#{name},#{salary},#{age})
    </insert>

以上是empMapper中的sql语句定义。 

 

接下来我们来看看测试语句:

package Test;
import java.util.List;

import org.apache.ibatis.session.SqlSession;

import com.demo.Utils.MybatisUtil;
import com.demo.entity.emp;
public class TestEmp {
    public static void main(String[] args){
        SqlSession session = MybatisUtil.getSqlSession();
        //查询所有
//      List<emp> list=
//              session.selectList("findAll");
//      for(emp e:list){
//          System.out.println(e.getAge());
//      }
        //session.close();

        //条件查询
//      emp e=session.selectOne("findById",1);
//      System.out.println(e.getName());
//      session.close();

        // 插入操作
//      emp e=new emp();
//      e.setName("wch");
//      e.setSalary(5000000.0);
//      e.setAge(22);
//      session.insert("save",e);
//      session.commit();
//      //若想修改或者添加数据,需要提交即:session.commit。
//      //我们以前使用的jdbc是自动提交,这里的框架将自动提交关闭了。
//      session.close();

        //删除操作
//      session.delete("delete",1);
//      session.commit();
        //更新操作
        emp e=new emp();
        e.setId(1);
        e.setSalary(100000.0);
        session.update("update", e);
        session.commit();
        session.close();
    }

}

以上就是利用MyBatis对数据库的具体简单操作。

 

 

 

版权声明:本文为博主原创文章,如需转载请表明出处。 https://blog.csdn.net/qq_39266910/article/details/77920761

 

1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看rEADME.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看rEADME.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值