数据库(MySQL):

account(用户表;没有外键),  profile(用户侧面信息表;有两个外键:catid,username),

category(宠物总分类表--鱼;没有外键),  product(宠物小分类表--金鱼;有一个外键:catid),

item(具体宠物分类--凤尾龙睛;有一个外键:productid),  orders(订单表;没有外键),

cart(购物车表;有两个外键:itemid,orderid; 主键:itemid 和 orderid作为联合主键)

account (用户表) 和 profile (用户的辅助信息;侧面信息) 是一对一关系。

//profile里有一个外键(username) 与 account里的主键(username)相对应。account没有外键。

category (宠物总分类表)  和 profile (用户侧面信息表)  是 多对多关系。//一类宠物可以有多个买家,买家也可以买多类宠物。

//profile里有一个外键(catid) 与 category 里的主键(catid)相对应。category 没有外键。

category (宠物总分类表)  和 product(宠物小分类)  是 一对多关系。//一类宠物有多个品种。

//product里有一个外键(catid) 与 category 里的主键(catid)相对应。category 没有外键。

product(宠物小分类) 和 item(具体宠物分类) 是一对多关系。//一类品种下的一只只狗。

//item里有一个外键(productid) 与 product里的主键(productid)相对应。

cart(购物车) 和 item(具体宠物分类) 是 一对多关系。

//cart里有一个外键(itemid) 与 item里的主键(itemid)相对应。

cart(购物车) 和 orders(订单表) 是 一对一关系。

//cart里有一个外键(orderid) 与 item里的主键(orderid)相对应。

用到的技术:

Spring + SpringMVC + MyBatis + Freemarker + MySQL

实现的功能:

登录、注册(Spring校验)、查询宠物(总分类、小分类、具体分类)、购物车

业务逻辑:

orders表里有一个orderdate字段,该字段为空表示没有结账。

cart表里itemid 和 orderid作为联合主键:也就是说同一张表里不能有相同的宠物具体分类,如果想订多个,用quantity字段控制(多次买合并,quantity+1)。

最开始是index页(从control层跳转过来的)

直接点进入商店 左上角显示游客(session为空)

右上角登录 登录失败显示红字 登录成功跳转到商店页面 并显示名字

注册:在下拉框(异步的)显示所有宠物大分类.(Spring 校验)。

进入商店后,显示宠物大分类(category),点击进入后显示该大分类下的宠物小分类(product);

再点击进入宠物小分类里是具体宠物分类(item):该页面有宠物的简单信息,可以点击加入购物车直接加入购物车(并进入购物车页面),也可以点击宠物序号进入宠物详细介绍页面

