急!!!数据库表设计问题?

xfile 2000-07-05 03:11:00
系统开发采用ASP+Access,其中有一数据库表不知如何设计,请教?

这个表包含若干(n)个企业的信息表:每个企业一条记录。


企业的信息字段包括:企业名称,产品种类,销售方式,地址,电话,传真.....等。

其中每个企业的地址,电话,传真.....等字段是唯一的
(即每个企业只有一个固定的地址,电话,传真.....等)

而每个企业的 "产品种类"和"销售方式"是多种的
(即每个企业可以有"多个产品种类(例如:苹果,鸭梨,香蕉等)"和"多种销售方式(例如:批发,零售,代销等)"
但"产品种类"和"销售方式"字段之间无任何联系)

欲实现的功能,主要是此表的查询!要求:

1.指定"企业名称"查询,要显示企业的所有信息,包括企业名称,产品种类,销售方式,地址,电话,传真.....等
其中,a.要把该企业的 "所有" 产品种类 和 销售方式都列出来。
b.企业名称可"模糊查询"(例如:键入"有限公司",要把所有包含"有限公司"的企业名称都显示出来,可能有多个)
这个b项单独实现较容易,但必须同时满足a项!

2.指定"产品种类"查询,要显示包含"产品种类"的所有企业的所有信息
同时满足(1)中的a项!

3.指定"销售方式"查询,要求同(2).

不知如何设计此表,同时满足条件1,2,3项

我也试过把此表分成3个表(把"产品种类"和"销售方式"提出来,分别与"企业名称"组成一个表),但好像也不行!

特此向高手求教!!!
...全文
176 9 打赏 收藏 转发到动态 举报
写回复
用AI写文章
9 条回复
切换为时间正序
请发表友善的回复…
发表回复
skt642 2001-05-31
  • 打赏
  • 举报
回复
69609关注!
Wingsun 2000-07-05
  • 打赏
  • 举报
回复
我已经说过,要通过JOIN的方法来确保信息完整性。不如这样吧,我设计一个库发给你,你看一看就知道了,Access格式的。
xfile 2000-07-05
  • 打赏
  • 举报
回复
精确查询可以,但模糊查询......

例如,键入:"南京",查询到3个"南京XXX"的企业

其信息如我上面画的表所示(见上面的帖子)
问题有2

1.如何把3个企业("南京XXX"的企业)与
各自本企业的"产品种类"或"销售方法"对应起来?
即:企业1只与"企业1的产品种类"与"企业1的销售方法"相对应,
不会出现 企业1与"企业2的产品种类"与"企业3的销售方法" 对应的情况

2.如何把每个企业的各自“所有”的 "产品种类"或"销售方法"对应起来?
xfile 2000-07-05
  • 打赏
  • 举报
回复
Wingsun,你好
不知我上贴说明白了没有?
不过在03:37:00,你我同时发了贴,不过我得排在你前,喜喜!!
xfile 2000-07-05
  • 打赏
  • 举报
回复
精确查询可以,但模糊查询......

例如,键入:"有限公司",查询到3个"有限公司"的企业

其信息如我上面画的表所示(见上面的帖子)

如何把3个企业(包含"有限公司"名称的企业)与各自的"产品种类"或"销售方法"对应起来?

即 企业1只与"企业1的产品种类"与"企业1的销售方法"相对应,
不会出现 企业1只与"企业2的产品种类"与"企业3的销售方法" 对应的情况
Wingsun 2000-07-05
  • 打赏
  • 举报
回复
再你的表述中你已经将它分为了三个表,一个是企业基本信息(表A),另一个是企业的产品种类信息(表B),最后一个是企业的销售方式(表C).A是主表,B、C是附表,表A中有一个每一个企业的唯一标识(唯一索引),通过这个表识字段将三张表联系在一起。那么你的结构建好后,就是实现查询的事了。
1。Select * from A,B,C Where A.ID=B.OrgID And A.ID=C.OrgID And A.Name Like '*南京*'
2。Select * from A,B,C Where A.ID=B.OrgID And A.ID=C.OrgID And B.Name Like '*计算机*'
3。Select * from A,B,C Where A.ID=B.OrgID And A.ID=C.OrgID And C.Name Like '*零售*'
当然SQL语句不一定就是这样的,你还可以使用JOIN子句来获得结果。JOIN子句比较好,能获得一个比较好的结果,上面写法有时不严谨容易出错,建议你使用JOIN子句。

