idea 下搭建ssm开发环境

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是自动执行的。

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值