宠物详细介绍页面:该页面也是显示item表里的数据,只不过信息更详细,还有宠物的图片(数据库里存的是图像名<#assign ppath=request.contextPath><img src="${ppath}/static/images/${item.product.pic}"> 这样就取出来了),该页面也可以把商品加入购物车(并进入购物车页面)。

购物车页面:

该页面显示已加入购物车内的商品,并且可以改变宠物数量的值或删除该宠物,然后点击Update Cart按钮,合计和总计会计算出相应的值。

这时虽然Orders表里已经产生一笔数据,但是它的orderdate字段为空,表示没有结账。

直到点击下面的按钮表示提交订单,orderdate字段才会添加当前时间,表示已结账并记录当前时间。

然后页面返回到刚进入商店时的宠物大分类页面

最后附上该项目的源码:

https://github.com/chenzhida666/PetStore

PetStore项目总结的更多相关文章

  1. WebX配置文件、启动与响应流程

    ** 最近几天一直在看Spring的Ioc和AOP的源码介绍,还有Webx的使用.看Spring的源代码让人眼花缭乱,webx的配置文件也会让人感觉错综复杂无从下手.今天把之前看到的想到的webx相关 ...

  2. webx--petstore

    配置对应环境,运行petstore 通过官网给的命令行方法,来运行petstore petstore是java ee的经典学习案例,下载链接 如何运行呢? 参见官网给的指导:webx官网 git cl ...

  3. 不是广告--如何学Java,我说点不太一样的学习方式

    首先声明,这篇文章不是卖课程.介绍培训班的广告. 最近有不少读者通过微信问我:小白应该怎么学好 Java? 提问的人里有在校大学生.有刚参加工作的.有想转行做程序员的,还有一部分是最近找工作不顺的. ...

  4. 学Java,找对圈子,跟对人

    我大学学的是机械专业,到大四才决定要学Java,以后当一名程序员. 到现在,十几年过去了,我现在已经是一家上市公司的技术总监了,管理的技术团队有100多人.很庆幸当初了选择了学Java. 还记得当初学 ...

  5. ABP教程-给项目添加SwaggerUI,生成动态webapi

    上一篇,我们是正式将ABP生成的代码项目,跑起来了,然后演示了下多租户的不同.那么这篇我们就来实现下SwaggerUI. Q:SwaggerUI是干什么的呢? A:他是一个能将我们的webapi,通过 ...

  6. Webx框架自带的petstore

    Webx框架:http://openwebx.org/ petstore:webx3/webx-sample/petstore/tags/3.0/petstore 编译之后:mvn jetty:run ...

  7. 从头开始基于Maven搭建SpringMVC+Mybatis项目(4)

    接上文内容,上一节中的示例中完成了支持分页的商品列表查询功能,不过我们的目标是打造一个商品管理后台,本节中还需要补充添加.修改.删除商品的功能,这些功能依靠Mybatis操作数据库,并通过Spring ...

  8. 从头开始基于Maven搭建SpringMVC+Mybatis项目(3)

    接上文内容,本节介绍基于Mybatis的查询和分页功能,并展示一个自定义的分页标签,可重复使用以简化JSP页面的开发. 从头阅读传送门 在上一节中,我们已经使用Maven搭建好了项目的基础结构,包括一 ...

  9. 从头开始基于Maven搭建SpringMVC+Mybatis项目(1)

    技术发展日新月异,许多曾经拥有霸主地位的流行技术短短几年间已被新兴技术所取代. 在Java的世界中,框架之争可能比语言本身的改变更让人关注.近几年,SpringMVC凭借简单轻便.开发效率高.与spr ...

随机推荐

  1. Vue.js新手入门指南

    最近在逛各大网站,论坛,以及像SegmentFault等编程问答社区,发现Vue.js异常火爆,重复性的提问和内容也很多,楼主自己也趁着这个大前端的热潮,着手学习了一段时间的Vue.js,目前用它正在 ...

  2. 分享一个好用的函数吧,将js中的对象转成url参数

    JavaScript&jQuery获取url参数方法 这个函数呢是自己在写基于Vue+ElementUI管理后台时用到的,,下面列出来两种使用方式: 最普通的,封装一个js函数 /** * 对 ...

  3. Redis实现中间件(订阅)

    什么是消息中间件 发布订阅 点对点   消息中间件本身是异步的通讯 案例:使用redis实现发布订阅功能 Redis发布订阅 Redis 发布订阅(pub/sub)是一种消息通信模式:发送者(pub) ...

  4. hdu 1963 Investment 解题报告

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1963 题目意思:有 本金 money,还有一些股票的种类,第 i 种股票买入需要 value[i] 这 ...

  5. oracle:数据库版本问题导致的bug

    公司开发出来的系统,由于各现场oracle数据库版本有10.2.0.4.11.2.0.1.11.2.0.3.11.2.0.4: 进而会导致版本不一导致错误问题.下面列举2个: 1.wm_concat ...

  6. poj-1273 Drainage Ditches(最大流基础题)

    题目链接: Drainage Ditches Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 67475   Accepted ...

  7. I.MX6 新版、旧版u-boot不兼容问题

    /************************************************************************* * I.MX6 新版.旧版u-boot不兼容问题 ...

  8. [shell test] multiple conditions

      Classic technique (escape metacharacters): if[ \( $g -eq 1-a "$c"="123" \) -o ...

  9. public void与public static void区别

    我们换个简单易懂的说法,这两句的区别就在于,能不能直接用类名访问. 很好理解的不是吗? 假如,我有一个类,如下图所示: 接下来先实例化一个对象,ca,你会发现它不仅可以访问普通的方法,也可以访问静态的 ...

  10. UIAlterController 的使用

    相对于IOS8.4之后苹果对提示框做了进一步的封装,这将与之前的提示框有很大的同. 之前的 UIAlterView  是弹出一个提示框. 而今天学习的提示框是 通过视图控制器进行弹出,这就意味着,我们 ...