SSM框架整合

今天突然接觸到mybatis這 又一支持SQL語句查詢,存儲過程和高級映射的優秀持久層框架。無疑不讓我有點小激動啊,其實在學習Hibernate框架之後,並且運用了一段時間之 後,不知道是腦袋不想去探索新的知識,還是已經有了一定的Hibernate的模式。當然,如果沒有想學習這個的衝動,也不會有這篇博客了,下面就讓我們 一起來學習MyBatis吧!

 

  需要注意的是,我例子中使用的軟件環境是 MyEclipse10.6Oracle 11g數據庫

 

 首先,一定是架包了,對吧,直接上圖吧

 

      

 

這就是mybatis多需要的架包,當然按照這個標題來說的話,那是和spring與struts2的整合了,那就必須要把其他相關的架包也加上去了,由於架包太多,然後這個主要是在學習mybatis,所以你懂的。

 

1. 來看看 web.xml 文件的變化

 

Java代碼
  1.     <filter>    
  2.         <filter-name>struts2</filter-name>    
  3.         <filter-class>  
  4.         org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter  
  5.         </filter-class>    
  6.     </filter>     
  7.     <filter-mapping>    
  8.         <filter-name>struts2</filter-name>    
  9.         <url-pattern>/*</url-pattern>    
  10.     </filter-mapping>    
  11.     
  12.     <context-param>    
  13.         <param-name>contextConfigLocation</param-name>    
  14.         <param-value>classpath:applicationContext.xml</param-value>    
  15.     </context-param>    
  16.     <listener>    
  17.         <listener-class>  
  18.             org.springframework.web.context.ContextLoaderListener  
  19.         </listener-class>    
  20.     </listener>    
  21.         <welcome-file-list>    
  22.             <welcome-file>index.jsp</welcome-file>    
  23.         </welcome-file-list>    
  24. </web-app>  
 

其實沒有加上什麼東西,是吧!

2. 創建實體類,在src目錄下創建,例:com.entity.Users.class

 

 

Java代碼
  1. public class Users {    
  2.         private Integer id;    
  3.         private String name;    
  4.         private String password;    
  5.         private String address;    
  6.         public Users() {    
  7.             super();    
  8.         }    
  9.         public Users(Integer id, String name, String password, String address) {    
  10.             super();    
  11.             this.id = id;    
  12.             this.name = name;    
  13.             this.password = password;    
  14.             this.address = address;    
  15.         }    
  16.         public Integer getId() {    
  17.             return id;    
  18.         }    
  19.         public void setId(Integer id) {    
  20.             this.id = id;    
  21.         }    
  22.         public String getName() {    
  23.             return name;    
  24.         }    
  25.         public void setName(String name) {    
  26.             this.name = name;    
  27.         }    
  28.         public String getPassword() {    
  29.             return password;    
  30.         }    
  31.         public void setPassword(String password) {    
  32.             this.password = password;    
  33.         }    
  34.         public String getAddress() {    
  35.             return address;    
  36.         }    
  37.         public void setAddress(String address) {    
  38.             this.address = address;    
  39.         }    
  40.     }   
 

 

3.創建接口dao,在src目錄下創建,例:com.dao.UsersDao

 

Java代碼
  1. import com.entity.Users;    
  2.     
  3. public interface UsersDao {    
  4.         
  5.     Users selectUser(Users users);    
  6.         
  7.     Users insertUser(Users users);    
  8.         
  9.     Users updateUser(Users users);    
  10.         
  11.     Users deleteUser(Integer userId);    
  12. }  
 


4.創建接口dao的實現,這裏是.xml文件,一般和接口dao放在一起,例:com.dao.UserMapper.xml

Java代碼
  1. <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"     
  2. "http://mybatis.org/dtd/mybatis-3-mapper.dtd">    
  3. <mapper namespace="com.dao.UsersDao">    
  4.     
  5.     <select id="selectUser" parameterType="com.entity.Users" resultType="com.entity.Users">    
  6.         SELECT * FROM Users WHERE name=#{name} AND password=#{password}    
  7.     </select>    
  8.         
  9.     <insert id="insertUser" parameterType="com.entity.Users" flushCache="true" >    
  10.         INSERT INTO Users (id,name,password,address) VALUES   
  11.         (seq_users.nextval,#{name},#{password},#{address})    
  12.     </insert>    
  13.         
  14.     <update id="updateUser" parameterType="com.entity.Users">    
  15.         UPDATE Users SET password=#{password} WHERE id=#{id}    
  16.     </update>    
  17.         
  18.     <delete id="deleteUser" parameterType="java.lang.Integer">    
  19.         DELETE FROM Users WHERE id=#{userId}    
  20.     </delete>    
  21.         
  22. </mapper>  
 

這裏做一點解釋,相信大家也有一點不理解,我也在這裏弄了好久,可能是太笨了,呵呵

 

1)namespace="com.dao.UsersDao"    //這裏通常放置接口,就是需要實現的接口

 

2)所有的id名都必須與 com.dao.UsersDao定義的方法名一致

 

   parameterType -- 將會傳遞的參數類的完全限定名或別名

 

3)還有一個參數

 

  flushCache="true" -- 一般設置爲true,其意義是無論什麼語句被調用,都會清空其緩存,默認值爲 false

 

4)在添加操作中,由於我使用的是oracle的序列號,所以這裏,就不能指定Id,需要指定數據庫中該表的序列號,才能進行添加

 


 

好的,我們繼續..

 

5.在src的根目錄下創建一個名叫 mybatis-config.xml的文件,主要用來我們剛纔寫的接口的實現文件

Java代碼
  1. <?xml version="1.0" encoding="UTF-8" ?>    
  2. <!DOCTYPE configuration PUBLIC    
  3.     "-//mybatis.org//DTD Config 3.0//EN"    
  4.     "http://mybatis.org/dtd/mybatis-3-config.dtd">    
  5.     <configuration>    
  6.         <mappers>    
  7.             <mapper resource="com/dao/UserMapper.xml"/>    
  8.         </mappers>    
  9.     </configuration>  
 

這裏沒什麼好解釋的..

6.到了最重要的時刻了,有沒有一點小激動啊,,,好吧,一點都不激動..一起來看吧

 

現在來創建spring的配置文件 applicationContext.xml,不用說,一定是放在src根目錄下的

 

 

Java代碼
  1. <?xml version="1.0" encoding="UTF-8"?>    
  2.     
  3. <beans xmlns="http://www.springframework.org/schema/beans"    
  4.     xmlns:tx="http://www.springframework.org/schema/tx"    
  5.     xmlns:p="http://www.springframework.org/schema/p"    
  6.     xmlns:aop="http://www.springframework.org/schema/aop"     
  7.     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"    
  8.     xsi:schemaLocation="    
  9.             http://www.springframework.org/schema/beans     
  10.             http://www.springframework.org/schema/beans/spring-beans-3.0.xsd     
  11.             http://www.springframework.org/schema/tx     
  12.             http://www.springframework.org/schema/tx/spring-tx-3.0.xsd     
  13.             http://www.springframework.org/schema/aop      
  14.             http://www.springframework.org/schema/aop/spring-aop-3.0.xsd">   
  15.       <!-- 這裏沒有使用外聯的文件,而是直接將值放到多需要的屬性值中 -->    
  16.     <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">    
  17.         <property name="driverClassName" value="oracle.jdbc.driver.OracleDriver"></property>       
  18.         <property name="url" value="jdbc:oracle:thin:@localhost:1521:orcl"></property>     
  19.         <property name="username" value="scott"></property>    
  20.         <property name="password" value="tiger"></property>    
  21.     </bean>  
  22.         
  23.     <!-- 這裏配置的是 sqlSessionFactory, -->  
  24.     <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">    
  25.         <property name="dataSource" ref="dataSource" />    
  26.         <property name="configLocation" value="classpath:mybatis-config.xml"></property>    
  27.     </bean>    
  28.         
  29.     <bean id="userMapper" class="org.mybatis.spring.mapper.MapperFactoryBean">    
  30.         <property name="mapperInterface" value="com.dao.UsersDao"></property>    
  31.         <property name="sqlSessionFactory" ref="sqlSessionFactory"></property>    
  32.     </bean>  
  33.         
  34.     <!-- 由於spring沒有配置與mybatis的支持,所以這裏就用到了名爲 mybatis-spring-1.1.1.jar -->  
 


好了,講到這裏,所有的配置全部已經結束,下面就來測試一下吧

7.創建測試類,demo.class 文件:

 

 

Java代碼
  1. package com.test;    
  2.     
  3. import org.springframework.context.ApplicationContext;    
  4. import org.springframework.context.support.ClassPathXmlApplicationContext;    
  5.     
  6. import com.dao.UsersDao;    
  7. import com.entity.Users;    
  8.     
  9. public class demo {    
  10.     public static void main(String[] args) {    
  11.         ApplicationContext ctx=null;    
  12.         ctx=new ClassPathXmlApplicationContext("applicationContext.xml");    
  13.         //這裏是在 applicationContext.xml文件中定義的名稱,從而可以獲取到對應的接口對象</span>    
  14.         UsersDao userMapper=(UsersDao)ctx.getBean("userMapper");    
  15.         Users u=new Users();    
  16.         u.setName("lisi");    
  17.         u.setPassword("123");    
  18.         System.out.println(userMapper.selectUser(u));    
  19.             
  20.         //添加(去掉下面的註釋進行調試)    
  21.         /*   
  22.         Users user=new Users();   
  23.         user.setName("Azzzzz");   
  24.         user.setPassword("123");   
  25.         user.setAddress("zzzz");   
  26.         userMapper.insertUser(user);   
  27.         //更新(去掉下面的註釋進行調試)   
  28.         /*   
  29.         u.setId(1);   
  30.         u.setPassword("updatePassword");   
  31.         userMapper.updateUser(u);   
  32.         */    
  33.         //刪除(去掉下面的註釋進行調試)    
  34.         /*   
  35.         userMapper.deleteUser(9);   
  36.         */      
  37.     }    
 


好啦,到這裏,簡單的struts+Spring+Mybatis框架就這樣了,其實在上面還沒有用到struts部分,但是我們前面已經配置的相關的 web.xml文件,不過話說回來,其實也是一樣的,我們的測試類中如果能順利執行某一個操作,那聯合struts2的話,相信也不在話下!

好吧,本人實在只學習到這麼多,不敢說可以幫大家能解決什麼問題,只希望在學習的過程中,能或多或少的啓到一點點作用,我就心滿意足了!

最後祝大家工作順利!加油!!!

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章