idea 下搭建ssm开发环境
整合思路
- 需要spring通过单例方式管理sqlSessionFactory。Spring与mybatis整合生成代理对象,使用sqlSessionFactory创建SqlSession。持久层的mapper都需要由spring进行管理。
整合环境
-
使用idea创建maven javaweb工程
-
在pom文件中添加依赖。(为了方面后面整合springmvc,这里导入ssm所需的所有jar包)
-
依赖代码
<properties> <!-- spring版本号 --> <spring.version>4.0.2.RELEASE</spring.version> <!-- mybatis版本号 --> <mybatis.version>3.2.6</mybatis.version> <!-- log4j日志文件管理包版本 --> <slf4j.version>1.7.7</slf4j.version> <log4j.version>1.2.17</log4j.version> </properties> <dependencies> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>4.11</version> <!-- 表示开发的时候引入,发布的时候不会加载此包 --> <scope>test</scope> </dependency> <!-- spring核心包 --> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-core</artifactId> <version>${spring.version}</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-web</artifactId> <version>${spring.version}</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-oxm</artifactId> <version>${spring.version}</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-tx</artifactId> <version>${spring.version}</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-jdbc</artifactId> <version>${spring.version}</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-webmvc</artifactId> <version>${spring.version}</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-aop</artifactId> <version>${spring.version}</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-context-support</artifactId> <version>${spring.version}</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-test</artifactId> <version>${spring.version}</version> </dependency> <!-- mybatis核心包 --> <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis</artifactId> <version>${mybatis.version}</version> </dependency> <!-- mybatis/spring包 --> <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis-spring</artifactId> <version>1.2.2</version> </dependency> <!-- 导入java ee jar 包 --> <dependency> <groupId>javax</groupId> <artifactId>javaee-api</artifactId> <version>7.0</version> </dependency> <!-- 导入Mysql数据库链接jar包 --> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>5.1.30</version> </dependency> <!-- 导入dbcp的jar包,用来在applicationContext.xml中配置数据库 --> <dependency> <groupId>commons-dbcp</groupId> <artifactId>commons-dbcp</artifactId> <version>1.2.2</version> </dependency> <!-- JSTL标签类 --> <dependency> <groupId>jstl</groupId> <artifactId>jstl</artifactId> <version>1.2</version> </dependency> <!-- 日志文件管理包 --> <!-- log start --> <dependency> <groupId>log4j</groupId> <artifactId>log4j</artifactId> <version>${log4j.version}</version> </dependency> <!-- 格式化对象,方便输出日志 --> <dependency> <groupId>com.alibaba</groupId> <artifactId>fastjson</artifactId> <version>1.1.41</version> </dependency> <dependency> <groupId>org.slf4j</groupId> <artifactId>slf4j-api</artifactId> <version>${slf4j.version}</version> </dependency> <dependency> <groupId>org.slf4j</groupId> <artifactId>slf4j-log4j12</artifactId> <version>${slf4j.version}</version> </dependency> <!-- log end --> <!-- 映入JSON --> <dependency> <groupId>org.codehaus.jackson</groupId> <artifactId>jackson-mapper-asl</artifactId> <version>1.9.13</version> </dependency> <!-- 上传组件包 --> <dependency> <groupId>commons-fileupload</groupId> <artifactId>commons-fileupload</artifactId> <version>1.3.1</version> </dependency> <dependency> <groupId>commons-io</groupId> <artifactId>commons-io</artifactId> <version>2.4</version> </dependency> <dependency> <groupId>commons-codec</groupId> <artifactId>commons-codec</artifactId> <version>1.9</version> </dependency> <dependency> <groupId>org.junit.jupiter</groupId> <artifactId>junit-jupiter-api</artifactId> <version>RELEASE</version> </dependency> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>4.10</version> </dependency> </dependencies>
-
-
静态资源打包问题
-
描述:一般情况下,我们用到的资源文件(各种xml,properites,xsd文件等)都放在src/main/resources下面,利用maven打包时,maven能把这些资源文件打包到相应的jar或者war里。有时候,比如mybatis的mapper.xml文件,我们习惯把它和Mapper.java放一起,都在src/main/java下面,这样利用maven打包时,就需要修改pom.xml文件,来把mapper.xml文件一起打包进jar或者war里了,否则,这些文件不会被打包的。(maven认为src/main/java只是java的源代码路径)。
-
解决办法:
-
在pom文件中添加如下代码
<build> <finalName>MySM</finalName> <resources> <resource> <directory>src/main/java</directory> <includes> <include>**/*.xml</include> </includes> <filtering>true</filtering> </resource> <resource> <directory>src/main/resources</directory> <includes> <include>**/*.xml</include> <include>**/*.properties</include> </includes> </resource> </resources> </build>
其中*/这样的写法,是为了保证各级子目录下的资源文件被打包*
-
-
-
更新项目,引入jar包,侧面更新按钮
-
创建相应配置文件
-
配置spring
-
在web.xml中加入spring的监听器以及相关的参数以完成配置。
<listener> <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class> </listener> <context-param> <param-name>contextConfigLocation</param-name> <param-value>classpath:spring/applicationContext.xml</param-value> </context-param>
-
-
sqlSessionFactory配置
-
在applicationContext.xml配置sqlSessionFactory和数据源
<!--加载配置文件--> <context:property-placeholder location="classpath:mybatis/db.properties"/> <!--数据源,使用dbcp--> <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close"> <property name="driverClassName" value="${jdbc.driverClass}"></property> <property name="url" value="${jdbc.jdbcUrl}"></property> <property name="username" value="${jdbc.user}"></property> <property name="password" value="${jdbc.password}"></property> <property name="maxActive" value="10"/> <property name="maxIdle" value="5"/> </bean> <!--sqlSessionFactory--> <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"> <!--加载mybatis的配置文件--> <property name="configLocation" value="mybatis/SqlMapConfig.xml"/> <!--数据源--> <property name="dataSource" ref="dataSource"/> </bean>
-
-
通过逆向工程从数据库生成相应得po类等文件
-
原始dao层开发(和spring整合后)
-
创建xml映射文件
<select id="findUserById" parameterType="int" resultType="com.timmy.po.User"> SELECT * FROM USER WHERE id=#{id} </select>
-
dao(实现类继承SqlSessionDaoSupport)
public interface UserDao { public User findUserById(int id) throws Exception; } public class UserDaoTest extends SqlSessionDaoSupport implements UserDao { public User findUserById(int id) throws Exception { SqlSession sqlSession = this.getSqlSession(); User user = sqlSession.selectOne("test.findUserById", id); sqlSession.commit(); return user; } }
-
配置dao
<bean id="userDao" class="com.timmy.dao.UserDaoTest"> <property name="sqlSessionFactory" ref="sqlSessionFactory"/> </bean>
-
测试程序
public class MapperTest { private ApplicationContext applicationContext; @Before public void setUp() throws Exception { applicationContext = new ClassPathXmlApplicationContext("classpath:spring/applicationContext.xml"); } @Test public void testFindUserId() throws Exception { // UserMapper userMapper= (UserMapper) applicationContext.getBean("userMapper"); // User user=userMapper.selectByPrimaryKey(1); // System.out.println(user); UserDao userDao = (UserDao) applicationContext.getBean("userDao"); User user = userDao.findUserById(1); System.out.println(user); } }
-
-
Mapper代理开发
-
通过MapperFactoryBean创建代理对象
<!--mapper配置 MapperFactoryBean:根据mapper接口生成代理对象--> <bean id="userMapper" class="org.mybatis.spring.mapper.MapperFactoryBean"> <!--mapperInterface指定mapper接口--> <property name="mapperInterface" value="com.timmy.mapper.UserMapper"></property> <property name="sqlSessionFactory" ref="sqlSessionFactory"></property> </bean>
注:这种方式下,针对每个mapper进行配置,极其之麻烦。
-
通过MapperScannerConfigurer进行mapper扫描(建议使用)
<!--mapper批量扫描,从mapper包中扫描出mapper接口,自动创建代理对象并且在spring容器中注册 但要遵循一定的规范:mapper.java和mapper.xml映射文件的文件名称保持一致,且在一个目录中 自动扫描出来的mapper的bean的id为mapper类名(s首字母小写) --> <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer"> <!--指定扫描的包名,假如扫描多个包,每个包中间使用半角逗号分隔--> <property name="basePackage" value="com.timmy.mapper"/> <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"/> </bean>
-
测试代码
public class MapperTest { private ApplicationContext applicationContext; @Before public void setUp() throws Exception { applicationContext = new ClassPathXmlApplicationContext("classpath:spring/applicationContext.xml"); } @Test public void testFindUserId() throws Exception { UserMapper userMapper= (UserMapper) applicationContext.getBean("userMapper"); User user=userMapper.selectByPrimaryKey(1); System.out.println(user); // UserDao userDao = (UserDao) applicationContext.getBean("userDao"); // User user = userDao.findUserById(1); // System.out.println(user); } }
-
-
错误解析
-
代码
public User findUserById(int id) throws Exception { SqlSession sqlSession = this.getSqlSession(); User user = sqlSession.selectOne("test.findUserById", id); sqlSession.commit(); return user; }
-
执行程序后出错
spring下配置好的SqlSession将自动完成commit,并在执行完sql之后自动close。也 就是说我们如果手动sqlsession.commit或者close,实际上是重复了一个动作。数据库中是出现了重复的数据的。这也证明了mybatis是自动执行的。
-