Maven+Spring+Spring MVC+Mybatis項目實戰

jopen 10年前發布 | 167K 次閱讀 JEE框架 MyBatis

1.建立mysql數據庫和表
建立一個學生選課管理數據庫。
表:學生表、班級表、教師表、課程表、學生選課表。
邏輯關系:每個學生有一個班級;每個班級對應一個班主任教師;每個教師只能當一個班的班主任;
使用下面的sql進行建數據庫,先建立學生表,插入數據(2條以上)。

use student_manager;
create TABLE student_tbl(
   STUDENT_ID         VARCHAR(255) PRIMARY KEY,  
   STUDENT_NAME       VARCHAR(100) NOT NULL,  
   STUDENT_SEX        VARCHAR(10),  
   STUDENT_BIRTHDAY   DATE,  
   CLASS_ID           VARCHAR(255)  
);


INSERT INTO STUDENT_TBL (STUDENT_ID,  
                         STUDENT_NAME,  
                         STUDENT_SEX,  
                         STUDENT_BIRTHDAY,  
                         CLASS_ID)  
  VALUES   (123456,  
            '某某某',  
            '女',  
            '1980-08-01',  
            121546  
            ) 
select from student_tbl;
desc student_tbl;


insert into student_tbl values('111','Tom','男',DATE('2013-09-08'),'101');
insert into student_tbl values('222','小紅','女',DATE('2014-02-08'),'101');
insert into student_tbl values('333','小明','男',DATE('2014-02-08'),'102');
insert into student_tbl values('444','小陽','女',DATE('2014-02-08'),'103');




創建連接MySql使用的配置文件mysql.properties。




jdbc.driverClassName=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/student_manager?user=root&password=limingnihao&useUnicode=true&characterEncoding=UTF-8




Maven + Spring + Spring MVC + Mybatis 開發環境:


1.搭建Maven開發環境:
   1.下載maven,安裝后配置 高級-->系統變量  MAVEN_HOME:E:\Jay.He\apache-maven-3.0.5
   2. path目錄中添加:.;%MAVEN_HOME%/bin;
   3. 驗證Maven安裝成功 :mvn -v或version
   
   
2.添加Spring和SpringMVC支持  -- web.xml


   <!--Spring 的配置 -->
   <context-param>
        <param-name>contextConfigLocation</param-name>
        <param-value>classpath
:applicationContext.xml</param-value>
    </context-param>
    
  <!-- 配置Spring的啟動監聽器 -->
    <listener>
        <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
    </listener>
    
    <!-- Spring的log4j監聽器 -->  
    <listener>  
        <listener-class>org.springframework.web.util.Log4jConfigListener</listener-class>  
    </listener>  
  
    <!-- 字符集 過濾器  -->  
    <filter>  
        <filter-name>CharacterEncodingFilter</filter-name>  
        <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>  
        <init-param>  
            <param-name>encoding</param-name>  
            <param-value>UTF-8</param-value>  
        </init-param>  
        <init-param>  
            <param-name>forceEncoding</param-name>  
            <param-value>true</param-value>  
        </init-param>  
    </filter>  
    <filter-mapping>  
        <filter-name>CharacterEncodingFilter</filter-name>  
        <url-pattern>/</url-pattern>  
    </filter-mapping>  
  
    <!-- Spring view轉發器,提供Spring MVC支持 -->  
    <servlet>  
        <servlet-name>dispatcher</servlet-name>  
        <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>  
        <init-param>  
            <param-name>contextConfigLocation</param-name>  
            <param-value>/WEB-INF/dispatcher-servlet.xml</param-value>  
        </init-param>  
        <load-on-startup>1</load-on-startup>  
    </servlet>  
    <servlet-mapping>  
        <servlet-name>dispatcher</servlet-name>  
        <url-pattern>
.do</url-pattern>  
    </servlet-mapping>  




  1. Spring的applicationContext的配置:


    <!-- 導入屬性配置文件 -->
    <context:property-placeholder location="classpath:jdbc.properties" />


     <!--配置數據庫連接屬性,通過properties文件配置 -->
    <bean id="dataSource"
    class="org.springframework.jdbc.datasource.DriverManagerDataSource">
    <property name="driverClassName" value="${jdbc.driverClassName}" />
    <property name="url" value="${jdbc.url}" />
    </bean>


     <!--配置事務管理器 -->
    <bean id="transactionManager"
    class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
    <property name="dataSource" ref="dataSource" />
    </bean>


     <!--Spring整合Mybatis的配置-->
    <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
    <!--mybatis-configuration.xml配置文件位置-->
    <property name="configLocation" value="classpath:mybatis-configuration.xml" />
    <property name="dataSource" ref="dataSource" />
    <!--dao接口對應的Mapper的xml文件位置-->
    <property name="mapperLocations" value="classpath:he/maven/example/**/.xml" />
           <!--掃描別名所在包 -->
           <property name="typeAliasesPackage" value="he.maven.example.bean" />
    </bean>  
      <!--配置Mybatis執行sql的模板 -->
        <bean id="sqlSessionTemplate" class="org.mybatis.spring.SqlSessionTemplate">
    <constructor-arg ref="sqlSessionFactory" />
    </bean>

    <!--掃描mappers文件,自動注入的包,一般是dao層(Mybatis起作用的地方) -->
        <!-- scan for mappers and let them be autowired -->
        <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
            <property name="basePackage" value="he.maven.example.dao" />
        </bean>


    3.數據庫連接的配置:


    jdbc.properties:


    jdbc.driverClassName=com.mysql.jdbc.Driver
    jdbc.url=jdbc:mysql://localhost:3306/student_manager?user=root&password=root&useUnicode=true&characterEncoding=UTF-8


    4.Spring MVC 文件dispatcher-servlet.xml的配置:


      <!--以注解形式開發,并配置注解需要掃描的包 -->
    <mvc:annotation-driven />
    <context:component-scan base-package="he.maven.example" />


      <!--Spring集成mybatis后的ORM配置 -->
    <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
    <property name="annotationClass" value="org.springframework.stereotype.Repository" />
    <property name="basePackage" value="he.maven.example" />
    <property name="sqlSessionFactory" ref="sqlSessionFactory" />
    </bean>

    <!--Spring MVC的控制規則 -->
    <bean
    class="org.springframework.web.servlet.view.InternalResourceViewResolver">
    <property name="prefix" value="/WEB-INF/views/" />
    <property name="suffix" value=".jsp" />
    </bean>
 本文由用戶 jopen 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
 轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
 本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!