zoukankan      html  css  js  c++  java
  • Ibatis+MySql实例

    1. 介绍

           Ibatis是开源的持久层框架。它的核心是SqlMap,将实体Bean跟关系数据库进行映射,将业务代码和SQL语句的书写进行分开,方便管理。Ibatis是“半自动”的ORM持久层框架。这 里的“半自动化”,是相对Hibernate等提供了全面的数据库封装机制的“全自动化”ORM 实现而言,“全自动”ORM 实现了 POJO 和数据库表之间的映射,以及 SQL 的自动生成和执行。而iBATIS 的着力点,则在于POJO 与 SQL之间的映射关系。也就是说,iBATIS并不会为程序员在运行期自动生成 SQL 执行。具体的 SQL 需要程序员编写,然后通过映射配置文件,将SQL所需的参数,以及返回的结果字段映射到指定 POJO。

    2. 前提

        1) 安装了MySql数据库;

        2) 将以下Jar包加入工程的classpath:commons-logging-1.0.4.jar、ibatis-2.3.0.677.jar、mysql-connector-java-5.0.3-bin.jar。

    3. 实例

     3.1 在MySql数据库中创建数据库

    CREATE DATABASE MYDB;  
    use MYDB;  
      
    Drop TABLE IF EXISTS `MYDB`.`student`;  
    Create TABLE `MYDB`.`student` (  
    `name` varchar(40) NOT NULL,  
    `psw` varchar(10) NOT NULL,  
    `enabled` boolean  
    );  
    insert into student values("lanp","lanpiao",true);  
    insert into student values("ph","ph",true);  
    insert into student values("wxh","wxh",true);  

     3.2 书写实体Bean:Student.java

     1     package com.lanp.beans;  
     2       
     3     /** 
     4      * Student Bean 
     5      * @author LanP 
     6      * @since 2011-11-27 15:36 
     7      * @version V1.0 
     8      */  
     9     public class Student {  
    10         private String name;  
    11         private String psw;  
    12         private Boolean enabled;  
    13           
    14         public String getName() {  
    15             return name;  
    16         }  
    17         public void setName(String name) {  
    18             this.name = name;  
    19         }  
    20         public String getPsw() {  
    21             return psw;  
    22         }  
    23         public void setPsw(String psw) {  
    24             this.psw = psw;  
    25         }  
    26         public Boolean getEnabled() {  
    27             return enabled;  
    28         }  
    29         public void setEnabled(Boolean enabled) {  
    30             this.enabled = enabled;  
    31         }  
    32     }  

     3.3 配置数据库的属性文件:mysql.properties

        mysql.driver = com.mysql.jdbc.Driver  
        mysql.url = jdbc:mysql://localhost:3306/MYDB  
        mysql.username = root  
        mysql.password = 157891  
    

    3.4 SqlMap配置文件:sqlMapConfig.xml

     1     <?xml version="1.0" encoding="UTF-8"?>  
     2     <!DOCTYPE sqlMapConfig        
     3         PUBLIC "-//ibatis.apache.org//DTD SQL Map Config 2.0//EN"        
     4         "http://ibatis.apache.org/dtd/sql-map-config-2.dtd">  
     5     <sqlMapConfig>  
     6         <!-- Properties属性配置文件,加载数据库连接信息 -->  
     7         <properties resource="mysql.properties"/>  
     8        
     9       <settings   
    10         cacheModelsEnabled="true"      
    11         enhancementEnabled="true"      
    12         lazyLoadingEnabled="true"      
    13         errorTracingEnabled="true"      
    14         maxRequests="32"          
    15         maxSessions="10"          
    16         maxTransactions="5"          
    17         useStatementNamespaces="false"   
    18         />   
    19         <!-- 配置Ibatis事务管理,使用JDBC事务类型,数据源使用Simple类型 -->  
    20         <transactionManager type="JDBC">  
    21             <dataSource type="SIMPLE">  
    22                 <property name="JDBC.Driver" value="${mysql.driver}"/>  
    23                 <property name="JDBC.ConnectionURL" value="${mysql.url}"/>  
    24                 <property name="JDBC.Username" value="${mysql.username}"/>  
    25                 <property name="JDBC.Password" value="${mysql.password}"/>  
    26             </dataSource>  
    27         </transactionManager>   
    28         <!-- 配置Ibatis要使用的SqlMap文件信息 -->  
    29         <sqlMap resource="com/lanp/beans/student.xml"/>  
    30     </sqlMapConfig>  

     3.5 student实体Bean的映射配置:student.xml

     1     <?xml version="1.0" encoding="UTF-8"?>  
     2     <!DOCTYPE sqlMap        
     3         PUBLIC "-//ibatis.apache.org//DTD SQL Map 2.0//EN"        
     4         "http://ibatis.apache.org/dtd/sql-map-2.dtd">  
     5     <sqlMap>  
     6         <!-- 为Person类设置一个别名 -->  
     7         <typeAlias alias="student" type="com.lanp.beans.Student"/>  
     8           
     9         <!-- 配置表和实体Bean之间的映射关系 -->  
    10         <resultMap id="studentMap" class="com.lanp.beans.Student">  
    11             <result property="name" column="name"/>  
    12             <result property="psw" column="psw"/>  
    13             <result property="enabled" column="enabled"/>  
    14         </resultMap>  
    15           
    16         <insert id="insertStudent" parameterClass="student">  
    17             <![CDATA[ 
    18                 insert into student values(#name#,#psw#,#enabled#); 
    19             ]]>  
    20         </insert>  
    21           
    22         <!-- 查看特定用户 -->  
    23         <select id="queryStudentById" parameterClass="string" resultMap="studentMap">  
    24             <![CDATA[ 
    25                 SELECT * FROM STUDENT WHERE NAME=#name# 
    26             ]]>  
    27         </select>  
    28           
    29         <!-- 查看所有的用户 -->  
    30         <select id="queryAllStudents" resultMap="studentMap">  
    31             <![CDATA[ 
    32                 SELECT * FROM STUDENT 
    33             ]]>  
    34         </select>  
    35     </sqlMap>  

     3.6 测试类:TestStudent.java

     1     package com.lanp.beans;  
     2       
     3     import java.io.Reader;  
     4     import java.util.List;  
     5       
     6     import com.ibatis.common.resources.Resources;  
     7     import com.ibatis.sqlmap.client.SqlMapClient;  
     8     import com.ibatis.sqlmap.client.SqlMapClientBuilder;  
     9       
    10     /** 
    11      * 测试Ibatis 
    12      * @author LanP 
    13      * @since 2011-11-27 15:36 
    14      * @version V1.0 
    15      */  
    16     public class TestStudent {  
    17       
    18         public static void main(String[] args) {  
    19       
    20             String resource = "sqlMapConfig.xml";  
    21             try {  
    22                 //读取配置文件  
    23                 Reader reader = Resources.getResourceAsReader(resource);  
    24                 //得到SqlMapClient  
    25                 SqlMapClient sqlMap = SqlMapClientBuilder.buildSqlMapClient(reader);  
    26                   
    27                 //新增学生信息  
    28                 insertStudent(sqlMap);  
    29                   
    30                 //查看全部的学生  
    31                 queryAllStudents(sqlMap);  
    32                   
    33                 //查看特定的学生  
    34                 queryStudentByName(sqlMap);  
    35             } catch(Exception e){}  
    36         }  
    37           
    38         /** 
    39          * 根据学生的名字查询特定的学生信息 
    40          * @param sqlMap 
    41          */  
    42         private static void queryStudentByName(SqlMapClient sqlMap) {  
    43             try {  
    44                 System.out.println("--------------查询特定的学生信息-------------------------");  
    45                 Student stu = (Student)sqlMap.queryForObject("queryStudentById", "lanp");  
    46                 if(null != stu) {  
    47                     System.out.println("== 学生名字: " + stu.getName() + " ,学生密码: " + stu.getPsw() + " ==");  
    48                 }  
    49             } catch(Exception e){}  
    50         }  
    51       
    52         /** 
    53          * 显示所有学生的信息 
    54          * @param sqlMap 
    55          */  
    56         @SuppressWarnings("unchecked")  
    57         private static void queryAllStudents(SqlMapClient sqlMap) {  
    58             try {  
    59                 System.out.println("--------------查询所有的学生信息-------------------------");  
    60                 List<Student> students = sqlMap.queryForList("queryAllStudents");  
    61                 if(null != students && students.size()>0) {  
    62                     for(int i=0; i<students.size(); i++) {  
    63                         Student student = students.get(i);  
    64                         System.out.println("== 学生名字: " + student.getName() + " ,学生密码: " + student.getPsw() +" ==");  
    65                     }  
    66                 }  
    67             } catch(Exception e){}  
    68         }  
    69       
    70       
    71       
    72         /** 
    73          * 新增学生信息 
    74          * @param sqlMap 
    75          */  
    76         private static void insertStudent(SqlMapClient sqlMap) {  
    77             try {  
    78                 System.out.println("--------------新增学生信息-------------------------");  
    79                 Student student = new Student();  
    80                 student.setName("xinh");  
    81                 student.setPsw("123");  
    82                 student.setEnabled(true);  
    83                 //开始Ibatis事务  
    84                 sqlMap.startTransaction();  
    85                 sqlMap.insert("insertStudent", student);  
    86                 //结束IBatis事务  
    87                 sqlMap.commitTransaction();  
    88             } catch(Exception e){}  
    89         }  
    90           
    91     }  

    原文地址 http://blog.csdn.net/lanpiao_87/article/details/7017404

  • 相关阅读:
    移动端小tips
    是否该放弃东莞的工作
    读书有感-learn html5 and javascript for ios
    eNSP多路由实现互联互通(华为路由E口直连)
    iTextSharp操作表格排版问题
    我今天开通博客
    12年的女程序员重新回归
    前端css样式规划
    前端神器-webstorm2017
    远程桌面资料共享
  • 原文地址:https://www.cnblogs.com/wuxinyu/p/4316407.html
Copyright © 2011-2022 走看看