文章目录
运行环境
- 数据库 mysql 5.7
- tomcat 8.0.50
- jdk 1.8
- maven 3.6
结构层次
项目结构可以划分以下几个层次。
- 持久对象层(pojo层)由实体类组成,Javabean承担。
- 数据访问层(dao层)由若干个dao层接口和mybatis映射文件组成,接口的名称统一以Dao结尾,且和mybatis的映射文件名称保持一致。
- 业务逻辑层(service层)用于实现系统的业务逻辑,由Service结尾的接口和ServiceImpl结尾的实现类。
- 表现层(web层)主要包括SpringMVC中的controller类和jsp页面。controller主要负责拦截请求,调用业务逻辑层的相应组件中的逻辑方法来处理请求,并将相应的结果返回给jsp页面
层次结构图
文件组织架构
项目所涉及的包,配置文件以及页面文件等都在项目的组织结构中。
创建数据库表
本例就展示全部书籍的查询功能
create database book;
use book;
create table t_book(
`id` int primary key auto_increment,
`name` varchar(100),
`price` decimal(11,2),
`author` varchar(100),
`sales` int,
`stock` int,
`img_path` varchar(200)
);
pom.xml
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.jasomWu</groupId>
<artifactId>ssmIntergration</artifactId>
<version>1.0-SNAPSHOT</version>
<!--依赖 junit,数据库驱动,连接池,servlet,jsp,mybatis-spring spring-->
<dependencies>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.12</version>
</dependency>
<!--数据库驱动-->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.47</version>
</dependency>
<!-- 数据库连接池 -->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid</artifactId>
<version>1.2.4</version>
</dependency>
<!--Servlet - JSP -->
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>servlet-api</artifactId>
<version>2.5</version>
</dependency>
<dependency>
<groupId>javax.servlet.jsp</groupId>
<artifactId>jsp-api</artifactId>
<version>2.2</version>
</dependency>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>jstl</artifactId>
<version>1.2</version>
</dependency>
<!--Mybatis-->
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.5.2</version>
</dependency>
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis-spring</artifactId>
<version>2.0.2</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>5.1.9.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-jdbc</artifactId>
<version>5.1.9.RELEASE</version>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>1.16.20</version>
</dependency>
</dependencies>
<!--静态资源导出问题-->
<build>
<resources>
<resource>
<directory>src/main/java</directory>
<includes>
<include>**/*.properties</include>
<include>**/*.xml</include>
</includes>
<filtering>false</filtering>
</resource>
<resource>
<directory>src/main/resources</directory>
<includes>
<include>**/*.properties</include>
<include>**/*.xml</include>
</includes>
<filtering>false</filtering>
</resource>
</resources>
</build>
</project>
建立基本结构和配置框架
将dao层,pojo层,service层,controller层,和各种xml文件配置出组织结构。
Mybatis层编写
数据库配置文件
jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/book?characterEncoding=utf-8
jdbc.username=root
jdbc.password=123
#最大连接池数量 初始化建立物理连接的个数 获取连接时最长的等待时间 最小连接池数量
maxActive:200
initialSize:5
maxWait:60000
minIdle:10
#maxIdle:15
编写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>
<!--spring配置数据源 -->
<typeAliases>
<package name="com.jasomWu.pojo"/>
</typeAliases>
<mappers>
<mapper resource="com/jasomWu/dao/BookMapper.xml"/>
</mappers>
</configuration>
编写 javaBean
@Data
@AllArgsConstructor
@NoArgsConstructor
public class Book {
private Integer id;
private String name;
private String author;
private BigDecimal price;
private Integer sales;
private Integer stock;
private String img_path;
}
编写 Mapper接口
public interface BookMapper {
List<Book> queryAllBook();
}
编写接口对应的 Mapper.xml 文件
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.jasomWu.dao.BookMapper">
<select id="queryAllBook" resultType="com.jasomWu.pojo.Book">
select *
from t_book
</select>
</mapper>
编写Service层的接口和实现类
public interface BookService {
List<Book> queryAllBooks();
}
@Service
public class BookServiceImpl implements BookService {
@Autowired
private BookMapper bookMapper;
@Override
public List<Book> queryAllBooks() {
return bookMapper.queryAllBook();
}
}
Spring层
编写Spring整合Mybatis的相关的配置文件: spring-dao.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"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd">
<!--1.关联数据库配置文件-->
<context:property-placeholder location="classpath:jdbc-config.properties"/>
<!--2.连接池-->
<bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource">
<property name="driverClassName" value="${jdbc.driver}"/>
<property name="url" value="${jdbc.url}"/>
<property name="username" value="${jdbc.username}"/>
<property name="password" value="${jdbc.password}"/>
<!-- 最大并发连接数 -->
<property name="maxActive" value="${maxActive}" />
<!-- 初始化连接数量 -->
<property name="initialSize" value="${initialSize}" />
<!-- 配置获取连接等待超时的时间 -->
<property name="maxWait" value="${maxWait}" />
<!-- 最小空闲连接数 -->
<property name="minIdle" value="${minIdle}" />
</bean>
<!-- 3.配置SqlSessionFactory对象 -->
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<!-- 注入数据库连接池 -->
<property name="dataSource" ref="dataSource"/>
<!-- 配置mybatis全局配置文件:mybatis-config.xml -->
<property name="configLocation" value="classpath:mybatis-config.xml"/>
</bean>
<!--4.配置dao接口扫描包,动态实现了dao接口可以注入到spring容器中-->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<!--注入sqlSessionFactory-->
<property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"/>
<!--要扫描的dao包-->
<property name="basePackage" value="com.jasomWu.dao"/>
</bean>
</beans>
整合mybatis
目的:
1、spring管理所有组件。mapper的实现类。
service—>Dao @Autowired:自动注入mapper;
2、spring用来管理事务,spring声明式事务
下一部分
有springMVC层和spring的配置文件,Controller 和 视图层编写及综合测试!
戳这里 ——> 基于maven的ssm搭建(二)