六月婷婷综合激情-六月婷婷综合-六月婷婷在线观看-六月婷婷在线-亚洲黄色在线网站-亚洲黄色在线观看网站

明輝手游網中心:是一個免費提供流行視頻軟件教程、在線學習分享的學習平臺!

購物車中數據的存放方式

[摘要]aierong [原作] 第一次做BToC站點的購物車,總結了一下購物車中數據的存放方式方式1:用會話會話中可以存放任何類型數據,每個用戶有一個唯一的會話ID,用此ID區分不同用戶的購物車會話數據是存放在WEB服務器的內存中的,如果使用購物車的用戶比較多的話,這樣一來將占用大量服務器資源會話有一小...

aierong [原作]

第一次做BToC站點的購物車,總結了一下購物車中數據的存放方式

方式1:用會話


會話中可以存放任何類型數據,每個用戶有一個唯一的會話ID,用此ID區分不同用戶的購物車
會話數據是存放在WEB服務器的內存中的,如果使用購物車的用戶比較多的話,這樣一來將占用大量服務器資源
會話有一小缺陷,它是依靠COOKIE來與用戶通訊的,一旦用戶關閉COOKIE,使用會話將比較麻煩

當然在ASP。NET中還有另2種方式保存會話數據
一種是指定另一臺服務器來存放會話數據,這樣一來可以有效分擔WEB服務器的運行開銷。
另一種是把會話數據存放在MS SQL中,MS SQL是利用局部臨時表實現的,會話數據放在局部臨時表中,MS SQL為每一個局部臨時表也分配一個唯一的ID

,我想是用此ID區分不同用戶的不同會話數據的。但是我不推薦使用此方法,頻繁在數據庫里面建立和刪除臨時表對數據庫的開銷太大

 

方式2:在數據庫里面用表(ShopingCart)

我喜歡的實現方式

表有幾個基本字段
CartId              購物車ID(唯一)
Id                      商品的ID(唯一)
Qty                    用戶購買商品的數量
CreateDate       購物車創建時間

此表的字段CartId是區分不同用戶的購物車的ID,要是登陸用戶,你可以在表中存放此登陸用戶的登陸名的ID,要是未登陸用戶使用購物車,

你可以給他分配一個GUID(全球唯一標志)做購物車ID

此方法有也有一些缺陷,一是它會造成大量無效數據,大家都知道,使用購物車的人,不一定會最終結帳購買商品。但是使用購物車就得

往表(ShopingCart)里面插入相關數據,未登陸用戶一離開站點,他在表中的數據就成了一堆廢數據,因為他在下次登陸時,我們分配給他的

是一個新的CartId購物車ID.有廢數據我們就得時常來維護此表,我們可以寫一個清除廢數據的過程(利用字段CreateDate和CartId可以判斷無效數據),人工調用運行也可以,要是想由MS SQL代我們來運行,就可以設置一個JOB,由JOB自動調用過程清楚廢數據

 

說拉缺陷,我們該說說此方式的優點拉
1。占用系統資源少,我們可以把數據庫安置在一臺電腦中,WEB服務器安置在另一電腦中,系統資源充分發揮
2。購物車中數據可以得到有效保留,我們可以試想一客戶在購物時,突然某其他原因(死機等原因)離開了購物站,他在購物車中數據有效保

留下來,他下次登陸時購物車中還有上次保留的數據,避免用戶再次選購商品的操作(此功能只對登陸用戶的購物車有效) ,要是用會話實現

購物車,所有用戶一旦離開站點,他的購物車中數據全部失效

好拉,我就總結了這些,由于剛剛接觸ASP。NET,對許多方面還認識不多,可能還有其他一些方法實現購物車,希望大家能夠給與指點,謝謝大家

 




主站蜘蛛池模板: 日韩一区二区三区视频在线观看 | 日本www在线视频 | 日韩经典欧美精品一区 | 欧美性色黄大片在线观看 | 亚洲二区在线播放 | 五月婷婷六月丁香激情 | 羞羞漫画在线阅读页面漫画入口页面弹窗无限 | 欧美专区视频 | 日本午夜精品 | 欧美一级做一a做片性视频 欧美一级做性受 | 日韩美女黄大片在线观看 | 在线亚洲精品国产波多野结衣 | 欧美在线视频免费看 | 一级做a爰片久久毛片下载 一级做a爰片久久毛片图片 | 亚洲天堂在线观看完整版 | 青青久久久 | 特级毛片黑人三人共一女 | 天天操天天操天天干 | 午夜在线精品不卡国产 | 日韩在线精品视频 | 午夜亚洲福利 | 四虎成人在线 | 特级aaa片毛片免费观看 | 亚洲免费二区 | 四虎欧美永久在线精品免费 | 四虎影视国产精品永久在线 | 日韩毛片在线观看 | 婷婷激情小说网 | 日韩一级黄色毛片 | 在线观看精品自拍视频 | 亚洲一级片免费 | 天天躁狠狠躁 | 影音先锋精品国产资源 | 色综合久久中文综合网 | 天堂最新在线资源 | 亚洲精品中文字幕乱码三区一二 | 啪啪动漫 | 亚洲成人7777 | 亚洲精品老司机综合影院 | 婷婷综合七月激情啪啪 | 午夜性福 |