Maven+Spring+Spring MVC+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>
- 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>