表一、客户表1
ID1  name1
表二、客户表2
id2  name2表三、进货单资料表
ID   cust_1d   date需求:
1、表一和表二属性很不一样,不希望合并在一起。
2、进货单资料表的cust_Id同时关联ID1,ID2,关联之后显示中文名称。要求可以显示一个进货的列表供查询。
3、表三不想拆成2个表。
4、表一和表二完全不同,没有关系,不能建立视图。请问可以实现吗?或者有其他的办法?我还几年没来,不知道有没有分给,哪位大侠有空路过帮我看看。

解决方案 »

  1.   

    select * from 表三 a join
    (select * from 表一 union all select * from 表二) b
    on a.cust_id=.id
      

  2.   

    select ID,cust_1d,date,name1,name2 from tb3 left join tb2 on tb3.cust_1d=tb2.id2
    left join tb1 on tb3.cust_1d=tb1.id1
      

  3.   


    错了,我忘考虑 tb1 和tb2 的ID为相同的情况了
      

  4.   

    select * from 表三 a join
    (select * from 表一 union all select * from 表二) b
    on a.cust_id=b.id
      

  5.   


    --好像没什么好方法可以处理 id1 和id2 相同的情况。除非在 表三中加标识性字段
     
    create table tb1(id1 int,name1 nvarchar(32))
    insert into tb1 select 1,N'的是法师法'
    create table tb2(id2 int,name2 nvarchar(32))
    insert into tb2 select 1,N'阿斯顿'
    insert into tb2 select 2,N'卢卡斯进的'create table tb3(id int,cust_1d int,date datetime)
    insert into tb3 select 1,1,GETDATE()
    insert into tb3 select 2,1,GETDATE()
    insert into tb3 select 3,2,GETDATE()--除非这样
    select  distinct cust_1d,name from tb3 a join
    (select id1 as id,name1 as name from tb1 union all select id2 as id,name2 as name from tb2) b
    on a.cust_1d=b.id
      

  6.   

     
    zhaowenzhong
    谢谢,你提醒了我。 表三中加标识性字段,
    最终目的只要表三可以实现同时关联两个表,客户中文称输出就行了。如果我表三这样设计,
    表三、进货单资料表
    ID ID1  id2 date
    应该就实现了表三同时关联表一和表二,不用纠结一个字段非要关联2个不同表,这样的话就可以各自关联,互不相干。但是又有新问题。
    1、每一条记录ID1或ID2,肯定有一个为空,因为每次只能向一个客户购进。这样关联的语句就不好写了....我再想想。
      

  7.   

    似乎用zhaowenzhong
    的left join就可以了,回头测试一下
      

  8.   

    表3中加字段不一定非要把两个字段ID1和ID2都加上去,可以加个标识位,用于表示是表1还是表2
    如,表3
    ID,TableID,TableFlag,Date
    其中TableFlag为1表示表1,2表示表2
    连接时SELECT * FROM 表1,表2,表3 WHERE TableId = CASE TableFlage WHEN 1 THEN 表1.Id 
                                                                WHEN 2 THEN 表2.Id END希望可以帮到你