上节课我们一起学习了搭建前台显示系统taotao-portal-web,这节课我们一起学习下前台显示内容的表设计。
我们以京东的首页为例,如下图所示,可以看到内容显示是分组显示的,广告位轮播图是一组,轮播图下面那两张图片是一组,右边的"促销"、"公告"是一组,但是它与轮播图又有所不同,不同之处在于它下面分了两个小组,每个小组下面有标题列表,每个标题都是一个链接,点击"促销"这组的任何一个标题进入会是一个新的网站,点击"公告"这组的任何一个标题进去则是公告的具体内容(相当于一篇文章)。"更多"表示还有其它分组。另外"京东秒杀"这也是一组,这组内容的特点是有标题有图片有价格。"发现好货"这组则是有图片有标题。
从上图京东首页的展示不难看出,我们应该将内容进行分类,每个分类下面有多条内容,它们是一对多的关系,这样的关系就适合用两张表来进行存储。一张表示内容分类表,另一张表示内容表。首先我们来看下内容分类表,如下图所示。表中有parent_id字段,这样便可以实现树形分级展示,分类要有分类名称(name字段),status字段用来表示该分类目前是否应该显示(如果已经逻辑删除了,那么便不再显示了),sort_order则是同级类目的展现次序,is_parent字段直接记录是否是父级类目(这个字段在树形展示时很有用)。
下面我们便来看一下内容表,内容表中肯定是有内容分类表的外键的(category_id),内容展示有的有标题,因此需要标题(title)这么一个字段,有的文章是有小标题的,因此我们应该加上小标题字段(sub_title),有的内容需要对标题进行描述,因此需要标题描述字段(title_desc),链接字段是必须要有的,因为内容涉及最多的便是跳转。之所以这张表设计了两个图片字段,是因为考虑到不同的显示屏所显示的图片会不一样,宽屏则应该显示宽屏图片,窄屏则应该显示窄屏图片。
下面我们来搭建内容工程
1、File----->New------>Other...------->Maven Project,在弹出的对话框中输入如下图所示内容。
2、添加taotao-content-interface模块,方法是在taotao-content工程上右键----->Maven------>New Maven Module Project,如下图所示。
勾选"create a simple project",在Module Name中输入taotao-content-interface,然后点击"Next"。
packaging打包方式我们使用默认的jar,直接点击"Finish"。
3、新建taotao-content-service模块,步骤基本上同上,只是打包方式换成war即可,如下图所示。
至于dao和pojo两个模块我们不用在taotao-content工程再新建一遍了,因为我们在taotao-manager工程当中便创建好了,我们只需要引用这两个模块就可以了。
4、配置taotao-content的pom.xml文件,添加对taotao-common工程的依赖,我们最好启动聚合工程,因此我们在聚合工程配置tomcat启动插件,8080、8081、8082都已经被占用了,我们这里使用8083,如下所示。
4.0.0
com.taotao
taotao-parent
0.0.1-SNAPSHOT
com.taotao
taotao-content
0.0.1-SNAPSHOT
pom
taotao-content-interface
taotao-content-service
com.taotao
taotao-common
0.0.1-SNAPSHOT
org.apache.tomcat.maven
tomcat7-maven-plugin
/
8083
5、配置taotao-content-interface的pom.xml文件,添加对taotao-manager-pojo的依赖,如下所示。
4.0.0
com.taotao
taotao-content
0.0.1-SNAPSHOT
taotao-content-interface
com.taotao
taotao-manager-pojo
0.0.1-SNAPSHOT
6、配置taotao-content-service的pom.xml文件,添加taotao-manager-dao、taotao-content-interface、spring、dubbo的依赖,如下所示。
4.0.0
com.taotao
taotao-content
0.0.1-SNAPSHOT
taotao-content-service
war
com.taotao
taotao-manager-dao
0.0.1-SNAPSHOT
com.taotao
taotao-content-interface
0.0.1-SNAPSHOT
org.springframework
spring-context
org.springframework
spring-beans
org.springframework
spring-webmvc
org.springframework
spring-jdbc
org.springframework
spring-aspects
org.springframework
spring-jms
org.springframework
spring-context-support
com.alibaba
dubbo
spring
org.springframework
netty
org.jboss.netty
org.apache.zookeeper
zookeeper
com.github.sgroschupf
zkclient
7、配置resource,我们把taotao-manager-service的src/main/resources目录下的mybatis、properties、spring三个目录粘贴过来。SqlMapConfig.xml文件不用动,如下图所示。
properties下的db.properties配置不用改,如下图所示。
spring目录下的applicationContext-dao.xml文件也不用修改,如下图所示。
applicationContext-service.xml文件需要修改扫描的包为"com.taotao.content.service",然后我们到taotao-content-interface的src/main/java目录下新建com.taotao.content.service包并在taotao-content-service的src/main/java目录下新建com.taotao.content.service.impl包。dubbo服务名称修改为"taotao-content",dubbo服务向外暴露的端口为"20881"(每发布一个服务就要更改一个端口)
修改applicationContext-trans.xml文件,修改切面的包为com.taotao.content.service。
把taotao-manager-service下的WEB-INF及web.xml,粘贴到taotao-content-service的webapp目录下,修改
发布服务不一定非要使用tomcat,之所以使用tomcat是为了部署方便。