xiaoshan5634 2011-01-19 17:50
浏览 290
已采纳

多对多表结构的设计有什么优点?

最近看到一个朋友说自己公司使用的表结构为多对多的关系,现在他们的customer已经860万了,而中间表m_customer_category 也有900多万了,如果按类型查找客户资料的话巨慢,就是customer,m_customer_category,custoemr_category三张表多对多关系,现在使用客户类型快速查找非常慢。
然后自己也想了想这种设计,感觉查询确实非常郁闷,而且想不出它到底有什么优势。
希望大家一起来讨论讨论。

  • 写回答

7条回答 默认 最新

  • finallygo 2011-01-24 10:28
    关注

    首先Customer与Order不是一对多的关系吗?一个客户可以有多个订单,一个订单只能属于一个客户,如果像我说的,首先表的设计就有问题
    不过如果你真要这么设计的话...
    首先考虑客户类型和订单状态字段是否有做索引的需要,
    select t3.* from(
    select * from Customer where customer_type=80
    ) t1 inner join Customer_Order t2 on t1.customer_id=t2.customer_id
    inner join (
    select * from Order where order_state='已经到帐'
    ) t3 on t2.order_id=t3.order_id

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(6条)

报告相同问题?

悬赏问题

  • ¥170 如图所示配置eNSP
  • ¥20 docker里部署springboot项目,访问不到扬声器
  • ¥15 netty整合springboot之后自动重连失效
  • ¥15 悬赏!微信开发者工具报错,求帮改
  • ¥20 wireshark抓不到vlan
  • ¥20 关于#stm32#的问题:需要指导自动酸碱滴定仪的原理图程序代码及仿真
  • ¥20 设计一款异域新娘的视频相亲软件需要哪些技术支持
  • ¥15 stata安慰剂检验作图但是真实值不出现在图上
  • ¥15 c程序不知道为什么得不到结果
  • ¥15 键盘指令混乱情况下的启动盘系统重装