表一、客户表1
ID1 name1
表二、客户表2
id2 name2表三、进货单资料表
ID cust_1d date需求:
1、表一和表二属性很不一样,不希望合并在一起。
2、进货单资料表的cust_Id同时关联ID1,ID2,关联之后显示中文名称。要求可以显示一个进货的列表供查询。
3、表三不想拆成2个表。
4、表一和表二完全不同,没有关系,不能建立视图。请问可以实现吗?或者有其他的办法?我还几年没来,不知道有没有分给,哪位大侠有空路过帮我看看。
ID1 name1
表二、客户表2
id2 name2表三、进货单资料表
ID cust_1d date需求:
1、表一和表二属性很不一样,不希望合并在一起。
2、进货单资料表的cust_Id同时关联ID1,ID2,关联之后显示中文名称。要求可以显示一个进货的列表供查询。
3、表三不想拆成2个表。
4、表一和表二完全不同,没有关系,不能建立视图。请问可以实现吗?或者有其他的办法?我还几年没来,不知道有没有分给,哪位大侠有空路过帮我看看。
(select * from 表一 union all select * from 表二) b
on a.cust_id=.id
left join tb1 on tb3.cust_1d=tb1.id1
错了,我忘考虑 tb1 和tb2 的ID为相同的情况了
(select * from 表一 union all select * from 表二) b
on a.cust_id=b.id
--好像没什么好方法可以处理 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
zhaowenzhong
谢谢,你提醒了我。 表三中加标识性字段,
最终目的只要表三可以实现同时关联两个表,客户中文称输出就行了。如果我表三这样设计,
表三、进货单资料表
ID ID1 id2 date
应该就实现了表三同时关联表一和表二,不用纠结一个字段非要关联2个不同表,这样的话就可以各自关联,互不相干。但是又有新问题。
1、每一条记录ID1或ID2,肯定有一个为空,因为每次只能向一个客户购进。这样关联的语句就不好写了....我再想想。
的left join就可以了,回头测试一下
如,表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希望可以帮到你