MyBatis学习系列二之增删改查

数据库的经典操作:增删改查。

在这一章我们主要说明一下简单的查询和增删改,并且对程序接口做了一些调整,以及对一些问题进行了解答。

1、调整后的结构图:

2、连接数据库文件配置分离:

  一般的程序都会把连接数据库的配置单独放在.properties 文件中,然后在XML文件中引用,示例如下:

  config.properties:

driver=oracle.jdbc.OracleDriver
url=jdbc:oracle:thin:@127.0.0.1:1521:orcl
username=phonesurvey
password=world

  mybatis-config.xml:

<?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>
    <properties resource="config.properties" />
    <environments default="development">
        <environment id="development">
            <transactionManager type="JDBC" />
            <dataSource type="POOLED">
                <property name="driver" value="${driver}"/>
                <property name="url" value="${url}"/>
                <property name="username" value="${username}"/>
                <property name="password" value="${password}"/>
            </dataSource>
        </environment>
    </environments>
    <mappers>
        <mapper resource="nankang/dao/agentDao.xml" />
    </mappers>
</configuration>

3、SqlSession分离:

  SqlSeesion单独做成工具类,以便调用,示例如下:

SqlSessionHelper:

package nankang.util;

import java.io.InputStream;

import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;

public class SqlSessionHelper {

    public static SqlSessionFactory getSessionFactory(){
        SqlSessionFactory sessionFactory = null;
        String resource= "mybatis-config.xml";
        try{
            InputStream inputStream = Resources.getResourceAsStream(resource);
            //Reader reader = Resources.getResourceAsReader(resource);
            sessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
        }catch(Exception ex){
            ex.printStackTrace();
        }
        return sessionFactory;
    }
}

  SqlSessionFactory创建时,根据Reader和InputStream都可以。

4、XML文件添加内容:

   agentDao.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.dtd">
<mapper namespace="nankang.dao.AgentDao">
    <!-- 根据Id查询 -->
    <select id="selectAgentById" parameterType="string" resultType="nankang.po.Agent">
        select * from Agent where AgentId=#{id}
    </select>
    <!-- 添加 -->
    <insert id="insertAgent" parameterType="nankang.po.Agent">
        insert into Agent(agentId, companyCode, LoginName, AgentPwd, AgentCode, Name, status,sysFlag)
        values(#{agentId},‘SHNK‘,#{loginName},‘D41D8CD98F00B204E9800998ECF8427E‘,#{agentCode},#{name},1,1)
    </insert>
    <!-- 删除 -->
    <delete id="deleteAgent" parameterType="string">
        delete from Agent where agentid=#{id}
    </delete>
    <!-- 修改 -->
    <update id="updateAgent" parameterType="nankang.po.Agent">
        update agent set name=#{name} where agentid=#{agentId}
    </update>
    <!-- 查询所有 -->
    <select id="selectAllAgent" resultType="nankang.po.Agent">
        select * from Agent
    </select>
    <!-- 查询所有无返回对象 -->
    <select id="selectAllAgent2" resultType="hashmap">
        select * from Agent
    </select>

</mapper>

AgentDao.java:

package nankang.dao;

import java.util.List;
import java.util.Map;

import nankang.po.Agent;

import org.apache.ibatis.annotations.Select;

public interface AgentDao {
    //根据Id查询
    public Agent selectAgentById(String Id);
    //根据名称查询
    @Select("select * from Agent where name=#{name}")
    public Agent selectAgentByName(String name);
    //添加
    public int insertAgent(Agent agent);
    //删除
    public int deleteAgent(String id);
    //修改
    public int updateAgent(Agent agent);
    //查询所有的
    public List<Agent> selectAllAgent();
    public List<Map<String, Object>> selectAllAgent2();

}

  1、XML文件中的语句,可以直接写在接口文件中,如:根据名称查询;

  2、其他参考示例。

  几个问题说明:

  1)如何查询数据集合?

    使用ResultType设置,返回用List<T>即可

  2)查询一条数据,如果为空,怎么判断?

    如果没有查询到数据,返回为NULL,进行空对象判断即可

  3)查询所有的集合,不放在构建对象的List中:

    resultType=map,返回类型 List<Map<String,Object>>,字段为空则不展示在Map中

  4)如何实现事务:

    SqlSession:commit,rollback,close

  

