ecshop

关注公众号 jb51net

关闭
CMS教程 > ecshop >

ecshop二次开发之表结构分析

脚本之家

本文实例讲述了ecshop二次开发之表结构分析。分享给大家供大家参考。具体如下:

ecshop二次开发首先要弄清楚各个数据库表的内容和数据库表之间的关系,这样有助于ecshop二次开发!

下面我就介绍一下 ecshop数据库表的结构

Ecs_account_log--用户帐号情况记录表,包括资金和积分等
(自增ID 号,用户登录后保存在session中的id号,跟users表中的user_id对应,用户该笔记录的余额,被冻结的资金,等级积分,跟消费积分是分开的,消费积分,跟等级积分是分开的,该笔操作发生
的时间,该笔操作的备注,一般是,充值或者提现。也可是是管理员后台写的任何在备注,操作类型,0为充值,1为提现,2为管理员调节,99为其他类型)

ecs_ad--广告列表配置表,包括站内站外的图片,文字,flash,代码广告
(自增ID号,0,站外广告;从1开始代表的是该广告所处的广告位,同表ad_position中的字段position_id的值,广告类型,0,图片;1,flash;2,代码;3,文字,该条广告记录的广告名称,广告链接地址
,广告链接的表现,文字广告就是文字或图片和flash就是它们的地址,代码广告就是代码内容,广告开始时间,广告结束时间,广告联系人,广告联系人的邮箱,广告联系人的电话,该广告点击数,该
广告是否关闭,1,开启;0,关闭;关闭后广告将不再有效,直至重新开启)

`ecs_ad_position`---广告位置配置表
(广告位自增id,广告位名称,广告位宽度,广告位高度,广告位描述,广告位模板代码)

`ecs_admin_action`-- 管理员权限列表树
(自增ID号,该id项的父id,对应本表的action_id字段,代表权限的英文字符串,对应汉文在语言文件中,如果该字段有某个字符串,就表示有该权限)

`ecs_admin_log`----管理员操作日志表
(自增ID号,写日志时间,该日志所记录的操作者id,同ecs_admin_user的user_id,管理操作内容,管理者登录ip);

`ecs_admin_message`--- 管理员留言记录表
(自增ID号,发送该留言的管理员id,同ecs_admin_user的user_id,接收消息的管理员id,同 ecs_admin_user的user_id,如果是给多个管理员发送,则同一个消息给每个管理员id发送一条,留言发送时间,留言阅读时间,留言是否阅读,1,已阅读;0,未阅读,留言是否已经是否已经被删除,1,已删除;0,未删除,留言的主题,留言的内容)

`ecs_admin_user`(自增ID号,管理员代号,管理员登录名,管理员邮箱,管理员登录秘密加密串,管理员添加时间,管理员最后一次登录时间,管理员最后一次登录ip,管理员管理权限列表,管理员导航栏配置项,该管理员负责的办事处的id,同ecs_agency的agency_id字段。如果管理员没负责办事处,则此处为0,记事本记录的数据)管理员资料权限列表

`ecs_adsense`---广告点击率统计表
(广告代号,-1是站外广告,如果是站内广告则为ecs_ad的ad_id,页面来源,点击率)

`ecs_affiliate_log`()分成相关的表,还没研究透

`ecs_agency`--办事处信息
(办事处ID,办事处名字,办事处描述)

`ecs_area_region`(配送区域的id号,等同于ecs_shipping_area的shipping_area_id的值,地区列表,等同于ecs_region的 region_id)记录表ecs_shipping_area中的shipping_area_name的地区名包括ecs_region中的城市

`ecs_article`(自增ID号,该文章的分类,同ecs_article_cat的cat_id,如果不在,将自动成为保留类型而不能删除,文章题目,文章内容,文章作者,文章作者的email,文章的关键字,文章类型,0,普通;1,置顶;2和大于2的,为保留文章,保留文章不能删除,是否显示。1,显示;0,不显示,文章添加时间,上传文件或者外部文件的url,0,正常;当该字段为1或者2时,会在文章最后添加一个链接“相关下载”,连接地址等于file_url的值;但程序在此处有bug,该文章标题所引用的连接,如果该项有值将不能显示文章内容,即该表中content的值)文章内容表

`ecs_article_cat`---- 文章分类信息表
cat代表catgory
(自增ID号,分类名称,分类类型;1,普通分类;2,系统分类;3,网店信息;4,帮助分类;5,网店帮助,分类关键字,分类说明文字,分类显示顺序,是否在导航栏显示;0,否;1,是,父节点
id,取值于该表cat_id字段)

`ecs_attribute`--- 商品类型属性表,该表记录的是每个商品类型的所有属性的配置情况,具体的商品的属性不在该表(自增ID号,商品类型,同 ecs_goods_type的cat_id,属性名称,当添加商品时,该属性的添加类别;0,为手工输入;1,为选择输入;2,为多行文本输入,属性是否多选;0,否;1,是;如果可以多选,则可以自定义属性,并且可以根据值的不同定不同的价,如果attr_input_type为1,即选择输入,则 attr_name对应的值的取值就是该字段的值,属性是否可以检索;0,不需要检索;1,关键字检索;2,范围检索;该属性应该是如果检索的话,可以通过该属性找到有该属性的商品,属性显示的顺序,数字越大越靠前,如果数字一样则按id顺序,是否关联;0,不关联;1,关联;如果关联,那么用户在购买该商品时,具有有该属性相同值的商品将被推荐给用户,属性分组,相同的为一个属性组。该值应该取自ecs_goods_type的attr_group的值的顺序)

