前面已经讲到用接口的方式编程。这种方式,要注意的一个地方就是。在User.xml  的配置文件中,mapper namespace="com.yihaomen.mybatis.inter.IUserOperation" ,命名空间非常重要,不能有错,必须与我们定义的package
和 接口一致。如果不一致就会出错,这一章主要在上一讲基于接口编程的基础上完成如下事情:

1. 用 mybatis 查询数据,包括列表

2. 用 mybatis 增加数据

3. 用 mybatis 更新数据.

4. 用 mybatis 删除数据.



查询数据,前面已经讲过简单的,主要看查询出列表的

查询出列表,也就是返回list, 在我们这个例子中也就是 List<User> , 这种方式返回数据,需要在User.xml 里面配置返回的类型 resultMap, 注意不是 resultType, 而这个resultMap 所对应的应该是我们自己配置的

 程序代码


< !-- 为了返回list 类型而定义的returnMap -->

    <resultMap type="User" id="resultListUser">

        <id column="id" property="id" />

        <result column="userName" property="userName" />

        <result column="userAge" property="userAge" />

        <result column="userAddress" property="userAddress" />

    </resultMap>

查询列表的语句在 User.xml 中

 程序代码


< !-- 返回list 的select 语句,注意 resultMap 的值是指向前面定义好的 -->

    <select id="selectUsers" parameterType="string" resultMap="resultListUser">

        select * from user where userName like #{userName}

    </select>

在 IUserOperation 接口中增加方法:public List<User> selectUsers(String userName);    

现在在 Test 类中做测试

 程序代码


public void getUserList(String userName){

        SqlSession session = sqlSessionFactory.openSession();

        try {

            IUserOperation userOperation=session.getMapper(IUserOperation.class);          

            List<User> users = userOperation.selectUsers(userName);

            for(User user:users){

                System.out.println(user.getId()+":"+user.getUserName()+":"+user.getUserAddress());

            }

            

        } finally {

            session.close();

        }

    }

现在在main  方法中可以测试:

 程序代码


public static void main(String[] args) {

        Test testUser=new Test();

        testUser.getUserList("%");

    }

可以看到,结果成功查询出来。如果是查询单个数据的话,用第二讲用过的方法就可以了。



用mybatis 增加数据 

在 IUserOperation 接口中增加方法:public void addUser(User user);

在 User.xml 中配置

 程序代码


