首页
技术笔记
网址导航
Json在线解析
二维码
Ip地址查询
在线流程图
新用户注册
|
会员登录
在线工具
开发笔记
毒鸡汤
网址导航
免费在线流程图
6赞
590
当前位置:
开发笔记
>
编程语言
> 正文
一些关于asp 购物车的想法
作者:贴进你的心聆听你的世界 | 2021-10-21 18:26
问题:1.购物车中的数据是否应该存储在数据库中?我特别想知道在真正的项目中,那些真正的软件工程师是如何考虑这个问题的。在Google上一搜,搜到了一篇咱园子里一位网友的观点:购物车应该是个临时存储数据的模块,他将其存放在Session对象中。这位网友说的很有道理,不过我并不喜欢这样的做法。如果大家都
问题: 1.购物车中的数据是否应该存储在数据库中?
我特别想知道在真正的项目中,那些真正的软件工程师是如何考虑这个问题的。在Google上一搜,搜到了一篇咱园子里一位网友的观点:购物车应该是个临时存储数据的模块,他将其存放在Session对象中。这位网友说的很有道理,不过我并不喜欢这样的做法。如果大家都将其存储在Session对象中,成千上万个用户一同购物的话,想必ASP.NET服务器必将承受巨大的负载。也许像我们国内的网站可能会好一些,但想Amazon这样的网站,怎么做的呢?Amazon中国网站,也就是Joyo的网站,并不是将其存储在Session对象中,因为我如果这次放入购物车中的商品没有提交订单,下次登录后购物车中还会有这些商品。因此,我想他们可能是将这些购物车中的数据放入了数据库中。
回复: 把购物车存放在Session中,这种做法似乎只存在于大学里的课程设计或者一些无人在意的实习项目中出现。事实上,基本所有的电子商务网站都把购物车数据存放到了数据库里。下面是一些解释和设计上需要注意的地方:
1、Session并不适合做大数据量的数据存放,当用户比较多的时候势必影响服务器性能,这是应该避免的。
2、Session存在意外丢失的问题,或者当用户不小心关闭浏览器,都会引起购物车内物品全部丢失,用户体验很不好
3、Cookies可以解决上面一条里Session的问题,但是Cookies的长度限制,以及使用Cookies时的通讯开销,还有安全性方面考虑,Cookies并不适合做购物车
4、比较好的用户体验是,无论用户登录与否,都可以在一定时间内记录购物车状态,这就要求数据库内购物车不能与用户捆绑太死
5、放到购物车里的商品,一般都是有购买意向的商品,但并不一定会成为真实的订单,这时候,保留这份数据,对数据挖掘、业务分析有至关重要的作用
问题: 2.关于并发?
原来我在开发自己的模拟网站的时候,曾经想到这样一个问题:如果一个客户在网站将一些图书放入了购物车,那么这些数量的图书是否应该从库存中减去呢?当时我是这样做了。我将购物车中相应图书的数量从数据库中减去,以防止此时其他用户看到”虚”的库存数量(如果没有减去,那么其他用户是可以购买的。例如:库存中图书的数量是10本,客户A将10本放入自己的购物车,此时客户B也将10本放入自己的购物车,那么谁将购买到此书将成为一个矛盾)。不过我这样做的结果是,每当客户更新购物车的同时就会同数据库有一次交流,加大了数据服务器的负担。Amazon.cn在这方面做的也不是很好,前些日子相信大家可能都遇到了当购买《深入理解操作系统》一书的时候,本来生成了订单,但是却在第二天告知缺货的事情。这一事件确实非常影响Amazon.cn的信誉,不知道现在他们的系统是否已经解决这一问题,不过现在《深入理解操作系统》一书的Joyo价已经今非昔比了。不知道各位高手是如何解决这一问题的,欢迎大家将自己的成功经验写在评论中。
回复: 首先说一下数据库服务器的负担,想一下每访问一个页面要对数据库进行多少次访问,然后想一下多次访问才能换来一次放购物车的操作(访问次数主要取决于网站易用性的设计,这是另外一个话题),所以,虽然在这里修改设计可以减轻一些数据库压力,但是这里并不是瓶颈,丁学认为不需要在这里太在意。
目前比较通用的做法,购物车的商品是不会立即扣减库存的,主要是为了防止有人通过购物车恶意占用商品,另外一般都会给一个冗余量,因为大部分购物车里的商品不会进入最终的成功订单,不可以让购物车影响销量,这是必须做到的。库存一般在订单成功提交的时候扣减库存,也就是用户在提交订单时,你还有一次机会提示用户没有库存了,所以更没有必须在放到购物车时就扣减库存。对于“成功订单”,并不是所有用户提交的订单都算成功订单,这里有一个自动审单的过程,这个程序不好写,但确实很重要,根据以前的数据分析、用户行为、用户信誉等经验性的数据来由系统在几分钟内自动对订单完成一次审核,审核力度与行业有关,这样可以杜绝大部分的假订单,其中一部分可能还要由自动审单系统转交人工审核。
这里有一个特殊情况,有一些特殊商品比如演唱会门票,可能会存在在线选座的行为,这种时候放购物车后留座变得比较有用,现在的做法一般是放购物车后立即留座,但某一段时间未成为真实订单的话就自动释放,比如十分钟,虽然无法完全杜绝恶意占座,不过可以解决多数问题。现在票务方面的成功订单和大部分其他行业不太一样,票务行业的在线选座成功订单的判断标准为是否已经成功支付,就是说除非你给钱了,不然只能给你留十分钟。
问题: 3.订单和订单明细同购物车的关系
我想这个问题可能一直是此类网站的一个大问题吧!前两天,CSTP的陈老师还曾在电话中面试我这道题,我当时很紧张,问题答的不是很清楚。其实这个问题简单的想并不难:两个表订单和明细,订单表中每列指向明细表中的对应列。外键就是订单表中的订单号。
回复: 这个问题比较简单,一种是放购物车里就当是订单了,拿一个状态标识一下,这种状态下订单是可修改的,购物车合并进订单系统(注意处理用户登录与非登录状态);第二种是有单独的购物车表,当最终提交订单时,复制购物车内的信息进订单和订单明细表。后一种用得比较多一些,具体选择哪个取决于行业和商品属性。
问题: 4.明细表中订单号的生成?
这个问题继承第3个问题,我一直不知道应该如何解决此问题。我有两个解决方案,一个是使用触发器,另一个是编程。前者在客户每次放入购物车中一种商品的同时增加一个明细,确认购买后生成订单,将明细表中的购买状态更改以触发触发器将生成一个订单号(当然这个订单号既可以在触发器中编程也可以是让订单表订单号的一列设置为自动生成序号)。后者将判断订单号,然后将其加1以生成新的订单号。但是这两个方案我总是觉得非常不好,很想知道在商用网站中订单号是如何处理的。
回复: 首先我个人认为触发器的方案不可取,理由不多说,不然又是一大坨。这里也有两种做法,一种是订单表自动生成编号,生成订单时,先写入订单表,然后取回订单号再更新订单明细表;另一种是按业务规则生成订单号,当订单号已知后随便先生成订单记录还是明细记录都可以,但是要保证明细记录最终一定有订单记录,不然会有很多诡异的明细项。后一种办法又有两种做法,一是订单号由数据库生成,一般采用临时表,好处是可以全业务通用流水号,另一种是订单号由程序生成,程序生成时可以使用GUID,但更好的办法是使用订单时间加标识值,时间部分可以根据订单量来确定粒度大小,标识部分采用有序编号,时间粒度还要考虑防止别人大概统计你的业务量(汗~~~这个也是另外的问题,很多做法,看情况了,改天有空再写个有关订单号生成的文章吧,先回复这么多,大概信息也够了……)
推荐阅读
程序员
安装和注册shell扩展上下文菜单来自wix安装程序
如何解决《安装和注册shell扩展上下文菜单来自wix安装程序》经验,为你挑选了1个好方法。 ...
[详细]
程序员
如何使用retofit2和RxAndroid取消请求
如何解决《如何使用retofit2和RxAndroid取消请求》经验,为你挑选了1个好方法。 ...
[详细]
程序员
为什么非const std :: array :: operator []不是constexpr?
如何解决《为什么非conststd::array::operator[]不是constexpr?》经验,为你挑选了3个好方法。 ...
[详细]
程序员
如何使用CSS水平居中链接元素?
如何解决《如何使用CSS水平居中链接元素?》经验,为你挑选了1个好方法。 ...
[详细]
程序员
更改字符时拆分字符串
如何解决《更改字符时拆分字符串》经验,为你挑选了2个好方法。 ...
[详细]
程序员
PEAR和Composer有什么区别?
如何解决《PEAR和Composer有什么区别?》经验,为你挑选了1个好方法。 ...
[详细]
程序员
哪一个是有效的初始化变量ie)构造函数或激活方法?
如何解决《哪一个是有效的初始化变量ie)构造函数或激活方法?》经验,为你挑选了1个好方法。 ...
[详细]
程序员
如何使用正则表达式对列表元素进行排序?
如何解决《如何使用正则表达式对列表元素进行排序?》经验,为你挑选了1个好方法。 ...
[详细]
程序员
使用Swift中的UITextView属性自定义UIView的加载时间较慢
如何解决《使用Swift中的UITextView属性自定义UIView的加载时间较慢》经验,为你挑选了1个好方法。 ...
[详细]
程序员
什么时候应该使用静态数据成员与const全局变量?
如何解决《什么时候应该使用静态数据成员与const全局变量?》经验,为你挑选了0个好方法。 ...
[详细]
程序员
如何保持cts:从匹配内部XML标签突出显示?
如何解决《如何保持cts:从匹配内部XML标签突出显示?》经验,为你挑选了1个好方法。 ...
[详细]
程序员
IIS配置错误 - 此配置部分不能在此路径中使用
如何解决《IIS配置错误-此配置部分不能在此路径中使用》经验,为你挑选了5个好方法。 ...
[详细]
程序员
保护和加密多租户云应用程序的共享数据库中的数据
如何解决《保护和加密多租户云应用程序的共享数据库中的数据》经验,为你挑选了0个好方法。 ...
[详细]
程序员
如何在不编写长查询的情况下查询所有GraphQL类型字段?
如何解决《如何在不编写长查询的情况下查询所有GraphQL类型字段?》经验,为你挑选了4个好方法。 ...
[详细]
程序员
拖放将自定义HTML拖放为拖动图像
如何解决《拖放将自定义HTML拖放为拖动图像》经验,为你挑选了1个好方法。 ...
[详细]
程序员
C中三个有效值的平均值
如何解决《C中三个有效值的平均值》经验,为你挑选了0个好方法。 ...
[详细]
程序员
用JavaScript创建MP4视频
如何解决《用JavaScript创建MP4视频》经验,为你挑选了1个好方法。 ...
[详细]
程序员
不能使用'PhpParser\Node\Scalar\String'作为类名,因为它是保留的
如何解决《不能使用'PhpParser\Node\Scalar\String'作为类名,因为它是保留的》经验,为你挑选了2个好方法。 ...
[详细]
程序员
如何加载模块并导航到模块?棱镜
如何解决《如何加载模块并导航到模块?棱镜》经验,为你挑选了1个好方法。 ...
[详细]
程序员
是否可以仅从Firebase检索密钥列表?
如何解决《是否可以仅从Firebase检索密钥列表?》经验,为你挑选了1个好方法。 ...
[详细]
吐了个 "CAO" !
吐个槽吧,看都看了
会员登录
|
用户注册
贴进你的心聆听你的世界
这个屌丝很懒,什么也没留下!
关注作者
Tags | 热门标签
actionscrip
bash
c#
c++
c语言
erlang
flutter
go
golang
java
javascript
lua
node.js
perl
php
python
scala
typescript
RankList | 热门文章
1
为什么以下C++程序打印'0'而不是'6'?
2
AWS API Gateway:由于配置错误导致执行失败:输出映射不匹配且未配置默认输出映射
3
Swift:CFArray:将值作为UTF字符串获取
4
Heroku:运行npm install和gulp build for Django app
5
使用Browserify在ES6中使用Bootstrap和jQuery包时出错
6
Emgu CV 3 findContours和Vec4i类型的层级参数是否等效?
7
如何将constexpr作为模板参数传递?
8
Android PC上的Android工作室更快吗?
9
在class属性中引用类名的最佳方法是什么?
10
将Android Studio更新为1.5后出现Gradle错误
11
实际上是否可以从构造微积分中删除"Pi"?
12
电话号码正则表达式不适用于swift
13
如何使docker-compose从远程git存储库构建映像?
14
Swift无法找到并读取属性列表(.plist)文件
15
使用BCrypt和Sequelize Model
16
UICollectionView的自定义焦点引擎行为
17
如何禁用导航控制器(Swift)中特定视图控制器的自动旋转?
18
F#通用函数筛选受歧视联合的列表
19
Visual Studio认为一切都是TypeScript资源
20
如何在windows中删除sublime中的整行
DevBox开发工具箱 | 专业的在线开发工具网站
京公网安备 11010802040832号
|
京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有