`ecs_auction_log`---拍卖出价记录信息表
(自增ID号,拍卖活动的id,取值于 ecs_goods_activity的act_id字段,出价的用户id,取值于ecs_users的user_id,出价价格,出价时间)

`ecs_auto_manage`---- 处理文章,商品自动上下线的计划任务列表;需要安装计划任务插件才有效(如果是商品就是ecs_goods的goods_id,如果是文章就是 ecs_article的article_id,goods是商品,article是文章,上线时间,下线时间)

`ecs_bonus_type`---红包类型表;(红包类型流水号,红包名称,红包所值的金额,红包发送类型.0,按用户如会员等级, 会员名称发放;1,按商品类别发送;2,按订单金额所达到的额度发送;3,线下发送,如果是按金额发送红包,该项是最小金额.即只要购买超过该金额的商品都可以领到红包,红包发送的开始时间,红包发送的结束时间, 红包可以使用的开始时间, 红包可以使用的结束时间,可以使用该红包的商品的最低价格.即只要达到该价格的商品才可以使用红包)

`ecs_booking_goods`(自增ID号,登记该缺货记录的用户的id,取值ecs_users的user_id,页面填的用户的email,默认取值于ecs_users的 email,页面填的用户的姓名,默认取值于ecs_users的consignee,页面填的用户的电话,默认取值于ecs_users的tel,缺货登记的商品id,取值于ecs_goods的 goods_id,缺货登记时留的订购描述,订购数量,缺货登记的时间,是否已经被处理,处理该缺货登记的管理员用户名,取值于session,该 session取值于ecs_admin_user的user_name,处理的时间,处理时管理员留的备注)缺货登记的订购和处理记录表

