在互联网行业的项目中尽可能减少表的关联查询,使用冗余解决表的关联问题。有利于分库分表
sku:最小库存单位。就是商品 id。就是商品最细力度的划分。每个 sku 都对应一款商品(如:iphone6 16G 白色、iphone6 16G 黑色)。
mybatis的逆向工程。根据数据库表生成 java 代码。
SSM框架整合
1、Dao层
使用mybatis框架,创建SqlMapConfig.xml。
创建一个applicationContext-dao.xml
(1)配置数据源
(2)让spring容易管理SqlSessionFactory,单例存在
(3)把mapper的代理对象放到spring容器中。使用扫描包的方式加载mapper的代理对象
2、Service层
(1)事务管理
(2)需要把service实现类对象放到spring容器中管理
3、表现层
(1)配置注解驱动
(2)配置视图解析器
(3)需要扫描controller
4、web.xml
(1)spring容器的配置
(2)springmvc前端控制器的配置
(3)Post乱码过滤器
整合思路
需要把配置文件放到 taotao-manager-web 工程下。因为此工程为 war 工程,其他的工程只是 jar 包。(配置文件是tomcat进行读取,而jar包中的配置文件tomcat读取不到,所以不能放在jar包中)
spring 与 springmvc 父子容器的关系
我们通常使用 spring 与 springmvc 时,都是在 spring 容器中扫描 service、dao,在 springvc 中扫描 controller,controller依赖service,但是springmvc本声明没有扫描service拿到service对象,通过子父容器管理所以可以访问父容器的service。
假设我们将controller的扫描放在spring容器而不是springmvc容器即spring中做全局扫描而springmvc中不做扫描,这样会出现404的错误,controller必须要放在controller中。
还有一种情况,当我们不考虑系统构架的延展性,我们可以不使用spring容器,将包的全局扫描放在springmvc中,即 <context:component-scan base-package="com.taotao" />
这样也能实现容器对象管理。
修改taotao-manager-mapper的pom文件
如果不添加此节点mybatis的mapper.xml文件都会被漏掉。
在taotao-manager-mapper的pom文件中添加如下内容:
<build>
<resources>
<resource>
<directory>src/main/java</directory>
<includes>
<include>**/*.properties</include>
<include>**/*.xml</include>
</includes>
<filtering>false</filtering>
</resource>
</resources>
</build>
使用maven的tomcat插件时Debug
解决方案:
下次启动Debug生效
分页插件PageHelper
使用方法
1、引入pageHelper的jar包,在taotao-manager-mapper的pom文件中添加。
<dependency>
<groupId>com.github.pagehelper</groupId>
<artifactId>pagehelper</artifactId>
</dependency>
2、需要在SqlMapConfig.xml文件中配置插件。
<!-- 配置分页插件 -->
<plugins>
<plugin interceptor="com.github.pagehelper.PageHelper">
<!-- 设置数据库类型 Oracle,Mysql,MariaDB,SQLite,Hsqldb,PostgreSQL六种数据库-->
<property name="dialect" value="mysql"/>
</plugin>
</plugins>
3、在查询的sql语句执行之前,添加一行代码:
PageHelper.startPage(1, 10);
第一个参数是page,要显示第几页。
第二个参数是rows,没页显示的记录数。
4、取查询结果的总数量。
创建一个PageInfo类的对象,从对象中取分页信息。
public class TestPageHelper {
@Test
public void testPageHelper() {
//创建一个spring容器
ApplicationContext applicationContext = new ClassPathXmlApplicationContext("classpath:spring/applicationContext-*.xml");
//从spring容器中获得Mapper的代理对象
TbItemMapper mapper = applicationContext.getBean(TbItemMapper.class);
//执行查询,并分页
TbItemExample example = new TbItemExample();
//分页处理
PageHelper.startPage(2, 10);
List<TbItem> list = mapper.selectByExample(example);
//取商品列表
for (TbItem tbItem : list) {
System.out.println(tbItem.getTitle());
}
//取分页信息
PageInfo<TbItem> pageInfo = new PageInfo<>(list);
long total = pageInfo.getTotal();
System.out.println("共有商品:"+ total);
}
}
原版本对逆向工程生成的代码支持不好,不能对有查询条件的查询进行分页,会抛异常。这个版本是修改版(黑马版)。