十年網(wǎng)站開(kāi)發(fā)經(jīng)驗(yàn) + 多家企業(yè)客戶(hù) + 靠譜的建站團(tuán)隊(duì)
量身定制 + 運(yùn)營(yíng)維護(hù)+專(zhuān)業(yè)推廣+無(wú)憂售后,網(wǎng)站問(wèn)題一站解決
首先倆表即可 即 商品表 + 商品屬性表
成都創(chuàng)新互聯(lián)公司是一家集網(wǎng)站建設(shè),泗陽(yáng)企業(yè)網(wǎng)站建設(shè),泗陽(yáng)品牌網(wǎng)站建設(shè),網(wǎng)站定制,泗陽(yáng)網(wǎng)站建設(shè)報(bào)價(jià),網(wǎng)絡(luò)營(yíng)銷(xiāo),網(wǎng)絡(luò)優(yōu)化,泗陽(yáng)網(wǎng)站推廣為一體的創(chuàng)新建站企業(yè),幫助傳統(tǒng)企業(yè)提升企業(yè)形象加強(qiáng)企業(yè)競(jìng)爭(zhēng)力??沙浞譂M(mǎn)足這一群體相比中小企業(yè)更為豐富、高端、多元的互聯(lián)網(wǎng)需求。同時(shí)我們時(shí)刻保持專(zhuān)業(yè)、時(shí)尚、前沿,時(shí)刻以成就客戶(hù)成長(zhǎng)自我,堅(jiān)持不斷學(xué)習(xí)、思考、沉淀、凈化自己,讓我們?yōu)楦嗟钠髽I(yè)打造出實(shí)用型網(wǎng)站。
商品表和屬性表是1對(duì)多的關(guān)系
所以商品表保存一些固定屬性 比如商品名字 總庫(kù)存 剩余庫(kù)存之類(lèi)等等 具體情況而定 比如你說(shuō)的褲子外套等
屬性表則保存比如你說(shuō)的顏色 尺碼 當(dāng)前屬性下的庫(kù)存之類(lèi)的
metA?http-equiv="Content-Type"?content="text/html;?chArset=utf-8"
?php?
$skuattr=?Array
(
'7'?=?Array
(
'6'?=?'22x33',
'9'?=?'44x55'
),
'8'?=?Array
(
'12'?=?'大小號(hào)'
),
'9'?=?Array
(
'8'?=?'金屬質(zhì)',
'13'?=?'塑料',
),
'16'?=?Array
(
'14'?=?'圓形'
)
);
/*
主要思路:
這個(gè)商品有4種參數(shù),參數(shù)不同的商品算作一種類(lèi)型
那么這個(gè)商品有2x1x2x1=4?種不同類(lèi)型,要全部列出這個(gè)商品類(lèi)型需要4行
第一個(gè)參數(shù)只有2種,那么每種需要顯示2次
第二個(gè)參數(shù)只有1種,那么每種需要顯示4次
第三個(gè)參數(shù)只有2種,那么每種需要顯示2次
第四個(gè)參數(shù)只有1種,那么每種需要顯示4次
這樣排列組合的新二維數(shù)組每一行就是商品的一種類(lèi)型了
這個(gè)問(wèn)題類(lèi)似一個(gè)四位數(shù)
千位可選2個(gè)不同的數(shù),百位只能選1個(gè)數(shù)字,十位只能選2個(gè)數(shù),個(gè)位只能選1個(gè)數(shù)
有多少個(gè)不同的數(shù)字。
這里就用函數(shù)getRows()算出了,然后從每一列下手,把參數(shù)出現(xiàn)的次數(shù)填入即可
PS:
拋磚引玉了,期待更好的解法~
發(fā)現(xiàn)問(wèn)題比較好理解,只是畢竟是索引數(shù)組顯示還是不太好弄的。
不然四位數(shù)用for循環(huán)四次,表示我想不出來(lái)
*/
showTypes($skuattr);????
function?showTypes($Arrs){
$rows=getRows($Arrs);//獲取行數(shù)?即商品的不同規(guī)格組合數(shù)
echo?$rows;
$newA=array();//結(jié)果數(shù)組
$col=0;
foreach($Arrs?as?$key=$value){
$row=0;
foreach($value?as?$key2=$value2){//豎直填充
$times=count($value);
for($i=0;$i($rows/$times);$i++){//重復(fù)次數(shù)
$newA[$row][$col]=$key.':'.$key2;
$row++;
}
}
$col++;
}
/*?echo?'pre';
print_r($newA);
echo?'/pre';?*/
foreach($newA?as?$value){//顯示結(jié)果
foreach($value?as?$value){
echo?$value.';';
}
echo?'/br';
}
}
function?getRows($Arrs){
$num=1;
foreach($Arrs?as?$value){
$num=$num*count($value);
}
return?$num;
}
?
看你這個(gè)數(shù)據(jù)庫(kù)字段名,應(yīng)該是打一個(gè)用戶(hù)一次產(chǎn)生的訂單全部放在這一條記錄里了,所以有total字段,那么就需要存用戶(hù)買(mǎi)的商品的id(或與sku匹配的相關(guān)id),和購(gòu)買(mǎi)商品的數(shù)量。我覺(jué)得可以組合成類(lèi)似這樣的字符串存進(jìn)去:
1,1;2,1;3,2
其中分號(hào)分隔的不同商品,逗號(hào)分隔的是一個(gè)商品的商品id和購(gòu)買(mǎi)數(shù)量
PHP連接MYSQL數(shù)據(jù)庫(kù)代碼
2015-03-04 275人 1頁(yè)
3.8分
- ?php $mysl_server_name='localhost'; //改成自己的mysl數(shù)據(jù)庫(kù)服務(wù)器 $mysl_username='root'; //改成自己的mysl數(shù)據(jù)庫(kù)用戶(hù)名 $mysl_password='12345678'; //改成自己的mysl數(shù)據(jù)庫(kù)密碼 $mysl_database='mycounter'; //改成自己的mysl數(shù)據(jù)庫(kù)名 $conn=mysl_connect($mysl_server_name,$mysl_username,$mysl_password,$mysl_database); $sl='CREATE DATABASE mycounter DEFAULT CHARACTER SET gbk COLLATE gbk_chinese_ci; '; mysl_uery($sl); $sl='CREATE TABLE `counter` (`id` INT(255) UNSIGNED NOT NULL AUTO_INCREMENT ,`count` INT(255) UNSIGNED NOT NULL DEFAULT 0,PRIMARY KEY ( `id` ) ) TYPE = innodb;'; mysl_select_db($mysl_database,$conn); $result=mysl_uery($sl); //echo $sl; mysl_close($conn); echo uot;Hello!數(shù)據(jù)庫(kù)mycounter已經(jīng)成功建立!uot;; ? PHP連
還有不會(huì)的可以看看后盾人的視頻
這個(gè)問(wèn)題的核心點(diǎn)在于:不同商品類(lèi)別差異很大,如何設(shè)計(jì)通用的存儲(chǔ)方案?簡(jiǎn)單來(lái)說(shuō),用數(shù)據(jù)庫(kù)去存儲(chǔ)所有信息,不管橫表還是縱表,都有明顯的缺陷:橫表:同一個(gè)字段對(duì)不同商品含義不一樣,這到了后面開(kāi)發(fā)和維護(hù)是很蛋疼的縱表:一個(gè)商品的屬性分布到很多行記錄中,業(yè)務(wù)處理很麻煩,而且縱表的記錄數(shù)會(huì)非常多,性能會(huì)有問(wèn)題所以不要嘗試只用數(shù)據(jù)庫(kù)去統(tǒng)一解決這個(gè)問(wèn)題,思路擴(kuò)散一些其實(shí)就簡(jiǎn)單了:公共表:提煉商品公共的信息放到數(shù)據(jù)庫(kù),例如商品id、名稱(chēng)、發(fā)布的商家、發(fā)布日期、上架狀態(tài)擴(kuò)展表:將變化的信息放到另外一個(gè)表,可以是數(shù)據(jù)庫(kù)表,例如電腦商品一個(gè)表、服裝一個(gè)表;也可以將信息放到MongoDB或者ElasticSearch這類(lèi)文檔數(shù)據(jù)庫(kù)。搜索組件:擴(kuò)展表在全文搜索的時(shí)候不好實(shí)現(xiàn),因此需要獨(dú)立的組件負(fù)責(zé)搜索,可以用Elastic Search或者Solr來(lái)冗余一份數(shù)據(jù),用于搜索。表結(jié)構(gòu)不算復(fù)雜,因?yàn)轫?xiàng)目關(guān)系只有SPU,沒(méi)有涉及到SKU,但是可以做參考,更多的還是要根據(jù)項(xiàng)目實(shí)際情況設(shè)計(jì)。重點(diǎn)說(shuō)明一下產(chǎn)品表的SPU,Keyword字段。本來(lái)之前設(shè)計(jì)了關(guān)系表,但是發(fā)現(xiàn)在做SQL查詢(xún)時(shí)太痛苦,所以約定了一種數(shù)據(jù)存儲(chǔ)結(jié)構(gòu)(數(shù)據(jù)結(jié)構(gòu)的重要性)基于上面的基礎(chǔ),可以實(shí)現(xiàn)URL規(guī)則變化的查詢(xún),類(lèi)似京東的產(chǎn)品查詢(xún)URL變化c=1,3 指分類(lèi)層次關(guān)系ev=3_1+4_18 指SPU查詢(xún) 按約定規(guī)則轉(zhuǎn)換成字符串再進(jìn)行查詢(xún)。
!DOCTYPE html
html
head
meta charset="utf-8"
title/title
link rel="stylesheet" href="---.css"
script src="---.js"/script
/head
body
div class="container"
div class="shop"
div class="header"
input type="checkbox" class="shop-checkbox"
span class="shop-icon"/span
span class="shop-name"---/span
span class="wangwang-icon"/span
/div
div class="items"
div class="item"
divinput class="item-checkbox" type="checkbox" name="" id=""/div
div
span class="item-img"/span
/div
div class="item-name"
div----/div
div class="promotion-icons"span/spanspan/spanspan/span/div
/div
div class="sku"---/div
div class="price"
div class="price-1"---/div
div class="price-2" data-price="---"----/div
/div
div class="num-control"
span class="num-minus"-/span
input class="num" type="text" value="1"
span class="num-plus"+/span
/div
div class="item-price-total"
span¥50.13/span
/div
div class="operation"
div---/div
div---/div
/div
/div
/div
/div
div class="shop"
div class="header"
input type="checkbox" class="shop-checkbox"
span class="shop-icon"/span
span class="shop-name"---/span
span class="wangwang-icon"/span
/div
div class="items"
div class="item"
divinput class="item-checkbox" type="checkbox" name="" id=""/div
div
span class="item-img"/span
/div
div class="item-name"
div----/div
div class="promotion-icons"span/spanspan/spanspan/span/div
/div
div class="sku"---/div
div class="price"
div class="price-1"---/div
div class="price-2" data-price="---"---/div
/div
div class="num-control"
span class="num-minus"-/span
input class="num" type="text" value="1"
span class="num-plus"+/span
/div
div class="item-price-total"
span¥9.90/span
/div
div class="operation"
div移入收藏夾/div
div刪除/div
/div
/div
div class="item"
divinput class="item-checkbox" type="checkbox" name="" id=""/div
div
span class="item-img"/span
/div
div class="item-name"
div---/div
div class="promotion-icons"span/spanspan/spanspan/span/div
/div
div class="sku"---/div
div class="price"
div class="price-1"---/div
div class="price-2" data-price="---"---/div
/div
div class="num-control"
span class="num-minus"-/span
input class="num" type="text" value="1"
span class="num-plus"+/span
/div
div class="item-price-total"
span¥19.9/span
/div
div class="operation"
div移入收藏夾/div
div刪除/div
/div
/div
/div
/body
/html
.container{
width: 1000px;
margin-left: auto;
margin-right: auto;
color: #444444;
}
.header{
margin: 8px;
}
.shop-icon, .wangwang-icon, .promotion-icons span{
display:inline-block;
width: 15px;
height: 15px;
background-color: rgb(117,192,241);
}
.promotion-icons span{
margin-right: 4px;
}
.items{
border: 1px solid #ebe9e9;
}
.item{
display: flex;
margin: 8px;
}
.item-img{
width:100px;
height: 100px;
display: inline-block;
background-color: aquamarine;
margin-left: 6px;
margin-right: 6px;
}
.item-name
{
display: flex;
flex-direction: column;
justify-content: space-between;
}
.sku, .price,.item-price-total,.operation,.num-control{
margin-left: 18px;
}
.num{
width: 18px;
height: 15px;
}
.num-control{
display: flex;
align-items: baseline;
}
.num-minus,.num-plus{
width: 18px;
height: 22px;
display: inline-block;
background-color: #ebe9e9;
}
.checkout{
display: flex;
justify-content: space-between;
}
.shop{
margin-bottom: 20px;
margin-top: 30px;
}
.goods,.freight,.checkout-button{
margin-left: 15px;
}
.price-1{
text-decoration: line-through;
color: gray;
}
.check-num ,.total-price{
font-size: large;
color: red;
margin-left: 3px;
margin-right: 3px;
}
.checkout-button{
height: 30px;
width: 50px;
background-color: beige;
}
.checkout{
margin-top: 15px;
}
.item-name{
width: 25%;
}
.item-price-total{
width: 5%;
}
.sku{
width: 20%;
}
function updatePrice(){
let items = document.querySelectorAll('.item');
let totalNum = 0;
let totalPrice = 0;
items.forEach(function(item){
if(item.querySelector('.item-checkbox').checked){
let num = item.querySelector('.num').value;
totalNum = totalNum + parseInt(num);
let price = item.querySelector('.price-2').getAttribute('data-price');
totalPrice = totalPrice + parseFloat(price) * num;
}
});
document.querySelector('.check-num').innerText= totalNum;
document.querySelector('.total-price').innerText = totalPrice;
}
window.onload=function(){
let itemCheckboxes = document.querySelectorAll('.item-checkbox');
itemCheckboxes.forEach(function(itemCheckbox){
itemCheckbox.onchange = function(){
updatePrice();
}
});
let minuses = document.querySelectorAll('.num-minus');
minuses.forEach(function(minus){
minus.onclick = function(event){
let num=minus.parentElement.querySelector('.num').value;
if(parseInt(num)1)
{
minus.parentElement.querySelector('.num').value=parseInt(num)-1;
updatePrice();
}
};
});
let pluses = document.querySelectorAll('.num-plus');
pluses.forEach(function(plus){
plus.onclick = function(event){
let num=plus.parentElement.querySelector('.num').value;
plus.parentElement.querySelector('.num').value=parseInt(num)+1;
updatePrice();
}
});
}