ecs_brand`--- 商品品牌信息记录表
(自增ID号,品牌名称,上传的该品牌公司logo图片,品牌描述,品牌的网址,品牌在前台页面的显示顺序,数字越大越靠后,该品牌是否显示,0,否;1,显示)
`ecs_card`(自增ID号,贺卡名称,贺卡图纸的名称,贺卡所需费用,订单达到该字段的值后使用此贺卡免费,贺卡的描述)贺卡的配置的信息

`ecs_cart`--购物车购物信息记录表
(自增ID号,用户登录id,取自 session,登录的sessionid,如果该用户退出,该sessionid对应的购物车中的所有记录都将被删除,商品的id,取自表goods的 goods_id,商品的货号,取自表goods的goods_sn,商品的名称,取自表goods的goods_name,商品的市场价,取自表 goods的market_price,商品的本店价,取自表goods的shop_price,商品的购买数量,在购物车时,实际库存不减少,商品的属性,中括号里是该属性特有的价格,取自ecs_goods的is_real,商品的扩展属性,取自ecs_goods的extension_code,该商品的父商品id,没有该值为0,有的话那该商品就是该id的配件,购物车商品类型,0,普通;1,团够;2,拍卖;3,夺宝奇兵,是否是赠品,0,否;其他,是参加优惠活动的id,取值于ecs_favourable_activity 的act_id,该商品的属性的id,取自goods_attr的goods_attr_id,如果有多个,只记录了最后一个,可能是个bug)

`ecs_category`-- 商品分类表,记录商品分类信息(自增ID号,分类名称,分类的关键字,可能是为了搜索,分类描述,该分类的父id,取值于该表的cat_id字段,该分类在页面显示的顺序,数字越大顺序越靠后;同数字,id在前的先显示,不确定字段,按名字和表设计猜,应该是该分类的单独模板文件的名字,该分类的计量单位,是否显示在导航栏,0,不;1,显示在导航栏,该分类的单独的样式表的包括文件名部分的文件路径,是否在前台页面显示,1,显示;0,不显示,该分类的最高和最低价之间的价格分级,当大于1时,会根据最大最小价格区间分成区间,会在页面显示价格范围,如 0-300,300-600,600-900这种,如果该字段有值,则该分类将还会按照该值对应在表goods_attr的goods_attr_id所对应的属性筛选,如,封面颜色下有红,黑分类筛选)

`ecs_collect_goods`---会员收藏商品的记录列表,一条记录一个收藏商品(收藏记录的自增id,该条收藏记录的会员id,取值于ecs_users的user_id,收藏的商品id,取值于ecs_goods的 goods_id,收藏时间,是否关注该收藏商品,1,是;0,否)

`ecs_comment`------用户对文章和产品的评论列表(用户评论的自增id,用户评论的类型;0,评论的是商品;1,评论的是文章,文章或者商品的id,文章对应的是 ecs_article 的article_id;商品对应的是ecs_goods的goods_id,评论时提交的email地址,默认取的ecs_users的email,评论该文章或商品的人的名称,取值ecs_users的user_name,评论的内容,该文章或者商品的星级;只有1到5星;由数字代替;其中5是代表5 星,评论的时间,评论时的用户ip,是否被管理员批准显示,1,是;0,未批准显示,评论的父节点;取值该表的comment_id字段;如果该字段为 0,则是一个普通评论,否则该条评论就是该字段的值所对应的评论的回复,发表该评论的用户的用户id,取值于ecs_users的user_id)

ecs_crons(自增ID号,该插件文件在相应路径下的不包括''.php''部分的文件名,运行该插件将通过该字段的值寻找将运行的文件,计划任务的名称,计划人物的描述,应该是用了设置计划任务执行的顺序的,即当同时触发2个任务时先执行哪一个,如果一样应该是id在前的先执行暂不确定,对每次处理的数据的数量的值,类型,名称序列化;比如删几天的日志,每次执行几个商品或文章的处理,'该计划任务上次被执行的时间', '该计划任务下次被执行的时间', '如果该字段有值,则计划任务将在每月的这一天执行该计划人物', '如果该字段有值,则计划任务将在每周的这一天执行该计划人物', '如果该字段有值,则该计划任务将在每天的这个小时段执行该计划任务', '如果该字段有值,则该计划任务将在每小时的这个分钟段执行该计划任务,该字段的值可以多个,用空格间隔', '该计划任务是否开启;0,关闭;1,开启', '执行后是否关闭,这个关闭的意思还得再研究下', '允许运行该计划人物的服务器ip', '运行触发该计划人物的文件列表可多个值,为空代表所有许可的文件都可以')'计划任务插件安装配置信息'

表的结构 `ecs_collect_goods`

CREATE TABLE IF NOT EXISTS `ecs_collect_goods` (
`rec_id` mediumint(8) unsigned NOT NULL AUTO_INCREMENT COMMENT '收藏记录的自增id',
`user_id` mediumint(8) unsigned NOT NULL DEFAULT '0' COMMENT '该条收藏记录的会员id,取值于ecs_users的user_id',
`goods_id` mediumint(8) unsigned NOT NULL DEFAULT '0' COMMENT '收藏的商品id,取值于ecs_goods的goods_id',
`add_time` int(11) unsigned NOT NULL DEFAULT '0' COMMENT '收藏时间',
`is_attention` tinyint(1) NOT NULL DEFAULT '0' COMMENT '是否关注该收藏商品,1,是;0,否',
PRIMARY KEY (`rec_id`),
KEY `user_id` (`user_id`),
KEY `goods_id` (`goods_id`),
KEY `is_attention` (`is_attention`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8 ROW_FORMAT=FIXED COMMENT='会员收藏商品的记录列表,一条记录一个收藏商品' AUTO_INCREMENT=3 ;

– 表的结构 `ecs_comment`

CREATE TABLE IF NOT EXISTS `ecs_comment` (
`comment_id` int(10) unsigned NOT NULL AUTO_INCREMENT COMMENT '用户评论的自增id',
`comment_type` tinyint(3) unsigned NOT NULL DEFAULT '0' COMMENT '用户评论的类型;0,评论的是商品;1,评论的是文章',
`id_value` mediumint(8) unsigned NOT NULL DEFAULT '0' COMMENT '文章或者商品的id,文章对应的是ecs_article 的article_id;商品对应的是ecs_goods的goods_id',
`email` varchar(60) NOT NULL COMMENT '评论时提交的email地址,默认取的ecs_users的email',
`user_name` varchar(60) NOT NULL COMMENT '评论该文章或商品的人的名称,取值ecs_users的user_name',
`content` text NOT NULL COMMENT '评论的内容',
`comment_rank` tinyint(1) unsigned NOT NULL DEFAULT '0' COMMENT '该文章或者商品的星级;只有1到5星;由数字代替;其中5是代表5星',
`add_time` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '评论的时间',
`ip_address` varchar(15) NOT NULL COMMENT '评论时的用户ip',
`status` tinyint(3) unsigned NOT NULL DEFAULT '0' COMMENT '是否被管理员批准显示,1,是;0,未批准显示',
`parent_id` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '评论的父节点;取值该表的comment_id字段;如果该字段为0,则是一个普通评论,否则该条评论就是该字段的值所对应的评论的回
复',
`user_id` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '发表该评论的用户的用户id,取值于ecs_users的user_id',
PRIMARY KEY (`comment_id`),
KEY `parent_id` (`parent_id`),
KEY `id_value` (`id_value`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8 ROW_FORMAT=DYNAMIC COMMENT='用户对文章和产品的评论列表' AUTO_INCREMENT=5 ;

– 表的结构 `ecs_crons`

CREATE TABLE IF NOT EXISTS `ecs_crons` (
`cron_id` tinyint(3) unsigned NOT NULL AUTO_INCREMENT COMMENT '自增ID号',
`cron_code` varchar(20) NOT NULL COMMENT '该插件文件在相应路径下的不包括”.php”部分的文件名,运行该插件将通过该字段的值寻找将运行的文件',
`cron_name` varchar(120) NOT NULL COMMENT '计划任务的名称',
`cron_desc` text COMMENT '计划人物的描述',
`cron_order` tinyint(3) unsigned NOT NULL DEFAULT '0' COMMENT '应该是用了设置计划任务执行的顺序的,即当同时触发2个任务时先执行哪一个,如果一样应该是id在前的先执行暂不确定',
`cron_config` text NOT NULL COMMENT '对每次处理的数据的数量的值,类型,名称序列化;比如删几天的日志,每次执行几个商品或文章的处理',
`thistime` int(10) NOT NULL DEFAULT '0' COMMENT '该计划任务上次被执行的时间',
`nextime` int(10) NOT NULL COMMENT '该计划任务下次被执行的时间',
`day` tinyint(2) NOT NULL COMMENT '如果该字段有值,则计划任务将在每月的这一天执行该计划人物',
`week` varchar(1) NOT NULL COMMENT '如果该字段有值,则计划任务将在每周的这一天执行该计划人物',
`hour` varchar(2) NOT NULL COMMENT '如果该字段有值,则该计划任务将在每天的这个小时段执行该计划任务',
`minute` varchar(255) NOT NULL COMMENT '如果该字段有值,则该计划任务将在每小时的这个分钟段执行该计划任务,该字段的值可以多个,用空格间隔',
`enable` tinyint(1) NOT NULL DEFAULT '1' COMMENT '该计划任务是否开启;0,关闭;1,开启',
`run_once` tinyint(1) NOT NULL DEFAULT '0' COMMENT '执行后是否关闭,这个关闭的意思还得再研究下',
`allow_ip` varchar(100) NOT NULL COMMENT '允许运行该计划人物的服务器ip',
`alow_files` varchar(255) NOT NULL COMMENT '运行触发该计划人物的文件列表可多个值,为空代表所有许可的文件都可以',
PRIMARY KEY (`cron_id`),
KEY `nextime` (`nextime`),
KEY `enable` (`enable`),
KEY `cron_code` (`cron_code`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8 ROW_FORMAT=DYNAMIC COMMENT='计划任务插件安装配置信息' AUTO_INCREMENT=4 ;

– 表的结构 `ecs_email_list`

CREATE TABLE IF NOT EXISTS `ecs_email_list` (
`id` mediumint(8) NOT NULL AUTO_INCREMENT COMMENT '邮件订阅的自增id',
`email` varchar(60) NOT NULL COMMENT '邮件订阅所填的邮箱地址',
`stat` tinyint(1) NOT NULL DEFAULT '0' COMMENT '是否确认,可以用户确认也可以管理员确认;0,未确认;1,已确认',
`hash` varchar(10) NOT NULL COMMENT '邮箱确认的验证码,系统生成后发送到用户邮箱,用户验证激活时通过该值判断是否合法;主要用来防止非法验证邮箱',
PRIMARY KEY (`id`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8 ROW_FORMAT=DYNAMIC COMMENT='增加电子杂志订阅表' AUTO_INCREMENT=5 ;
– 表的结构 `ecs_email_sendlist`
CREATE TABLE IF NOT EXISTS `ecs_email_sendlist` (
`id` mediumint(8) NOT NULL AUTO_INCREMENT COMMENT '邮件发送队列自增id',
`email` varchar(100) NOT NULL COMMENT '该邮件将要发送到的邮箱地址',
`template_id` mediumint(8) NOT NULL COMMENT '该邮件的模板id,取值于ecs_mail_templates的template_id',
`email_content` text NOT NULL COMMENT '邮件发送的内容',
`error` tinyint(1) NOT NULL DEFAULT '0' COMMENT '错误次数,不知干什么用的,猜应该是发送邮件的失败记录',
`pri` tinyint(10) NOT NULL COMMENT '该邮件发送的优先级;0,普通;1,高',
`last_send` int(10) NOT NULL COMMENT '上一次发送的时间',
PRIMARY KEY (`id`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8 ROW_FORMAT=DYNAMIC COMMENT='增加发送队列表' AUTO_INCREMENT=18 ;

– 表的结构 `ecs_error_log`

CREATE TABLE IF NOT EXISTS `ecs_error_log` (
`id` int(10) NOT NULL AUTO_INCREMENT COMMENT '计划任务错误自增id',
`info` varchar(255) NOT NULL COMMENT '错误详细信息',
`file` varchar(100) NOT NULL COMMENT '产生错误的执行文件的绝对路径',
`time` int(10) NOT NULL COMMENT '错误发生的时间',
PRIMARY KEY (`id`),
KEY `time` (`time`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8 ROW_FORMAT=DYNAMIC COMMENT='该表用来记录页面触发计划任务时失败所产生的错误,从程序来看,目前主要是记录某计划任务所对应的插件文
件不存在的错误' AUTO_INCREMENT=1 ;

– 表的结构 `ecs_favourable_activity`

CREATE TABLE IF NOT EXISTS `ecs_favourable_activity` (
`act_id` smallint(5) unsigned NOT NULL AUTO_INCREMENT COMMENT '优惠活动的自增id',
`act_name` varchar(255) NOT NULL COMMENT '优惠活动的活动名称',
`start_time` int(10) unsigned NOT NULL COMMENT '活动的开始时间',
`end_time` int(10) unsigned NOT NULL COMMENT '活动的结束时间',
`user_rank` varchar(255) NOT NULL COMMENT '可以参加活动的用户信息,取值于ecs_user_rank的rank_id;其中0是非会员,其他是相应的会员等级;多个值用逗号分隔',
`act_range` tinyint(3) unsigned NOT NULL COMMENT '优惠范围;0,全部商品;1,按分类;2,按品牌;3,按商品',
`act_range_ext` varchar(255) NOT NULL COMMENT '根据优惠活动范围的不同,该处意义不同;但是都是优惠范围的约束;如,如果是商品,该处是商品的id,如果是品牌,该处是品牌的id',
`min_amount` decimal(10,2) unsigned NOT NULL COMMENT '订单达到金额下限,才参加活动',
`max_amount` decimal(10,2) unsigned NOT NULL COMMENT '参加活动的订单金额下限,0,表示没有上限',
`act_type` tinyint(3) unsigned NOT NULL COMMENT '参加活动的优惠方式;0,送赠品或优惠购买;1,现金减免;价格打折优惠',
`act_type_ext` decimal(10,2) unsigned NOT NULL COMMENT '如果是送赠品,该处是允许的最大数量,0,无数量限制;现今减免,则是减免金额,单位元;打折,是折扣值,100算,8折就是80',
`gift` text NOT NULL COMMENT '如果有特惠商品,这里是序列化后的特惠商品的id,name,price信息;取值于ecs_goods的goods_id,goods_name,价格是添加活动时填写的',
`sort_order` tinyint(3) unsigned NOT NULL COMMENT '活动在优惠活动页面显示的先后顺序,数字越大越靠后',
PRIMARY KEY (`act_id`),
KEY `act_name` (`act_name`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8 ROW_FORMAT=DYNAMIC COMMENT='优惠活动的配置信息,优惠活动包括送礼,减免,打折' AUTO_INCREMENT=5 ;

– 表的结构 `ecs_feedback`

CREATE TABLE IF NOT EXISTS `ecs_feedback` (
`msg_id` mediumint(8) unsigned NOT NULL AUTO_INCREMENT COMMENT '反馈信息自增id',
`parent_id` mediumint(8) unsigned NOT NULL DEFAULT '0' COMMENT '父节点,取自该表msg_id;反馈该值为0;回复反馈为节点id',
`user_id` mediumint(8) unsigned NOT NULL DEFAULT '0' COMMENT '反馈的用户的id',
`user_name` varchar(60) NOT NULL COMMENT '反馈的用户的用户名',
`user_email` varchar(60) NOT NULL COMMENT '反馈的用户的邮箱',
`msg_title` varchar(200) NOT NULL COMMENT '反馈的标题,回复为reply',
`msg_type` tinyint(1) unsigned NOT NULL DEFAULT '0' COMMENT '反馈的类型,0,留言;1,投诉;2,询问;3,售后;4,求购',
`msg_content` text NOT NULL COMMENT '反馈的内容',
`msg_time` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '反馈的时间',
`message_img` varchar(255) NOT NULL DEFAULT '0' COMMENT '用户上传的文件的地址',
`order_id` int(11) unsigned NOT NULL DEFAULT '0' COMMENT '该反馈关联的订单id,由用户提交,取值于 ecs_order_info的order_id;0,为无匹配;',
PRIMARY KEY (`msg_id`),
KEY `user_id` (`user_id`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8 ROW_FORMAT=DYNAMIC COMMENT='用户反馈信息表,包括留言,投诉,咨询等' AUTO_INCREMENT=7 ;

– 表的结构 `ecs_friend_link`

CREATE TABLE IF NOT EXISTS `ecs_friend_link` (
`link_id` smallint(5) unsigned NOT NULL AUTO_INCREMENT COMMENT '友情链接自增id',
`link_name` varchar(255) NOT NULL COMMENT '友情链接的名称,img的alt的内容;',
`link_url` varchar(255) NOT NULL COMMENT '友情链接网站的链接地址',
`link_logo` varchar(255) NOT NULL COMMENT '友情链接的logo',
`show_order` tinyint(3) unsigned NOT NULL DEFAULT '0' COMMENT '在页面的显示顺序',
PRIMARY KEY (`link_id`),
KEY `show_order` (`show_order`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8 ROW_FORMAT=DYNAMIC COMMENT='友情链接配置信息表' AUTO_INCREMENT=3 ;

– 表的结构 `ecs_goods`

CREATE TABLE IF NOT EXISTS `ecs_goods` (
`goods_id` mediumint(8) unsigned NOT NULL AUTO_INCREMENT COMMENT '商品的自增id',
`cat_id` smallint(5) unsigned NOT NULL DEFAULT '0' COMMENT '商品所属商品分类id,取值ecs_category的cat_id',
`goods_sn` varchar(60) NOT NULL COMMENT '商品的唯一货号',
`goods_name` varchar(120) NOT NULL COMMENT '商品的名称',
`goods_name_style` varchar(60) NOT NULL DEFAULT '+' COMMENT '商品名称显示的样式;包括颜色和字体样式;格式如#ff00ff+strong',
`click_count` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '商品点击数',
`brand_id` smallint(5) unsigned NOT NULL DEFAULT '0' COMMENT '品牌id,取值于ecs_brand 的brand_id',
`provider_name` varchar(100) NOT NULL COMMENT '供货人的名称,程序还没实现该功能',
`goods_number` smallint(5) unsigned NOT NULL DEFAULT '0' COMMENT '商品库存数量',
`goods_weight` decimal(10,3) unsigned NOT NULL DEFAULT '0.000' COMMENT '商品的重量,以千克为单位',
`market_price` decimal(10,2) unsigned NOT NULL DEFAULT '0.00' COMMENT '市场售价',
`shop_price` decimal(10,2) unsigned NOT NULL DEFAULT '0.00' COMMENT '本店售价',
`promote_price` decimal(10,2) unsigned NOT NULL DEFAULT '0.00' COMMENT '促销价格',
`promote_start_date` int(11) unsigned NOT NULL DEFAULT '0' COMMENT '促销价格开始日期',
`promote_end_date` int(11) unsigned NOT NULL DEFAULT '0' COMMENT '促销价结束日期',
`warn_number` tinyint(3) unsigned NOT NULL DEFAULT '1' COMMENT '商品报警数量',
`keywords` varchar(255) NOT NULL COMMENT '商品关键字,放在商品页的关键字中,为搜索引擎收录用',
`goods_brief` varchar(255) NOT NULL COMMENT '商品的简短描述',
`goods_desc` text NOT NULL COMMENT '商品的详细描述',
`goods_thumb` varchar(255) NOT NULL COMMENT '商品在前台显示的微缩图片,如在分类筛选时显示的小图片',
`goods_img` varchar(255) NOT NULL COMMENT '商品的实际大小图片,如进入该商品页时介绍商品属性所显示的大图片',
`original_img` varchar(255) NOT NULL COMMENT '应该是上传的商品的原始图片',
`is_real` tinyint(3) unsigned NOT NULL DEFAULT '1' COMMENT '是否是实物,1,是;0,否;比如虚拟卡就为0,不是实物',
`extension_code` varchar(30) NOT NULL COMMENT '商品的扩展属性,比如像虚拟卡',
`is_on_sale` tinyint(1) unsigned NOT NULL DEFAULT '1' COMMENT '该商品是否开放销售,1,是;0,否',
`is_alone_sale` tinyint(1) unsigned NOT NULL DEFAULT '1' COMMENT '是否能单独销售,1,是;0,否;如果不能单独销售,则只能作为某商品的配件或者赠品销售',
`integral` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '购买该商品可以使用的积分数量,估计应该是用积分代替金额消费;但程序好像还没有实现该功能',
`add_time` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '商品的添加时间',
`sort_order` smallint(4) unsigned NOT NULL DEFAULT '0' COMMENT '应该是商品的显示顺序,不过该版程序中没实现该功能',
`is_delete` tinyint(1) unsigned NOT NULL DEFAULT '0' COMMENT '商品是否已经删除,0,否;1,已删除',
`is_best` tinyint(1) unsigned NOT NULL DEFAULT '0' COMMENT '是否是精品;0,否;1,是',
`is_new` tinyint(1) unsigned NOT NULL DEFAULT '0' COMMENT '是否是新品;0,否;1,是',
`is_hot` tinyint(1) unsigned NOT NULL DEFAULT '0' COMMENT '是否热销,0,否;1,是',
`is_promote` tinyint(1) unsigned NOT NULL DEFAULT '0' COMMENT '是否特价促销;0,否;1,是',
`bonus_type_id` tinyint(3) unsigned NOT NULL DEFAULT '0' COMMENT '购买该商品所能领到的红包类型',
`last_update` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '最近一次更新商品配置的时间',
`goods_type` smallint(5) unsigned NOT NULL DEFAULT '0' COMMENT '商品所属类型id,取值表goods_type的cat_id',
`seller_note` varchar(255) NOT NULL COMMENT '商品的商家备注,仅商家可见',
`give_integral` int(11) NOT NULL DEFAULT '-1' COMMENT '购买该商品时每笔成功交易赠送的积分数量。',
PRIMARY KEY (`goods_id`),
KEY `goods_sn` (`goods_sn`),
KEY `cat_id` (`cat_id`),
KEY `last_update` (`last_update`),
KEY `brand_id` (`brand_id`),
KEY `goods_weight` (`goods_weight`),
KEY `promote_end_date` (`promote_end_date`),
KEY `promote_start_date` (`promote_start_date`),
KEY `goods_number` (`goods_number`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8 ROW_FORMAT=DYNAMIC COMMENT='商品表' AUTO_INCREMENT=35 ;

– 表的结构 `ecs_goods_activity`

CREATE TABLE IF NOT EXISTS `ecs_goods_activity` (
`act_id` mediumint(8) unsigned NOT NULL AUTO_INCREMENT COMMENT '自增ID号',
`act_name` varchar(255) NOT NULL COMMENT '促销活动的名称',
`act_desc` text NOT NULL COMMENT '促销活动的描述',
`act_type` tinyint(3) unsigned NOT NULL,
`goods_id` mediumint(8) unsigned NOT NULL COMMENT '参加活动的id,取值于ecs_goods的goods_id',
`goods_name` varchar(255) NOT NULL COMMENT '商品的名称,取值于ecs_goods的goods_id',
`start_time` int(10) unsigned NOT NULL COMMENT '活动开始时间',
`end_time` int(10) unsigned NOT NULL COMMENT '活动结束时间',
`is_finished` tinyint(3) unsigned NOT NULL COMMENT '活动是否结束,0,结束;1,未结束',
`ext_info` text NOT NULL COMMENT '序列化后的促销活动的配置信息,包括最低价,最高价,出价幅度,保证金等',
PRIMARY KEY (`act_id`),
KEY `act_name` (`act_name`,`act_type`,`goods_id`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8 ROW_FORMAT=DYNAMIC COMMENT='拍卖活动和夺宝奇兵活动配置信息表' AUTO_INCREMENT=5 ;

– 表的结构 `ecs_goods_article`

CREATE TABLE IF NOT EXISTS `ecs_goods_article` (
`goods_id` mediumint(8) unsigned NOT NULL DEFAULT '0' COMMENT '商品id,取自ecs_goods的goods_id',
`article_id` mediumint(8) unsigned NOT NULL DEFAULT '0' COMMENT '文章id,取自 ecs_article 的article_id',
`admin_id` tinyint(3) unsigned NOT NULL DEFAULT '0' COMMENT '猜想是管理员的id,但是程序中似乎没有提及到',
PRIMARY KEY (`goods_id`,`article_id`,`admin_id`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8 ROW_FORMAT=FIXED COMMENT='文章关联产品表,即文章中提到的相关产品';
– 表的结构 `ecs_goods_attr`
CREATE TABLE IF NOT EXISTS `ecs_goods_attr` (
`goods_attr_id` int(10) unsigned NOT NULL AUTO_INCREMENT COMMENT '自增ID号',
`goods_id` mediumint(8) unsigned NOT NULL DEFAULT '0' COMMENT '该具体属性属于的商品,取值于ecs_goods的goods_id',
`attr_id` smallint(5) unsigned NOT NULL DEFAULT '0' COMMENT '该具体属性属于的属性类型的id,取自ecs_attribute 的attr_id',
`attr_value` text NOT NULL COMMENT '该具体属性的值',
`attr_price` varchar(255) NOT NULL COMMENT '该属性对应在商品原价格上要加的价格',
PRIMARY KEY (`goods_attr_id`),
KEY `goods_id` (`goods_id`),
KEY `attr_id` (`attr_id`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8 ROW_FORMAT=DYNAMIC COMMENT='具体商品的属性表' AUTO_INCREMENT=62 ;

– 表的结构 `ecs_goods_cat`

CREATE TABLE IF NOT EXISTS `ecs_goods_cat` (
`goods_id` mediumint(8) unsigned NOT NULL DEFAULT '0' COMMENT '商品id',
`cat_id` smallint(5) unsigned NOT NULL DEFAULT '0' COMMENT '商品分类id',
PRIMARY KEY (`goods_id`,`cat_id`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8 ROW_FORMAT=FIXED COMMENT='商品的扩展分类';

– 表的结构 `ecs_goods_gallery`

CREATE TABLE IF NOT EXISTS `ecs_goods_gallery` (
`img_id` mediumint(8) unsigned NOT NULL AUTO_INCREMENT COMMENT '商品相册自增id',
`goods_id` mediumint(8) unsigned NOT NULL DEFAULT '0' COMMENT '图片属于商品的id',
`img_url` varchar(255) NOT NULL COMMENT '实际图片url',
`img_desc` varchar(255) NOT NULL COMMENT '图片说明信息',
`thumb_url` varchar(255) NOT NULL COMMENT '微缩图片url',
`img_original` varchar(255) NOT NULL COMMENT '根据名字猜,应该是上传的图片文件的最原始的文件的url',
PRIMARY KEY (`img_id`),
KEY `goods_id` (`goods_id`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8 ROW_FORMAT=DYNAMIC COMMENT='商品相册表,只出现在页面的商品相册中' AUTO_INCREMENT=23 ;

– 表的结构 `ecs_booking_goods`

CREATE TABLE IF NOT EXISTS `ecs_booking_goods` (
`rec_id` mediumint(8) unsigned NOT NULL AUTO_INCREMENT COMMENT '自增ID号',
`user_id` mediumint(8) unsigned NOT NULL DEFAULT '0' COMMENT '登记该缺货记录的用户的id,取值ecs_users的user_id',
`email` varchar(60) NOT NULL COMMENT '页面填的用户的email,默认取值于ecs_users的email',
`link_man` varchar(60) NOT NULL COMMENT '页面填的用户的姓名,默认取值于ecs_users的consignee ',
`tel` varchar(60) NOT NULL COMMENT '页面填的用户的电话,默认取值于ecs_users的tel',
`goods_id` mediumint(8) unsigned NOT NULL DEFAULT '0' COMMENT '缺货登记的商品id,取值于ecs_goods的 goods_id',
`goods_desc` varchar(255) NOT NULL COMMENT '缺货登记时留的订购描述',
`goods_number` smallint(5) unsigned NOT NULL DEFAULT '0' COMMENT '订购数量',
`booking_time` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '缺货登记的时间',
`is_dispose` tinyint(1) unsigned NOT NULL DEFAULT '0' COMMENT '是否已经被处理',
`dispose_user` varchar(30) NOT NULL COMMENT '处理该缺货登记的管理员用户名,取值于session,该session取值于ecs_admin_user的user_name',
`dispose_time` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '处理的时间',
`dispose_note` varchar(255) NOT NULL COMMENT '处理时管理员留的备注',
PRIMARY KEY (`rec_id`),
KEY `user_id` (`user_id`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8 ROW_FORMAT=DYNAMIC COMMENT=' 缺货登记的订购和处理记录表' AUTO_INCREMENT=4 ;

- 表的结构 `ecs_brand`

CREATE TABLE IF NOT EXISTS `ecs_brand` (
`brand_id` smallint(5) unsigned NOT NULL AUTO_INCREMENT COMMENT '自增ID号',
`brand_name` varchar(60) NOT NULL COMMENT '品牌名称',
`brand_logo` varchar(80) NOT NULL COMMENT '上传的该品牌公司logo图片',
`brand_desc` text NOT NULL COMMENT '品牌描述',
`site_url` varchar(255) NOT NULL COMMENT '品牌的网址',
`sort_order` tinyint(3) unsigned NOT NULL DEFAULT '0' COMMENT '品牌在前台页面的显示顺序,数字越大越靠后',
`is_show` tinyint(1) unsigned NOT NULL DEFAULT '1' COMMENT '该品牌是否显示,0,否;1,显示',
PRIMARY KEY (`brand_id`),
KEY `is_show` (`is_show`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8 ROW_FORMAT=DYNAMIC COMMENT=' 商品品牌信息记录表' AUTO_INCREMENT=9 ;

– 表的结构 `ecs_card`

CREATE TABLE IF NOT EXISTS `ecs_card` (
`card_id` tinyint(3) unsigned NOT NULL AUTO_INCREMENT COMMENT '自增ID号',
`card_name` varchar(120) NOT NULL COMMENT '贺卡名称',
`card_img` varchar(255) NOT NULL COMMENT '贺卡图纸的名称',
`card_fee` decimal(6,2) unsigned NOT NULL DEFAULT '0.00' COMMENT '贺卡所需费用',
`free_money` decimal(6,2) unsigned NOT NULL DEFAULT '0.00' COMMENT '订单达到该字段的值后使用此贺卡免费',
`card_desc` varchar(255) NOT NULL COMMENT '贺卡的描述',
PRIMARY KEY (`card_id`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8 ROW_FORMAT=DYNAMIC COMMENT=' 贺卡的配置的信息' AUTO_INCREMENT=2 ;

– 表的结构 `ecs_cart`

CREATE TABLE IF NOT EXISTS `ecs_cart` (
`rec_id` mediumint(8) unsigned NOT NULL AUTO_INCREMENT COMMENT '自增ID号',
`user_id` mediumint(8) unsigned NOT NULL DEFAULT '0' COMMENT '用户登录id,取自session,',
`session_id` char(32) CHARACTER SET utf8 COLLATE utf8_bin NOT NULL COMMENT '登录的sessionid,如果该用户退出,该sessionid对应的购物车中的所有记录都将被删除',
`goods_id` mediumint(8) unsigned NOT NULL DEFAULT '0' COMMENT '商品的id,取自表goods的goods_id',
`goods_sn` varchar(60) NOT NULL COMMENT '商品的货号,取自表goods的goods_sn',
`goods_name` varchar(120) NOT NULL COMMENT '商品的名称,取自表goods的goods_name',
`market_price` decimal(10,2) unsigned NOT NULL DEFAULT '0.00' COMMENT '商品的市场价,取自表goods的market_price',
`goods_price` decimal(10,2) NOT NULL DEFAULT '0.00' COMMENT '商品的本店价,取自表goods的shop_price',
`goods_number` smallint(5) unsigned NOT NULL DEFAULT '0' COMMENT '商品的购买数量,在购物车时,实际库存不减少',
`goods_attr` text NOT NULL COMMENT '商品的属性,中括号里是该属性特有的价格',
`is_real` tinyint(1) unsigned NOT NULL DEFAULT '0' COMMENT '取自ecs_goods的is_real',
`extension_code` varchar(30) NOT NULL COMMENT '商品的扩展属性,取自ecs_goods的extension_code',
`parent_id` mediumint(8) unsigned NOT NULL DEFAULT '0' COMMENT '该商品的父商品id,没有该值为0,有的话那该商品就是该id的配件',
`rec_type` tinyint(1) unsigned NOT NULL DEFAULT '0' COMMENT '购物车商品类型,0,普通;1,团够;2,拍卖;3,夺宝奇兵',
`is_gift` smallint(5) unsigned NOT NULL DEFAULT '0' COMMENT '是否是赠品,0,否;其他,是参加优惠活动的id,取值于ecs_favourable_activity 的act_id',
`can_handsel` tinyint(3) unsigned NOT NULL DEFAULT '0',
`goods_attr_id` mediumint(8) NOT NULL COMMENT '该商品的属性的id,取自goods_attr的goods_attr_id,如果有多个,只记录了最后一个,可能是个bug',
PRIMARY KEY (`rec_id`),
KEY `session_id` (`session_id`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8 ROW_FORMAT=DYNAMIC COMMENT=' 购物车购物信息记录表' AUTO_INCREMENT=82 ;

– 表的结构 `ecs_category`

CREATE TABLE IF NOT EXISTS `ecs_category` (
`cat_id` smallint(5) unsigned NOT NULL AUTO_INCREMENT COMMENT '自增ID号',
`cat_name` varchar(90) NOT NULL COMMENT '分类名称',
`keywords` varchar(255) NOT NULL COMMENT '分类的关键字,可能是为了搜索',
`cat_desc` varchar(255) NOT NULL COMMENT '分类描述',
`parent_id` smallint(5) unsigned NOT NULL DEFAULT '0' COMMENT '该分类的父id,取值于该表的cat_id字段',
`sort_order` tinyint(1) unsigned NOT NULL DEFAULT '0' COMMENT '该分类在页面显示的顺序,数字越大顺序越靠后;同数字,id在前的先显示',
`template_file` varchar(50) NOT NULL COMMENT '不确定字段,按名字和表设计猜,应该是该分类的单独模板文件的名字',
`measure_unit` varchar(15) NOT NULL COMMENT '该分类的计量单位',
`show_in_nav` tinyint(1) NOT NULL DEFAULT '0' COMMENT '是否显示在导航栏,0,不;1,显示在导航栏',
`style` varchar(150) NOT NULL COMMENT '该分类的单独的样式表的包括文件名部分的文件路径',
`is_show` tinyint(1) unsigned NOT NULL DEFAULT '1' COMMENT '是否在前台页面显示,1,显示;0,不显示',
`grade` tinyint(4) NOT NULL DEFAULT '0' COMMENT '该分类的最高和最低价之间的价格分级,当大于1时,会根据最大最小价格区间分成区间,会在页面显示价格范围,如0-300,300-600,600-900
这种',
`filter_attr` smallint(6) NOT NULL DEFAULT '0' COMMENT '如果该字段有值,则该分类将还会按照该值对应在表goods_attr的goods_attr_id所对应的属性筛选,如,封面颜色下有红,黑分类筛选 ',
PRIMARY KEY (`cat_id`),
KEY `parent_id` (`parent_id`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8 ROW_FORMAT=DYNAMIC COMMENT=' 商品分类表,记录商品分类信息' AUTO_INCREMENT=9 ;

希望本文所述对大家的ecshop二次开发有所帮助。