mybatis(二)

这次接着上次写增删改查吧。

现将上节的方法改造一下,改造测试类。

package cn.my.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 org.junit.Before;
import org.junit.Test;

import cn.my.mybatis.entity.User;

public class TestUser {
    private SqlSessionFactory factory;
    @Before
    public void setUp() throws IOException{
        String resource = "SqlMapConfig.xml";
        InputStream inputStream = Resources.getResourceAsStream(resource);
        factory = new SqlSessionFactoryBuilder().build(inputStream);
    }

    @Test
    public void testFindById(){
        SqlSession session = factory.openSession();
        User user = session.selectOne("cn.my.mybatis.entity.User.findById", 1);
        session.close();
        System.out.println(user);
    }
}

简单的改造一下是为了后面写增删改查是每次都需要写setup方法中的代码。

下面我就不贴图了,我直接写代码了

1.新增

1.1首先添加新增的映射文件

<?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="cn.my.mybatis.entity.User">
    <select id="findById" parameterType="int" resultType="cn.my.mybatis.entity.User">
        select * from user where id=#{id}
    </select>
    <!-- 新增映射 -->
    <insert id="insertUser" parameterType="cn.my.mybatis.entity.User">
        INSERT INTO `user` (`username`,`birthday`,`sex`,`address`)
        VALUES(‘id‘,‘username‘,‘birthday‘,‘sex‘,‘address‘)
    </insert>
</mapper>

1.2 .添加新增测试方法

package cn.my.test;

import java.io.IOException;
import java.io.InputStream;
import java.util.Date;

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 org.junit.Before;
import org.junit.Test;

import cn.my.mybatis.entity.User;

public class TestUser {
    private SqlSessionFactory factory;
    @Before
    public void setUp() throws IOException{
        String resource = "SqlMapConfig.xml";
        InputStream inputStream = Resources.getResourceAsStream(resource);
        factory = new SqlSessionFactoryBuilder().build(inputStream);
    }

    @Test
    public void testFindById(){
        SqlSession session = factory.openSession();
        User user = session.selectOne("cn.my.mybatis.entity.User.findById", 1);
        session.close();
        System.out.println(user);
    }
    /**
     * 新增用户
     */
    @Test
    public void testInserUser(){
        SqlSession session = factory.openSession();
        User user = new User();
        user.setAddress("许昌");
        user.setUsername("曹操");
        user.setSex("男");
        user.setBirthday(new Date());
        session.insert("cn.my.mybatis.entity.User.insertUser", user);
        session.commit();//这行记住一定不要忘,要不然提交不了
        session.close();
        System.out.println(user);
    }
}

运行结果:

这样添加就写完了。如果需要添加完毕之后返回新增的id值。

user.xml代码

