mybatis3的一个介绍文章

2024-01-16 09:20
文章标签 介绍 文章 mybatis3

本文主要是介绍mybatis3的一个介绍文章,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

mybatis3的一个介绍文章

论坛首页    Java企业应用论坛   

Mybatis3.0查询,保存,更新,删除数据。

全部  Hibernate  Spring  Struts  iBATIS  企业应用  Lucene  SOA  Java综合  设计模式  Tomcat  OO  JBoss
浏览 337 次
主题:Mybatis3.0查询,保存,更新,删除数据。
精华帖 (0) :: 良好帖 (0) :: 新手帖 (1) :: 隐藏帖 (0)
作者正文
发表时间:前天   最后修改:前天
iBATIS
源代码http://eassen.iteye.com/blog/1399002

近来打算开发一个技术框架,并应用此框架开发出一个论坛,开始打算用sturts2+spring+hibernate+jquery为基础,然后再进行封装,最后形成技术框架,但通过此网站获知mybatis比hibernate更灵活,实用。因此开始逐步接触mybatis。

以下是mybatis3.0的开发实例,使用的java环境jdk5.0,ide为eclipse3.7,数据库是oracle11g。

1.数据环境配置

Xml代码  复制代码  收藏代码
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN" "mybatis-3-config.dtd">
  3. <configuration>
  4. <!-- - - - - - - 数据库环境配置- - - - - - - - - -->
  5. <environments default="environments">
  6. <environment id="eassen">
  7. <transactionManager type="JDBC"/>
  8. <dataSource type="POOLED">
  9. <property name="driver" value="oracle.jdbc.driver.OracleDriver"/>
  10. <property name="url" value="jdbc:oracle:thin:@127.0.0.1:1521:eassen"/>
  11. <property name="username" value="eassen"/>
  12. <property name="password" value="oracle"/>
  13. </dataSource>
  14. </environment>
  15. </environments>
  16. <!-- - - - - - - -映射文件路径- - - - - - -->
  17. <mappers>
  18. <mapper resource="com/pojo/sql/DmMydwtMapper.xml"/>
  19. </mappers>
  20. </configuration>
Xml代码   收藏代码
  1. <?xml version="1.0" encoding="UTF-8"?>  
  2. <!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN" "mybatis-3-config.dtd">  
  3.   
  4. <configuration>  
  5.     <!-- - - - - - - 数据库环境配置- - - - - - - - - -->  
  6.     <environments default="environments">  
  7.         <environment id="eassen">  
  8.             <transactionManager type="JDBC"/>  
  9.             <dataSource type="POOLED">  
  10.                 <property name="driver" value="oracle.jdbc.driver.OracleDriver"/>  
  11.                 <property name="url" value="jdbc:oracle:thin:@127.0.0.1:1521:eassen"/>  
  12.                 <property name="username" value="eassen"/>  
  13.                 <property name="password" value="oracle"/>  
  14.             </dataSource>  
  15.         </environment>  
  16.     </environments>  
  17.     <!-- - - - - - - -映射文件路径- - - - - - -->  
  18.     <mappers>  
  19.         <mapper resource="com/pojo/sql/DmMydwtMapper.xml"/>  
  20.     </mappers>  
  21. </configuration>  

2.数据库表映射(DM_MYDWT)XML文件