xfile 2000-07-05
  • 打赏
  • 举报
回复
谢谢你的答复。
但此方法我想过,类似于:

企业名称 产品种类 销售方法 电话 传真 .......

企业1 产品1,产品2,产品3 销售1,销售4 .......

企业2 产品1,产品3 销售2,销售3 .......

企业3 产品2,产品53 销售1,销售5 .......

.......等

但如何列出所有企业的"产品种类"或"销售方法".

而且,在 "产品种类"或"销售方法"时,采用 Like 和Find 方法来查找,
效率不是太高?
WHQ 2000-07-05
  • 打赏
  • 举报
回复
规范的做法是采用主子表,即企业是主表、产品与销售分别是子表,主子表用外键的关系连接。查询不存在任何问题。
leslielu 2000-07-05
  • 打赏
  • 举报
回复
用字符串,把销售方式按一个字段处理,可以中间用“,”分割每种方式。同样对产品种类。这样就在一个表内。查询也是对字符串找子串的问题
酷窗版演示:http://www.edd8.com/bbs/index.asp?style=0 简装版演示:http://www.edd8.com/bbs/index2.asp 一点点论坛(http://www.edd8.com/bbs)使用说明 欢迎大家下载使用一点点论坛,在使用论坛前,请认真阅读以下内容: ===================================== 论坛:一点点论坛(http://www.edd8.com/bbs) 主页:一点点星空驿站(http://www.edd8.com/) 站长:叮咚虫(e_Mail:b_li@163.com) 版本:EDD8 Ver.2003 for DV =====================================   一点点论坛是建立在动网论坛基础上的ASP互动论坛,从动网Var5.b109开始论坛结构便开始脱离动网,与动网升级一起,本论坛本身也同时实现了动网新的功能,到519的发布,本人常得论坛本身已功能基本完善,所以决定与动网完全脱离,到动网Final的出现,本论坛也决定不再跟随动网升级了,本人全面对原来的论坛进行了代码优化和版面重排,并升级了部分功能代码,完成了现在这样的论坛。使论坛已经完全脱离了动网,以后也不可以随动网一起升级了!   所以选择本论坛的朋友请先明白,如果采用了本论坛的数据结构,以后就不可以和动网一起升级了,而现有的动网Final版的数据库和本论坛的数据库也是不兼容的!对于动网V5.b519的用户,本人同时在压缩包里提供了升级文件,可以把你519的数据库升级成和本论坛一致的数据结构!   由于一些朋友催得较,部分功能还是没有完善的(但不会出错),我以后也会给出升级包的。所以决定使用本论坛的朋友,请一定要到本站论坛的“站务办公室”进行指定的留言签名,以好我第一时间通知大家升级!   论坛中使用到的部分插件并没有一同奉上,原因是我还没完成代码优化,请过几天到我的论坛上下载。可以下载的插件主要有:社区银行、网络拳皇、可乐吧台球、五子棋等等…… ===================================== 主要特色功能说明: ◎ 双版面设计,用户可以根据不同爱好选择不同的版式(酷窗版和精简版),系统会记录用户的选择,不用重复选择,也不会出现版面混淆等现象; ◎ 发贴回贴互动功能,给用户随机的互动事件,增加用户的参与兴趣; ◎ 增强的UBB代码和JS代码,新增的买卖贴、定时贴等十几种特色功能UBB代码; ◎ 贴子功能加强,增加互动鲜花、鸡蛋、金钱、炸弹等功能,并保存数据作为用户在论坛的人缘依据; ◎ 不好说了,等你去发掘吧,不然又说我叫卖了…… ====================================== 安装说明: 解压就可以了,数据库名称和路径有变动时不要忘了在CONN。ASP中进行相应修改。 (注意:当论坛中一个贴子也没有时,论坛明星会出错,但当你加入贴子后就正常了,大家不要惊慌) 升级:(对519),解压后把你的原519数据库覆盖现数据库,再执行根目录下的UPDATE。ASP文件就行了,如果没有升级成功的提示,说明你的数据不能进行升级! (注意:数据库的升级应做了备份,并在本机上进行!) ====================================== 最后一点说明: 由于论坛本来是打算自己用的,所以在设计的过程中部分变量已经去掉,不能从后台设置了(如格边框),请大家最好保持现有的风格。 如果还不问题,可以到我的论坛上来交流。??注意,由于本人时间不限,技术支持是有限的,请不要过于强求!

34,576

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