< !--执行增加操作的SQL语句。id和parameterType  

       分别与IUserOperation接口中的addUser方法的名字和  

       参数类型一致。以#{name}的形式引用Student参数  

       的name属性,MyBatis将使用反射读取Student参数  

       的此属性。#{name}中name大小写敏感。引用其他  

       的gender等属性与此一致。seGeneratedKeys设置  

       为"true"表明要MyBatis获取由数据库自动生成的主  

       键;keyProperty="id"指定把获取到的主键值注入  

       到Student的id属性--> 

    <insert id="addUser" parameterType="User" 

        useGeneratedKeys="true" keyProperty="id"> 

        insert into user(userName,userAge,userAddress)  

             values(#{userName},#{userAge},#{userAddress})  

    </insert>

然后在 Test 中写测试方法:

 程序代码


/**

     * 测试增加,增加后,必须提交事务,否则不会写入到数据库.

     */

    public void addUser(){

        User user=new User();

        user.setUserAddress("人民广场");

        user.setUserName("飞鸟");

        user.setUserAge(80);

        SqlSession session = sqlSessionFactory.openSession();

        try {

            IUserOperation userOperation=session.getMapper(IUserOperation.class);

            userOperation.addUser(user);

            session.commit();

            System.out.println("当前增加的用户 id为:"+user.getId());

        } finally {

            session.close();

        }

    }

用mybatis 更新数据

方法类似,先在 IUserOperation 中增加方法:public void addUser(User user);

然后配置 User.xml

 程序代码


<update id="updateUser" parameterType="User" >

        update user set userName=#{userName},userAge=#{userAge},userAddress=#{userAddress} where id=#{id}

    </update>

Test 类总的测试方法如下:

 程序代码


public void updateUser(){

        //先得到用户,然后修改,提交。

        SqlSession session = sqlSessionFactory.openSession();

        try {

            IUserOperation userOperation=session.getMapper(IUserOperation.class);

            User user = userOperation.selectUserByID(4);            

            user.setUserAddress("原来是魔都的浦东创新园区");

            userOperation.updateUser(user);

            session.commit();

            

        } finally {

            session.close();

        }

    }

用mybatis 删除数据 

同理,IUserOperation 增加方法:public void deleteUser(int id);

配置User.xml

 程序代码


<delete id="deleteUser" parameterType="int">

        delete from user where id=#{id}

    </delete>

然后在Test类中写测试方法:

 程序代码




    /**

     * 删除数据,删除一定要 commit.

     * @param id

     */

    public void deleteUser(int id){

        SqlSession session = sqlSessionFactory.openSession();

        try {

            IUserOperation userOperation=session.getMapper(IUserOperation.class);          

            userOperation.deleteUser(id);

            session.commit();            

        } finally {

            session.close();

        }

    }

这样,所有增删改查都完成了,注意在增加,更改,删除的时候要调用session.commit(),这样才会真正对数据库进行操作,否则是没有提交的。



到此为止,简单的单表操作,应该都会了,接下来的时间了,我会讲多表联合查询,以及结果集的选取。

Mybatis学习(3)实现数据的增删改查的更多相关文章

  1. mysql学习笔记一 —— 数据的增删改查

    1.连接mysql mysql 直接回车(是以root身份,密码空,登陆的是本机localhost) [root@www mysql]# mysql -uroot -p123 -S /var/lib/ ...

  2. Mybatis学习笔记之---CRUD(增删改查)

    Mybatis的CRUD(增删改查) 1.pom.xml <dependencies> <dependency> <groupId>junit</groupI ...

  3. Mybatis 接口方式对数据的增删改查 一对一关联查询

    数据库中有两个表 student 和studentInfo student表中的字段和数据 studentInfo表中的字段 ok数据库说完了,开始建立一个项目,对数据库中的数据进行操作吧 新建jav ...

  4. Mybatis学习总结(二)—使用接口实现数据的增删改查

    在这一篇中,让我们使用接口来实现一个用户数据的增删改查. 完成后的项目结构如下图所示: 在这里,person代表了一个用户的实体类.在该类中,描述了相关的信息,包括id.name.age.id_num ...

  5. Mybatis框架基于注解的方式,实对数据现增删改查

    编写Mybatis代码,与spring不一样,不需要导入插件,只需导入架包即可: 在lib下 导入mybatis架包:mybatis-3.1.1.jarmysql驱动架包:mysql-connecto ...

  6. Mybatis实现数据的增删改查

    Mybatis实现数据的增删改查 1.项目结构(使用maven创建项目) 2.App.java package com.GetcharZp.MyBatisStudy; import java.io.I ...

  7. django学习-12.访问不同url/接口地址实现对指定数据的增删改查功能

    1.前言 通过前面博客[django学习-10.django连接mysql数据库和创建数据表]里的操作,我们已经成功在数据库[hongjingsheng_project]里创建了一张数据表[hello ...

  8. MyBatis学习(三)MyBatis基于动态代理方式的增删改查

    1.前言 上一期讲到MyBatis-Statement版本的增删改查.可以发现.这种代码写下来冗余的地方特别多.写一套没啥.如果涉及到多表多查询的时候就容易出现问题.故.官方推荐了一种方法.即MyBa ...

  9. Mysql学习笔记(六)增删改查

    PS:数据库最基本的操作就是增删改查了... 学习内容: 数据库的增删改查 1.增...其实就是向数据库中插入数据.. 插入语句 insert into table_name values(" ...

  10. vue实现对数据的增删改查(CURD)

    vue实现对数据的增删改查(CURD) 导语: 网上看到一个写的比较好的学习文章,转载分享一下 在管理员的一些后台页面里,个人中心里的数据列表里,都会有对这些数据进行增删改查的操作.比如在管理员后台的 ...

随机推荐

  1. 90%的人都不知道的Node.js 依赖关系管理(上)

    转载请注明出处:葡萄城官网,葡萄城为开发者提供专业的开发工具.解决方案和服务,赋能开发者. 原文参考:https://dzone.com/articles/nodejs-dependency-mana ...

  2. spark_shuffle方式的演进过程

    spark shuffle有四种方式,分别是 hashshuffle 优化后的hashshuffle sortshuffle bypass 一.hashshuffle与优化 一开始spark的shuf ...

  3. Lua在Windows下的安装、配置、运行

    Lua在Windows下的安装.配置.运行 本文链接:https://blog.csdn.net/ChinarCSDN/article/details/78667262 展开 # Windows下安装 ...

  4. Docker学习(12) Dockerfile构建过程

    Dockerfile的构建过程 以上为构建缓存

  5. 安装spark 报错:java.io.IOException: Could not locate executable E:\hadoop-2.7.7\bin\winutils.exe

    打开 cmd 输入 spark-shell 虽然可以正常出现 spark 的标志符,但是报错:java.io.IOException: Could not locate executable E:\h ...

  6. mybatis的多参数传递,使用

    1.mybatis的多参数使用 mapper 使用 通过@param注解,传递到xml中的参数名称指定 public interface RedisInstanceTypesMapper extend ...

  7. 优雅关闭springboot应用

    1.添加钩子函数,钩子函数中指定要调用的方法 @PostConstruct public void run() { this.zkClient.start(this); this.schedulerS ...

  8. LLVM编译器架构

    LLVM编译器架构 LLVM概述 LLVM项目是模块化和可重用的编译器及工具链技术的集合.尽管名称如此,LLVM与传统虚拟机关系不大.名称" LLVM"本身不是缩写.它是项目的全名 ...

  9. NVIDIA Nsight Systems CUDA 跟踪

    NVIDIA Nsight Systems CUDA 跟踪 CUDA跟踪 NVIDIA Nsight Systems能够捕获有关在概要过程中执行CUDA的信息. 可以在报告的时间轴上收集和呈现以下信息 ...

  10. Single Shot Multibox Detection (SSD)实战(上)

    Single Shot Multibox Detection (SSD)实战(上) 介绍了边界框.锚框.多尺度对象检测和数据集.现在,我们将利用这些背景知识构建一个目标检测模型:单次多盒检测(SSD) ...