Xml代码  复制代码  收藏代码
  1. <?xml version="1.0" encoding="UTF-8" ?>
  2. <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
  3. "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
  4. <mapper namespace="com.dao.DmMydwtMapper">
  5. <resultMap id="BaseResultMap" type="com.pojo.DmMydwt">
  6. <id column="MYDWT_DM" property="mydwtDm" jdbcType="CHAR" javaType="String" />
  7. <result column="MYDWT_MC" property="mydwtMc" jdbcType="VARCHAR"
  8. javaType="String" />
  9. <result column="YXBZ" property="yxbz" jdbcType="CHAR" javaType="String" />
  10. <result column="XYBZ" property="xybz" jdbcType="CHAR" javaType="String" />
  11. </resultMap>
  12. <sql id="Base_Column_List">
  13. MYDWT_DM, MYDWT_MC, YXBZ, XYBZ
  14. </sql>
  15. <select id="selectByPrimaryKey" resultMap="BaseResultMap"
  16. parameterType="java.lang.String">
  17. select
  18. <include refid="Base_Column_List" />
  19. from EASSEN.DM_MYDWT
  20. where MYDWT_DM = #{mydwtDm,jdbcType=CHAR}
  21. </select>
  22. <delete id="deleteByPrimaryKey" parameterType="java.lang.String"
  23. flushCache="true">
  24. delete from EASSEN.DM_MYDWT
  25. where MYDWT_DM =
  26. #{mydwtDm,jdbcType=CHAR}
  27. </delete>
  28. <insert id="insert" parameterType="com.pojo.DmMydwt" flushCache="true">
  29. insert into EASSEN.DM_MYDWT (MYDWT_DM, MYDWT_MC, YXBZ,
  30. XYBZ)
  31. values
  32. (#{mydwtDm,jdbcType=CHAR}, #{mydwtMc,jdbcType=VARCHAR},
  33. #{yxbz,jdbcType=CHAR},
  34. #{xybz,jdbcType=CHAR})
  35. </insert>
  36. <insert id="insertSelective" parameterType="com.pojo.DmMydwt"
  37. flushCache="true">
  38. insert into EASSEN.DM_MYDWT
  39. <trim prefix="(" suffix=")" suffixOverrides=",">
  40. MYDWT_DM,
  41. MYDWT_MC,
  42. YXBZ,
  43. XYBZ,
  44. </trim>
  45. <trim prefix="values (" suffix=")" suffixOverrides=",">
  46. #{mydwtDm,jdbcType=CHAR},
  47. #{mydwtMc},
  48. #{yxbz,jdbcType=CHAR},
  49. #{xybz,jdbcType=CHAR},
  50. </trim>
  51. </insert>
  52. <update id="updateByPrimaryKeySelective" parameterType="com.pojo.DmMydwt"
  53. flushCache="true">
  54. update EASSEN.DM_MYDWT
  55. <set>
  56. <if test="mydwtMc != null">
  57. MYDWT_MC = #{mydwtMc,jdbcType=VARCHAR},
  58. </if>
  59. <if test="yxbz != null">
  60. YXBZ = #{yxbz,jdbcType=CHAR},
  61. </if>
  62. <if test="xybz != null">
  63. XYBZ = #{xybz,jdbcType=CHAR},
  64. </if>
  65. </set>
  66. where MYDWT_DM = #{mydwtDm,jdbcType=CHAR}
  67. </update>
  68. <update id="updateByPrimaryKey" parameterType="com.pojo.DmMydwt"
  69. flushCache="true">
  70. update EASSEN.DM_MYDWT
  71. set MYDWT_MC =
  72. #{mydwtMc,jdbcType=VARCHAR},
  73. YXBZ = #{yxbz,jdbcType=CHAR},
  74. XYBZ =
  75. #{xybz,jdbcType=CHAR}
  76. where MYDWT_DM = #{mydwtDm,jdbcType=CHAR}
  77. </update>
  78. </mapper>
Xml代码   收藏代码
  1. <?xml version="1.0" encoding="UTF-8" ?>  
  2. <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"   
  3. "http://mybatis.org/dtd/mybatis-3-mapper.dtd">  
  4. <mapper namespace="com.dao.DmMydwtMapper">  
  5.     <resultMap id="BaseResultMap" type="com.pojo.DmMydwt">  
  6.         <id column="MYDWT_DM" property="mydwtDm" jdbcType="CHAR" javaType="String" />  
  7.         <result column="MYDWT_MC" property="mydwtMc" jdbcType="VARCHAR"  
  8.             javaType="String" />  
  9.         <result column="YXBZ" property="yxbz" jdbcType="CHAR" javaType="String" />  
  10.         <result column="XYBZ" property="xybz" jdbcType="CHAR" javaType="String" />  
  11.     </resultMap>  
  12.     <sql id="Base_Column_List">  
  13.         MYDWT_DM, MYDWT_MC, YXBZ, XYBZ  
  14.     </sql>  
  15.     <select id="selectByPrimaryKey" resultMap="BaseResultMap"  
  16.         parameterType="java.lang.String">  
  17.         select  
  18.         <include refid="Base_Column_List" />  
  19.         from EASSEN.DM_MYDWT  
  20.         where MYDWT_DM = #{mydwtDm,jdbcType=CHAR}  
  21.     </select>  
  22.     <delete id="deleteByPrimaryKey" parameterType="java.lang.String"  
  23.         flushCache="true">  
  24.         delete from EASSEN.DM_MYDWT  
  25.         where MYDWT_DM =  
  26.         #{mydwtDm,jdbcType=CHAR}  
  27.     </delete>  
  28.     <insert id="insert" parameterType="com.pojo.DmMydwt" flushCache="true">  
  29.         insert into EASSEN.DM_MYDWT (MYDWT_DM, MYDWT_MC, YXBZ,  
  30.         XYBZ)  
  31.         values  
  32.         (#{mydwtDm,jdbcType=CHAR}, #{mydwtMc,jdbcType=VARCHAR},  
  33.         #{yxbz,jdbcType=CHAR},  
  34.         #{xybz,jdbcType=CHAR})  
  35.     </insert>  
  36.     <insert id="insertSelective" parameterType="com.pojo.DmMydwt"  
  37.         flushCache="true">  
  38.         insert into EASSEN.DM_MYDWT  
  39.         <trim prefix="(" suffix=")" suffixOverrides=",">  
  40.             MYDWT_DM,  
  41.             MYDWT_MC,  
  42.             YXBZ,  
  43.             XYBZ,  
  44.         </trim>  
  45.         <trim prefix="values (" suffix=")" suffixOverrides=",">  
  46.             #{mydwtDm,jdbcType=CHAR},  
  47.             #{mydwtMc},  
  48.             #{yxbz,jdbcType=CHAR},  
  49.             #{xybz,jdbcType=CHAR},  
  50.         </trim>  
  51.     </insert>  
  52.     <update id="updateByPrimaryKeySelective" parameterType="com.pojo.DmMydwt"  
  53.         flushCache="true">  
  54.         update EASSEN.DM_MYDWT  
  55.         <set>  
  56.             <if test="mydwtMc != null">  
  57.                 MYDWT_MC = #{mydwtMc,jdbcType=VARCHAR},  
  58.             </if>  
  59.             <if test="yxbz != null">  
  60.                 YXBZ = #{yxbz,jdbcType=CHAR},  
  61.             </if>  
  62.             <if test="xybz != null">  
  63.                 XYBZ = #{xybz,jdbcType=CHAR},  
  64.             </if>  
  65.         </set>  
  66.         where MYDWT_DM = #{mydwtDm,jdbcType=CHAR}  
  67.     </update>  
  68.     <update id="updateByPrimaryKey" parameterType="com.pojo.DmMydwt"  
  69.         flushCache="true">  
  70.         update EASSEN.DM_MYDWT  
  71.         set MYDWT_MC =  
  72.         #{mydwtMc,jdbcType=VARCHAR},  
  73.         YXBZ = #{yxbz,jdbcType=CHAR},  
  74.         XYBZ =  
  75.         #{xybz,jdbcType=CHAR}  
  76.         where MYDWT_DM = #{mydwtDm,jdbcType=CHAR}  
  77.     </update>  
  78. </mapper>  

3.数据库表(DM_MYDWT)java

Java代码  复制代码  收藏代码
  1. package com.pojo;
  2. import java.io.Serializable;
  3. public class DmMydwt implements Serializable {
  4. /**
  5. *
  6. */
  7. private static final long serialVersionUID = 1078518054837885063L;
  8. /**
  9. * EASSEN.DM_MYDWT.MYDWT_DM
  10. * @ibatorgenerated 2012-02-05 20:14:30
  11. */
  12. private String mydwtDm;
  13. /**
  14. * EASSEN.DM_MYDWT.MYDWT_MC
  15. * @ibatorgenerated 2012-02-05 20:14:30
  16. */
  17. private String mydwtMc;
  18. /**
  19. * EASSEN.DM_MYDWT.YXBZ
  20. * @ibatorgenerated 2012-02-05 20:14:30
  21. */
  22. private String yxbz;
  23. /**
  24. * EASSEN.DM_MYDWT.XYBZ
  25. * @ibatorgenerated 2012-02-05 20:14:30
  26. */
  27. private String xybz;
  28. public String getMydwtDm() {
  29. return mydwtDm;
  30. }
  31. public void setMydwtDm(String mydwtDm) {
  32. this.mydwtDm = mydwtDm;
  33. }
  34. public String getMydwtMc() {
  35. return mydwtMc;
  36. }
  37. public void setMydwtMc(String mydwtMc) {
  38. this.mydwtMc = mydwtMc;
  39. }
  40. public String getYxbz() {
  41. return yxbz;
  42. }
  43. public void setYxbz(String yxbz) {
  44. this.yxbz = yxbz;
  45. }
  46. public String getXybz() {
  47. return xybz;
  48. }
  49. public void setXybz(String xybz) {
  50. this.xybz = xybz;
  51. }
  52. }
Java代码   收藏代码
  1. package com.pojo;  
  2.   
  3. import java.io.Serializable;  
  4.   
  5. public class DmMydwt implements Serializable {  
  6.     /** 
  7.      *  
  8.      */  
  9.     private static final long serialVersionUID = 1078518054837885063L;  
  10.   
  11.     /** 
  12.      * EASSEN.DM_MYDWT.MYDWT_DM 
  13.      * @ibatorgenerated 2012-02-05 20:14:30 
  14.      */  
  15.     private String mydwtDm;  
  16.   
  17.     /** 
  18.      * EASSEN.DM_MYDWT.MYDWT_MC 
  19.      * @ibatorgenerated 2012-02-05 20:14:30 
  20.      */  
  21.     private String mydwtMc;  
  22.   
  23.     /** 
  24.      * EASSEN.DM_MYDWT.YXBZ 
  25.      * @ibatorgenerated 2012-02-05 20:14:30 
  26.      */  
  27.     private String yxbz;  
  28.   
  29.     /** 
  30.      * EASSEN.DM_MYDWT.XYBZ 
  31.      * @ibatorgenerated 2012-02-05 20:14:30 
  32.      */  
  33.     private String xybz;  
  34.   
  35.     public String getMydwtDm() {  
  36.         return mydwtDm;  
  37.     }  
  38.   
  39.     public void setMydwtDm(String mydwtDm) {  
  40.         this.mydwtDm = mydwtDm;  
  41.     }  
  42.   
  43.     public String getMydwtMc() {  
  44.         return mydwtMc;  
  45.     }  
  46.   
  47.     public void setMydwtMc(String mydwtMc) {  
  48.         this.mydwtMc = mydwtMc;  
  49.     }  
  50.   
  51.     public String getYxbz() {  
  52.         return yxbz;  
  53.     }  
  54.   
  55.     public void setYxbz(String yxbz) {  
  56.         this.yxbz = yxbz;  
  57.     }  
  58.   
  59.     public String getXybz() {  
  60.         return xybz;  
  61.     }  
  62.   
  63.     public void setXybz(String xybz) {  
  64.         this.xybz = xybz;  
  65.     }  
  66. }  

 

4.DAO

Java代码  复制代码  收藏代码
  1. package com.dao;
  2. import com.pojo.DmMydwt;
  3. public interface DmMydwtMapper {
  4. /**
  5. * 根据主键删除
  6. * 参数:主键
  7. * 返回:删除个数
  8. * @ibatorgenerated 2012-02-05 20:14:58
  9. */
  10. int deleteByPrimaryKey(String mydwtDm);
  11. /**
  12. * 插入,空属性也会插入
  13. * 参数:pojo对象
  14. * 返回:删除个数
  15. * @ibatorgenerated 2012-02-05 20:14:58
  16. */
  17. int insert(DmMydwt record);
  18. /**
  19. * 插入,空属性不会插入
  20. * 参数:pojo对象
  21. * 返回:删除个数
  22. * @ibatorgenerated 2012-02-05 20:14:58
  23. */
  24. int insertSelective(DmMydwt record);
  25. /**
  26. * 根据主键查询
  27. * 参数:查询条件,主键值
  28. * 返回:对象
  29. * @ibatorgenerated 2012-02-05 20:14:58
  30. */
  31. DmMydwt selectByPrimaryKey(String mydwtDm);
  32. /**
  33. * 根据主键修改,空值条件不会修改成null
  34. * 参数:1.要修改成的值
  35. * 返回:成功修改个数
  36. * @ibatorgenerated 2012-02-05 20:14:58
  37. */
  38. int updateByPrimaryKeySelective(DmMydwt record);
  39. /**
  40. * 根据主键修改,空值条件会修改成null
  41. * 参数:1.要修改成的值
  42. * 返回:成功修改个数
  43. * @ibatorgenerated 2012-02-05 20:14:58
  44. */
  45. int updateByPrimaryKey(DmMydwt record);
  46. }
Java代码   收藏代码
  1. package com.dao;  
  2.   
  3. import com.pojo.DmMydwt;  
  4.   
  5. public interface DmMydwtMapper {  
  6.     /** 
  7.      * 根据主键删除 
  8.      * 参数:主键 
  9.      * 返回:删除个数 
  10.      * @ibatorgenerated 2012-02-05 20:14:58 
  11.      */  
  12.     int deleteByPrimaryKey(String mydwtDm);  
  13.   
  14.     /** 
  15.      * 插入,空属性也会插入 
  16.      * 参数:pojo对象 
  17.      * 返回:删除个数 
  18.      * @ibatorgenerated 2012-02-05 20:14:58 
  19.      */  
  20.     int insert(DmMydwt record);  
  21.   
  22.     /** 
  23.      * 插入,空属性不会插入 
  24.      * 参数:pojo对象 
  25.      * 返回:删除个数 
  26.      * @ibatorgenerated 2012-02-05 20:14:58 
  27.      */  
  28.     int insertSelective(DmMydwt record);  
  29.   
  30.     /** 
  31.      * 根据主键查询 
  32.      * 参数:查询条件,主键值 
  33.      * 返回:对象 
  34.      * @ibatorgenerated 2012-02-05 20:14:58 
  35.      */  
  36.     DmMydwt selectByPrimaryKey(String mydwtDm);  
  37.   
  38.     /** 
  39.      * 根据主键修改,空值条件不会修改成null 
  40.      * 参数:1.要修改成的值 
  41.      * 返回:成功修改个数 
  42.      * @ibatorgenerated 2012-02-05 20:14:58 
  43.      */  
  44.     int updateByPrimaryKeySelective(DmMydwt record);  
  45.   
  46.     /** 
  47.      * 根据主键修改,空值条件会修改成null 
  48.      * 参数:1.要修改成的值 
  49.      * 返回:成功修改个数 
  50.      * @ibatorgenerated 2012-02-05 20:14:58 
  51.      */  
  52.     int updateByPrimaryKey(DmMydwt record);  
  53. }  

 

5.mybatis加载

Java代码  复制代码  收藏代码
  1. package com.db;
  2. import java.io.IOException;
  3. import java.io.Reader;
  4. import org.apache.ibatis.io.Resources;
  5. import org.apache.ibatis.session.SqlSession;
  6. import org.apache.ibatis.session.SqlSessionFactory;
  7. import org.apache.ibatis.session.SqlSessionFactoryBuilder;
  8. public class ConnectionFactory {
  9. private static SqlSessionFactory factory;
  10. private static SqlSession sqlSession = null;
  11. // 读取MyBatis配置文件,创建SqlSessionFactory
  12. static {
  13. try {
  14. Reader reader = Resources.getResourceAsReader("sqlMapConfig.xml");
  15. factory = new SqlSessionFactoryBuilder().build(reader, "eassen");
  16. catch (IOException e) {
  17. e.printStackTrace();
  18. }
  19. }
  20. /**
  21. * 获取SqlSession
  22. * @return
  23. */
  24. public static SqlSession getSession() {
  25. if(sqlSession == null){
  26. sqlSession = factory.openSession();
  27. }
  28. return sqlSession;
  29. }
  30. /**
  31. * 从配置文件中获取数据库表映射对象信息
  32. * @param mapper
  33. * @return
  34. */
  35. public static <T> T getMapper(Class<T> mapper) {
  36. SqlSession session = getSession();
  37. return (T) session.getMapper(mapper);
  38. }
  39. /**
  40. * 数据提交
  41. */
  42. public static void commit(){
  43. sqlSession.commit();
  44. }
  45. /**
  46. * 数据回滚
  47. */
  48. public static void rollback(){
  49. sqlSession.rollback();
  50. }
  51. /**
  52. * 关闭sqlsession
  53. */
  54. public static void close(){
  55. if(sqlSession != null){
  56. sqlSession.close();
  57. }
  58. }
  59. }
Java代码   收藏代码
  1. package com.db;  
  2.   
  3. import java.io.IOException;  
  4. import java.io.Reader;  
  5. import org.apache.ibatis.io.Resources;  
  6. import org.apache.ibatis.session.SqlSession;  
  7. import org.apache.ibatis.session.SqlSessionFactory;  
  8. import org.apache.ibatis.session.SqlSessionFactoryBuilder;  
  9.   
  10. public class ConnectionFactory {  
  11.     private static SqlSessionFactory factory;  
  12.     private static SqlSession sqlSession = null;  
  13.   
  14.       
  15.     // 读取MyBatis配置文件,创建SqlSessionFactory  
  16.     static {  
  17.         try {  
  18.             Reader reader = Resources.getResourceAsReader("sqlMapConfig.xml");  
  19.             factory = new SqlSessionFactoryBuilder().build(reader, "eassen");  
  20.         } catch (IOException e) {  
  21.             e.printStackTrace();  
  22.         }  
  23.     }  
  24.   
  25.     /** 
  26.      * 获取SqlSession 
  27.      * @return 
  28.      */  
  29.     public static SqlSession getSession() {  
  30.         if(sqlSession == null){  
  31.             sqlSession = factory.openSession();  
  32.         }  
  33.         return sqlSession;  
  34.     }  
  35.   
  36.     /** 
  37.      * 从配置文件中获取数据库表映射对象信息 
  38.      * @param mapper 
  39.      * @return 
  40.      */  
  41.     public static <T> T getMapper(Class<T> mapper) {  
  42.         SqlSession session = getSession();  
  43.         return (T) session.getMapper(mapper);  
  44.     }  
  45.       
  46.     /** 
  47.      * 数据提交 
  48.      */  
  49.     public static void commit(){  
  50.         sqlSession.commit();  
  51.     }  
  52.     /** 
  53.      * 数据回滚 
  54.      */  
  55.     public static void rollback(){  
  56.         sqlSession.rollback();  
  57.     }  
  58.     /** 
  59.      * 关闭sqlsession 
  60.      */  
  61.     public static void close(){  
  62.         if(sqlSession != null){  
  63.             sqlSession.close();  
  64.         }  
  65.     }  
  66.       
  67.       
  68. }  

6.数据查询,插入,更新,删除测试

Java代码  复制代码  收藏代码
  1. package com.test;
  2. import com.dao.DmMydwtMapper;
  3. import com.db.ConnectionFactory;
  4. import com.pojo.DmMydwt;
  5. public class MydTest {
  6. public static void main(String[] args) {
  7. try {
  8. // 获取对象
  9. DmMydwtMapper mydwtMapper = ConnectionFactory
  10. .getMapper(com.dao.DmMydwtMapper.class);
  11. // 查询相关MYDWT_DM为“1001”的信息
  12. DmMydwt mydwt = mydwtMapper.selectByPrimaryKey("1001");
  13. System.out.println("mybatis查询测试:=================================");
  14. System.out.println("MYDWT_DM:" + mydwt.getMydwtDm());
  15. System.out.println("MYDWT_MC:" + mydwt.getMydwtMc());
  16. // 插入数据
  17. System.out.println("mybatis保存测试:=================================");
  18. mydwt = new DmMydwt();
  19. mydwt.setMydwtDm("aaaa");
  20. mydwt.setMydwtMc("mybatis保存");
  21. mydwt.setYxbz("Y");
  22. mydwt.setXybz("Y");
  23. mydwtMapper.insert(mydwt);
  24. // 更新数据
  25. System.out.println("mybatis更新测试:=================================");
  26. mydwt.setMydwtMc(new String("mybatis保存".getBytes(),"UTF-8"));
  27. mydwtMapper.updateByPrimaryKey(mydwt);
  28. // 删除数据
  29. System.out.println("mybatis删除测试:=================================");
  30. mydwtMapper.deleteByPrimaryKey("1001");
  31. ConnectionFactory.commit();
  32. catch (Exception e) {
  33. ConnectionFactory.rollback();
  34. e.printStackTrace();
  35. finally {
  36. // 关闭sqlsession
  37. ConnectionFactory.close();
  38. }
  39. }
  40. }
Java代码   收藏代码
  1. package com.test;  
  2.   
  3. import com.dao.DmMydwtMapper;  
  4. import com.db.ConnectionFactory;  
  5. import com.pojo.DmMydwt;  
  6.   
  7. public class MydTest {  
  8.   
  9.     public static void main(String[] args) {  
  10.         try {  
  11.             // 获取对象  
  12.             DmMydwtMapper mydwtMapper = ConnectionFactory  
  13.                     .getMapper(com.dao.DmMydwtMapper.class);  
  14.   
  15.             // 查询相关MYDWT_DM为“1001”的信息  
  16.             DmMydwt mydwt = mydwtMapper.selectByPrimaryKey("1001");  
  17.             System.out.println("mybatis查询测试:=================================");  
  18.             System.out.println("MYDWT_DM:" + mydwt.getMydwtDm());  
  19.             System.out.println("MYDWT_MC:" + mydwt.getMydwtMc());  
  20.               
  21.             // 插入数据  
  22.             System.out.println("mybatis保存测试:=================================");  
  23.             mydwt = new DmMydwt();  
  24.             mydwt.setMydwtDm("aaaa");  
  25.             mydwt.setMydwtMc("mybatis保存");  
  26.             mydwt.setYxbz("Y");  
  27.             mydwt.setXybz("Y");  
  28.             mydwtMapper.insert(mydwt);  
  29.             // 更新数据  
  30.             System.out.println("mybatis更新测试:=================================");  
  31.             mydwt.setMydwtMc(new String("mybatis保存".getBytes(),"UTF-8"));  
  32.             mydwtMapper.updateByPrimaryKey(mydwt);  
  33.               
  34.             // 删除数据  
  35.             System.out.println("mybatis删除测试:=================================");  
  36.             mydwtMapper.deleteByPrimaryKey("1001");  
  37.             ConnectionFactory.commit();  
  38.         } catch (Exception e) {  
  39.             ConnectionFactory.rollback();  
  40.             e.printStackTrace();  
  41.         } finally {  
  42.             // 关闭sqlsession  
  43.             ConnectionFactory.close();  
  44.         }  
  45.     }  
  46. }  

7.控制台信息输出

Java代码  复制代码  收藏代码
  1. 2012-02-08 11:43:01 Logging initialized using 'org.apache.ibatis.logging.commons.JakartaCommonsLoggingImpl' adapter.
  2. 2012-02-08 11:43:01 PooledDataSource forcefully closed/removed all connections.
  3. 2012-02-08 11:43:01 PooledDataSource forcefully closed/removed all connections.
  4. 2012-02-08 11:43:01 PooledDataSource forcefully closed/removed all connections.
  5. 2012-02-08 11:43:01 PooledDataSource forcefully closed/removed all connections.
  6. 2012-02-08 11:43:02 Created connection 17671659.
  7. 2012-02-08 11:43:02 ooo Connection Opened
  8. 2012-02-08 11:43:02 ==> Executing: select MYDWT_DM, MYDWT_MC, YXBZ, XYBZ from EASSEN.DM_MYDWT where MYDWT_DM = ?
  9. 2012-02-08 11:43:02 ==> Parameters: 1001(String)
  10. 2012-02-08 11:43:02 <== Columns: MYDWT_DM, MYDWT_MC, YXBZ, XYBZ
  11. 2012-02-08 11:43:02 <== Row: 1001, 您经常访问的网站包括:, Y, Y
  12. mybatis查询测试:=================================
  13. MYDWT_DM:1001
  14. MYDWT_MC:您经常访问的网站包括:
  15. mybatis保存测试:=================================
  16. 2012-02-08 11:43:02 ==> Executing: insert into EASSEN.DM_MYDWT (MYDWT_DM, MYDWT_MC, YXBZ, XYBZ) values (?, ?, ?, ?)
  17. 2012-02-08 11:43:02 ==> Parameters: aaaa(String), mybatis保存(String), Y(String), Y(String)
  18. mybatis更新测试:=================================
  19. 2012-02-08 11:43:02 ==> Executing: update EASSEN.DM_MYDWT set MYDWT_MC = ?, YXBZ = ?, XYBZ = ? where MYDWT_DM = ?
  20. 2012-02-08 11:43:02 ==> Parameters: mybatis保存(String), Y(String), Y(String), aaaa(String)
  21. mybatis删除测试:=================================
  22. 2012-02-08 11:43:02 ==> Executing: delete from EASSEN.DM_MYDWT where MYDWT_DM = ?
  23. 2012-02-08 11:43:02 ==> Parameters: 1001(String)
  24. 2012-02-08 11:43:02 xxx Connection Closed
  25. 2012-02-08 11:43:02 Returned connection 17671659 to pool.
 
发表时间:8 小时前  

关于Mybatis3的更新操作,常见有以下两种:

 

第一种:

 

Xml代码   收藏代码
  1. <update id="updateBySelected" parameterType="users">  
  2.     update users  
  3.     <set>  
  4.         <if test="name!=null">user_name = #{name}</if>  
  5.         <if test="addr!=null">user_addr = #{addr}</if>  
  6.     </set>  
  7.     where user_id=#{id}  
  8. </update>  

 

第二种:

 

Xml代码   收藏代码
  1. <update id="update" parameterType="users">  
  2.     update users set user_name = #{name}, user_addr = #{addr}  
  3.     where user_id=#{id}  
  4. </update>  

 

个人认为有时候还是有需要将字段值设置为null的,比如清空日期字段。因此,针对只更新某一两个字段值的情况,我一般是这样操作的:

 

Java代码   收藏代码
  1. // 只更新用户姓名(前台页面只传入id、name)  
  2. User user = userService.findById(id);//根据用户ID获取缓存的用户对象  
  3. user.setName(name);//更新用户姓名  
  4. userService.update(user);//同时更新User表所有字段值  

 

不知道楼主是如何操作的(只更新某些字段)?

 

 

 

回帖地址
0  0 请登录后投票
 

论坛首页    Java企业应用版 

跳转论坛:移动开发技术 Web前端技术 Java企业应用 编程语言技术 综合技术 入门技术 招聘求职 海阔天空
posted on 2012-02-10 23:44  lexus 阅读( ...) 评论( ...) 编辑 收藏

转载于:https://www.cnblogs.com/lexus/archive/2012/02/10/2346218.html

这篇关于mybatis3的一个介绍文章的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/612072

相关文章

性能测试介绍

性能测试是一种测试方法,旨在评估系统、应用程序或组件在现实场景中的性能表现和可靠性。它通常用于衡量系统在不同负载条件下的响应时间、吞吐量、资源利用率、稳定性和可扩展性等关键指标。 为什么要进行性能测试 通过性能测试,可以确定系统是否能够满足预期的性能要求,找出性能瓶颈和潜在的问题,并进行优化和调整。 发现性能瓶颈:性能测试可以帮助发现系统的性能瓶颈,即系统在高负载或高并发情况下可能出现的问题

水位雨量在线监测系统概述及应用介绍

在当今社会,随着科技的飞速发展,各种智能监测系统已成为保障公共安全、促进资源管理和环境保护的重要工具。其中,水位雨量在线监测系统作为自然灾害预警、水资源管理及水利工程运行的关键技术,其重要性不言而喻。 一、水位雨量在线监测系统的基本原理 水位雨量在线监测系统主要由数据采集单元、数据传输网络、数据处理中心及用户终端四大部分构成,形成了一个完整的闭环系统。 数据采集单元:这是系统的“眼睛”,

Hadoop数据压缩使用介绍

一、压缩原则 (1)运算密集型的Job,少用压缩 (2)IO密集型的Job,多用压缩 二、压缩算法比较 三、压缩位置选择 四、压缩参数配置 1)为了支持多种压缩/解压缩算法,Hadoop引入了编码/解码器 2)要在Hadoop中启用压缩,可以配置如下参数

图神经网络模型介绍(1)

我们将图神经网络分为基于谱域的模型和基于空域的模型,并按照发展顺序详解每个类别中的重要模型。 1.1基于谱域的图神经网络         谱域上的图卷积在图学习迈向深度学习的发展历程中起到了关键的作用。本节主要介绍三个具有代表性的谱域图神经网络:谱图卷积网络、切比雪夫网络和图卷积网络。 (1)谱图卷积网络 卷积定理:函数卷积的傅里叶变换是函数傅里叶变换的乘积,即F{f*g}

C++——stack、queue的实现及deque的介绍

目录 1.stack与queue的实现 1.1stack的实现  1.2 queue的实现 2.重温vector、list、stack、queue的介绍 2.1 STL标准库中stack和queue的底层结构  3.deque的简单介绍 3.1为什么选择deque作为stack和queue的底层默认容器  3.2 STL中对stack与queue的模拟实现 ①stack模拟实现

Mysql BLOB类型介绍

BLOB类型的字段用于存储二进制数据 在MySQL中,BLOB类型,包括:TinyBlob、Blob、MediumBlob、LongBlob,这几个类型之间的唯一区别是在存储的大小不同。 TinyBlob 最大 255 Blob 最大 65K MediumBlob 最大 16M LongBlob 最大 4G

FreeRTOS-基本介绍和移植STM32

FreeRTOS-基本介绍和STM32移植 一、裸机开发和操作系统开发介绍二、任务调度和任务状态介绍2.1 任务调度2.1.1 抢占式调度2.1.2 时间片调度 2.2 任务状态 三、FreeRTOS源码和移植STM323.1 FreeRTOS源码3.2 FreeRTOS移植STM323.2.1 代码移植3.2.2 时钟中断配置 一、裸机开发和操作系统开发介绍 裸机:前后台系

nginx介绍及常用功能

什么是nginx nginx跟Apache一样,是一个web服务器(网站服务器),通过HTTP协议提供各种网络服务。 Apache:重量级的,不支持高并发的服务器。在Apache上运行数以万计的并发访问,会导致服务器消耗大量内存。操作系统对其进行进程或线程间的切换也消耗了大量的CPU资源,导致HTTP请求的平均响应速度降低。这些都决定了Apache不可能成为高性能WEB服务器  nginx:

多路转接之select(fd_set介绍,参数详细介绍),实现非阻塞式网络通信

目录 多路转接之select 引入 介绍 fd_set 函数原型 nfds readfds / writefds / exceptfds readfds  总结  fd_set操作接口  timeout timevalue 结构体 传入值 返回值 代码 注意点 -- 调用函数 select的参数填充  获取新连接 注意点 -- 通信时的调用函数 添加新fd到

火语言RPA流程组件介绍--浏览网页

🚩【组件功能】:浏览器打开指定网址或本地html文件 配置预览 配置说明 网址URL 支持T或# 默认FLOW输入项 输入需要打开的网址URL 超时时间 支持T或# 打开网页超时时间 执行后后等待时间(ms) 支持T或# 当前组件执行完成后继续等待的时间 UserAgent 支持T或# User Agent中文名为用户代理,简称 UA,它是一个特殊字符串头,使得服务器