<!-- 新增映射 -->
<insert id="insertUser" parameterType="cn.my.mybatis.entity.User">
    <selectKey keyProperty="id" order="AFTER" resultType="java.lang.Integer">
        SELECT LAST_INSERT_ID()
    </selectKey>
        INSERT INTO `user` (`username`,`birthday`,`sex`,`address`)
        VALUES(#{username},#{birthday},#{sex},#{address})
</insert>

测试类代码

/**
     * 新增用户
     */
    @Test
    public void testInserUser(){
        SqlSession session = factory.openSession();
        User user = new User();
        user.setAddress("许昌");
        user.setUsername("曹操1");
        user.setSex("男");
        user.setBirthday(new Date());
        session.insert("cn.my.mybatis.entity.User.insertUser", user);
        session.commit();
        session.close();
        System.out.println(user.getId());
    }  

看结果:

2.修改

1.1 user.xml添加代码

<!-- 修改用户 -->
    <update id="updateUser" parameterType="cn.my.mybatis.entity.User">
        UPDATE `user`
        SET
          `username` = #{username},
          `birthday` = #{birthday},
          `sex` = #{sex},
          `address` = #{address}
        WHERE `id` = #{id} ;
    </update>

2.1测试类代码

/**
     * 修改
     */
    @Test
    public void testUpdateUser(){
        SqlSession session = factory.openSession();
        User user = new User();
        user.setId(29);
        user.setAddress("许昌1");
        user.setUsername("曹操2");
        user.setSex("女");
        user.setBirthday(new Date());
        session.update("cn.my.mybatis.entity.User.updateUser", user);
        session.commit();
        session.close();
    }  

运行结果:

3.删除

user.xml

<delete id="deleteUser" parameterType="java.lang.Integer">
    delete from user where id=#{id}
</delete>

测试类代码

/**
     * 删除
     */
    @Test
    public void testDeleteUser(){
        SqlSession session = factory.openSession();
        session.delete("cn.my.mybatis.entity.User.deleteUser", 29);
        session.commit();
        session.close();
    } 

运行结构:删除id为29的。

好了以上就是一个最简单的例子。有时间我会继续往下写的,如果需要加群一起研究的可以q我,939705214,也可以添加群号581591235

时间: 2024-10-11 03:20:05

mybatis(二)的相关文章

Mybatis(二) 全局配置文件详解

这节来说说全局配置文件的东西,非常简单.看一遍就懂了. --WH 一.全部配置内容 SqlMapConfig.xml的配置内容和顺序如下,顺序不能乱.现在来对这些属性的意思一一进行讲解. 二.properties 作用:引用java属性文件中的配置信息,比如,加载连接数据库的各种属性的配置文件. db.properties 1 <!-- 2 properties:引用java属性文件中的配置信息 3 比如加载连接数据库的帐号密码等信息的properties配置文件. 4 使用${}可以引用已经加

mybatis(二)执行CRUD操作的两种方式配置和注解

一.使用MyBatis对表执行CRUD操作——基于XML的实现 1.定义sql映射xml文件 userMapper.xml文件的内容如下: <?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper

框架学习笔记之Mybatis(二)

一.动态sql 通过mybatis提供的标签,实现sql语句的拼接. 1.where <select id="findUserList" parameterType="user" resultType="user"> select * from user <!--使用where可以自动处理第一个and--> <where> <if test="id!=null and id!=''"&

mybatis二(参数处理)

1.单个参数 mybatis不会做特殊处理. #{参数名/任意名}:取出参数值. 2.多个参数 mybatis会做特殊处理. 多个参数会被封装成 一个map. key:param1...paramN,或者参数的索引也可以. value:传入的参数值. #{}就是从map中获取指定的key的值: 多个参数传递的时候要使用命名参数的形式: 3.命名参数:明确指定封装参数时map的key:@Param("id") 多个参数会被封装成 一个map, key:使用@Param注解指定的值 val

mybatis(二):config配置

一.properties引入外部配置文件:resource:引入类路径下的资源. <properties resource="dbconfig.properties"></properties> 二.settings包含很多重要的设置项,可以设置是否开启缓存,延迟加载,驼峰命名规则等:name:设置项名:value:false或true. <settings> <setting name="mapUnderscoreToCamelCa

MyBatis(二) resultMap使用

1.问题引出: 在做映射时候,之前,按照表DDL的字段名,设置java对象的属性.但是,在实际应用无法完全保证表字段名与java类属性完全一致,而且java类应该保持驼峰格式的规范风格.对于类似字段user_id等的情况,不能较好的处理.这时,需要使用resultMap标签来将,DDL的字段名和java类属性名一一对应起来. 下面实现一个使用resultMap做映射的实例,来阐述其使用方法: 2.resultMap使用,resultMap和resultType的不同使用场景: 在表的Mapper

Spring整合MyBatis(二)源码分析

在Spring配置Mybatis的文件中我们可以看到如下代码: <!-- 扫描dao --> <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer"> <property name="basePackage" value="org.tarena.note.dao"> </property> MapperScannerConfig

Mybatis二

1 Mybatis的映射文件 1.1 #和$的区别? 1.1.1 #和$的相同点 都是可以从map中获取值或者pojo对象的值 1.1.2 #和$的不同点 #{}以预编译的形式,将参数设置到sql语句中. ${}取出的值直接拼接在sql语句中,但是可能会有SQL注入问题. 示例: EmployeeMapper.java package com.xuweiwei.mybatis.mapper; import com.xuweiwei.mybatis.pojo.Employee; import or

Mybatis(二)总结

1. 输入映射(就是映射文件中可以传入哪些参数类型) 1)基本类型 2)pojo类型 3)Vo类型2. 输出映射(返回的结果集可以有哪些类型) 1)基本类型 2)pojo类型 3)List类型3. 动态sql:动态的拼接sql语句,因为sql中where条件有可能多也有可能少 1)where:可以自动添加where关键字,还可以去掉第一个条件的and关键字 2)if:判断传入的参数是否为空 3)foreach:循环遍历传入的集合参数 4)sql:封装查询条件,以达到重用的目的 4. 对单个对象的