西部数码主机 | 阿里云主机| 虚拟主机 | 服务器 | 返回乐道官网
当前位置: 主页 > php教程 > ecshop教程 >

ECSHOP按属性货号搜索

时间:2012-10-07 21:46来源:未知 作者:好模板 点击:
ECSHOP前台可按商品名称关键字、商品货号关键字等搜索商品,但不能按属性货号搜索。属性货号是ECSHOP属性库存的唯一识别号,建立属性库存后,属性货号保存在products表中,下面介绍

 ECSHOP前台可按商品名称关键字、商品货号关键字等搜索商品,但不能按属性货号搜索。属性货号是ECSHOP属性库存的唯一识别号,建立属性库存后,属性货号保存在products表中,下面介绍如何开发按属性货号关键字搜索。

编辑/search.php

一、修改搜索关键字变量,添加属性货号关键字product_sn。

  1. $keywords  ."(goods_name LIKE '%$val%' OR goods_sn LIKE '%$val%' OR keywords LIKE '%$val%' $sc_dsad)"

修改为

  1. $keywords  ."(goods_name LIKE '%$val%' OR goods_sn LIKE '%$val%' OR product_sn LIKE '%$val%' OR keywords LIKE '%$val%' $sc_dsad)"
  2. //添加按属性货号product_sn查询 

二、修改商品总数SQL语句,添加goods表与products表连接查询。

  1. /* 获得符合条件的商品总数 */ 
  2. $sql   = "SELECT COUNT(*) FROM " .$ecs->table('goods'). " AS g ". 
  3.     "WHERE g.is_delete = 0 AND g.is_on_sale = 1 AND g.is_alone_sale = 1 $attr_in ". 
  4.     "AND (( 1 " . $categories . $keywords . $brand . $min_price . $max_price . $intro . $outstock ." ) ".$tag_where." )"; 

修改为:

  1. /* 获得符合条件的商品总数 */ 
  2. $sql   = "SELECT COUNT(*) FROM " .$ecs->table('goods'). " AS g ". 
  3.     "LEFT JOIN " . $GLOBALS['ecs']->table('products') . " AS p ". 
  4.         "ON g.goods_id = p.goods_id ". 
  5.     "WHERE g.is_delete = 0 AND g.is_on_sale = 1 AND g.is_alone_sale = 1 $attr_in ". 
  6.     "AND (( 1 " . $categories . $keywords . $brand . $min_price . $max_price . $intro . $outstock ." ) ".$tag_where." )"; 

三、修改商品查询SQL语句,添加goods表与products表连接查询。


  1. /* 查询商品 */ 
  2. $sql = "SELECT g.goods_id, g.goods_name, g.market_price, g.is_new, g.is_best, g.is_hot, g.shop_price AS org_price, "
  3.             "IFNULL(mp.user_price, g.shop_price * '$_SESSION[discount]') AS shop_price, ". 
  4.             "g.promote_price, g.promote_start_date, g.promote_end_date, g.goods_thumb, g.goods_img, g.goods_brief, g.goods_type ". 
  5.         "FROM " .$ecs->table('goods'). " AS g ". 
  6.         "LEFT JOIN " . $GLOBALS['ecs']->table('member_price') . " AS mp ". 
  7.                 "ON mp.goods_id = g.goods_id AND mp.user_rank = '$_SESSION[user_rank]' ". 
  8.         "WHERE g.is_delete = 0 AND g.is_on_sale = 1 AND g.is_alone_sale = 1 $attr_in ". 
  9.             "AND (( 1 " . $categories . $keywords . $brand . $min_price . $max_price . $intro . $outstock . " ) ".$tag_where." ) " . 
  10.         "ORDER BY $sort $order"; 

修改为:

  1. /* 查询商品 */ 
  2. $sql = "SELECT g.goods_id, g.goods_name, g.market_price, g.is_new, g.is_best, g.is_hot, g.shop_price AS org_price, "
  3.             "IFNULL(mp.user_price, g.shop_price * '$_SESSION[discount]') AS shop_price, ". 
  4.             "g.promote_price, g.promote_start_date, g.promote_end_date, g.goods_thumb, g.goods_img, g.goods_brief, g.goods_type ". 
  5.         "FROM " .$ecs->table('goods'). " AS g ". 
  6.         "LEFT JOIN " . $GLOBALS['ecs']->table('member_price') . " AS mp ". 
  7.                 "ON mp.goods_id = g.goods_id AND mp.user_rank = '$_SESSION[user_rank]' ". 
  8.         "LEFT JOIN " . $GLOBALS['ecs']->table('products') . " AS p ". 
  9.                 "ON g.goods_id = p.goods_id ". 
  10.         "WHERE g.is_delete = 0 AND g.is_on_sale = 1 AND g.is_alone_sale = 1 $attr_in ". 
  11.             "AND (( 1 " . $categories . $keywords . $brand . $min_price . $max_price . $intro . $outstock . " ) ".$tag_where." ) " . 
  12.         "ORDER BY $sort $order"; 

 

(责任编辑:好模板)
顶一下
(5)
71.4%
踩一下
(2)
28.6%
------分隔线----------------------------