依赖

  • 数据库驱动
  • druid(连接池)
  • mybatis
  • mybatis-spring
  • spring-tx (如果要用到事务)

 

jdbc.properties

#数据库连接信息
jdbc.driverClassName=com.mysql.cj.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/db_mall?serverTimezone=UTC
jdbc.username=chy
jdbc.password=abcd

#druid配置
jdbc.initialSize=10
jdbc.maxActive=300
jdbc.maxIdle=10

 

mybatis-config.xml

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE configuration
        PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-config.dtd">

<configuration>
    <!-- 实体类别名 -->
    <typeAliases>
        <package name="com.chy.mall.entity" />
    </typeAliases>

    <!-- 指定映射文件位置 -->
    <mappers>
        <package name="com.chy.mall.dao.mapper" />
    </mappers>

</configuration>

注意修改实体类的位置、mapper映射文件的位置

 

spring-db.xml

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns:context="http://www.springframework.org/schema/context" xmlns:tx="http://www.springframework.org/schema/tx"
       xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context https://www.springframework.org/schema/context/spring-context.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx.xsd">

    <!-- 引入数据库连接信息db.properties -->
    <context:property-placeholder location="classpath:jdbc.properties" />

    <!-- 配置druid数据源 -->
    <bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource">
        <property name="driverClassName" value="${jdbc.driverClassName}" />
        <property name="url" value="${jdbc.url}" />
        <property name="username" value="${jdbc.username}" />
        <property name="password" value="${jdbc.password}" />
        <property name="initialSize" value="${jdbc.initialSize}" />
        <property name="maxActive" value="${jdbc.maxActive}" />
        <property name="minIdle" value="${jdbc.maxIdle}" />
    </bean>

    <!-- 配置mybatis的SqlSessionFactory -->
    <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
        <property name="dataSource" ref="dataSource" />
        <!-- mybatis的配置可以单独写在一个xml配置文件中,在此文件中引入,也可以直接写在这个bean中 -->
        <property name="configLocation" value="classpath:mybatis-config.xml" />
    </bean>

    <!-- 指定mapper接口位置 -->
    <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
        <!-- 如果有多个包,用逗号或分号分隔 -->
        <property name="basePackage" value="com.chy.mall.dao" />
    </bean>

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

    <tx:annotation-driven transaction-manager="transactionManager" />

</beans>

注意修改mapper接口的位置

 

常见问题

NoSuchBeanDefinitionException: No bean named ‘xxx’ available”

原因是标注bean的注解没被扫描到,一般是spring配置文件中没配置组件扫描,或者包没写全

<!-- 有多个包时逗号分隔 -->
<context:component-scan base-package="" />

<!-- 一劳永逸的方法是直接写项目所在的包 -->
<context:component-scan base-package="com.chy.mall" />

 

跨库操作

jdbc:mysql://localhost:3306/?serverTimezone=UTC

url中不写数据库名,写sql时表名写成 库名.表名 的形式