5、测试

package nankang.test;

import java.util.List;
import java.util.Map;

import nankang.dao.AgentDao;
import nankang.util.SqlSessionHelper;

import org.apache.ibatis.session.SqlSession;

public class test {

    /**
     * @param args
     */
    public static void main(String[] args) {

        SqlSession sqlSession = SqlSessionHelper.getSessionFactory().openSession();
        try{

            AgentDao agentMapper = sqlSession.getMapper(AgentDao.class);

            //根据Id查询
//            Agent agent = agentMapper.selectAgentById("SHNKAG00000000051");
//            if(null != agent){
//                System.out.println(agent.getName());
//            }else{
//                System.out.println("不存在该用户");
//            }
//            agent = agentMapper.selectAgentByName("1001");
//            System.out.println(agent.getAgentId());
            //查询所有
            List<Map<String, Object>> agentList = agentMapper.selectAllAgent2();
            System.out.println(agentList.size());
            //添加
//            Format format = new SimpleDateFormat("00yyyyMMddhhmmss");
//            Calendar calendar = Calendar.getInstance();
//            String dateStr = format.format(calendar.getTime());
//            Agent agent = new Agent();
//            agent.setAgentId(dateStr);
//            agent.setLoginName("1111");
//            agent.setAgentCode("aaaa");
//            agent.setName("aaaa");
//            int num = agentMapper.insertAgent(agent);
//            System.out.println(num);
            //删除
//            int num = agentMapper.deleteAgent("0020150226093127");
//            System.out.println(num);
            //更新
//            Agent agent = new Agent();
//            agent.setAgentId("0020150226010005");
//            agent.setName("Test");
//            int num = agentMapper.updateAgent(agent);
//            System.out.println(num);

            //增删改,提交
            sqlSession.commit();
            System.out.println("完成");
        }catch(Exception ex){
            sqlSession.rollback();
            System.out.println(ex.getMessage());
        }finally{
            sqlSession.close();
        }

    }

}

  这边需要注意的是:SqlSession一定要close

6、源码下载:http://pan.baidu.com/s/1pJmeYpX (Fish的分享>MyBatis>myBatis2.rar)

时间: 2024-11-06 15:24:45

MyBatis学习系列二之增删改查的相关文章

ES学习(二)--增删改查

一. 查看健康状况 GET _cat/health?v 二. 查看索引 GET _cat/indices?v 三. 插入索引 PUT /ecommerce 四. 在索引下插入文档 PUT /ecommerce/_doc/1 { "name":"gaolujie yagao", "desc":"youxiao fangzhu", "price":25, "producer":"g

Mybatis使用之简单的增删改查

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

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

Android中使用Sqlite数据库 (二) 增删改查

定义接口 package com.example.android_db.service; import java.util.List; import java.util.Map; public interface PersonService { public boolean addPerson(Object[] params); public boolean deletePerson(Object[] params); public boolean updatePerson(Object[] p

Android学习---SQLite数据库的增删改查和事务(transaction)调用

上一篇文章中介绍了手工拼写sql语句进行数据库的CRUD操作,本文将介绍调用sqlite内置的方法实现CRUD操作,其实质也是通过拼写sql语句. 首先,创建一个新的android项目: 其次,查看代码实现增删查改: 1.创建DB工具类 MyDBHelper.java(创建数据库的操作) package com.amos.android_db; import android.content.Context; import android.database.sqlite.SQLiteDatabas

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:/

python学习之-员信息增删改查

python学习之-成员信息增删改查 主要实现了成员信息的增加,修改,查询,和删除功能,写着玩玩,在写的过程中,遇到的问题,旧新成员信息数据的合并,手机号和邮箱的验证, #!/usr/bin/env python# coding=utf8#author:[email protected] import os, sys, time,jsonimport re member_dict = \ {}member_name_list = []member_list = []def handler_mem

MVC学习-用EF做增删改查

在DbContext中有两个很重要的方法: 一.几个方法的说明 1.一个是Entry()方法: public DbEntityEntry<TEntity> Entry<TEntity>(TEntity entity) where TEntity : class; 可以将 任何类型的数据放入到上下文对象中 DbEntityEntry有个 属性EntityState,它可以为上下文中的对象做标识,并依照标识的值做相应的sql操作 public enum EntityState { De

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