首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 数据库 > SQL Server >

这样的处理该如何做

2012-01-02 
这样的处理该怎么做有两个表tb1CODE1A3Atb2TYPE1TYPE2TYPE_CODEAT1T1AT2T2AT3T3BT1B1现在想根据tb1的CODE

这样的处理该怎么做
有两个表
tb1

CODE
1A
3A

tb2
TYPE1   TYPE2   TYPE_CODE
AT         1           T1
AT         2           T2
AT         3           T3
BT         1           B1

现在想根据tb1的CODE取出tb2的TYPE_CODE,结果如下
TYPE_CODE
T1
T3

就是把tb1的CODE分解开,A对应TYPE1的AT,   前面的数字对应TYPE2的数字
该怎么做呢

[解决办法]
select tb2.TYPE_CODE from tb2,tb1
where tb2.TYPE1 = left(tb1.CODE,1) and tb2.type2 = right(tb1.code,1)
[解决办法]
create table tb1(code varchar(10))
insert into tb1
select '1A '
union all select '3A '

create table tb2(type1 varchar(10),type2 int,type_code varchar(10))
insert into tb2
select 'AT ',1, 'T1 '
union all select 'AT ',2, 'T2 '
union all select 'AT ',3, 'T3 '
union all select 'BT ',1, 'B1 '

select type_code from tb2,tb1
where charindex(tb1.code,tb2.type_code+tb2.type1)> 0
[解决办法]
--创建测试环境
create table tb1(CODE varchar(10))
create table tb2(TYPE1 varchar(10),TYPE2 varchar(10),TYPE_CODE varchar(10))

--插入测试数据
insert tb1(CODE)
select '1A ' union all
select '3A '

insert tb2(TYPE1,TYPE2,TYPE_CODE)
select 'AT ', '1 ', 'T1 ' union all
select 'AT ', '2 ', 'T2 ' union all
select 'AT ', '3 ', 'T3 ' union all
select 'BT ', '1 ', 'B1 '

--求解过程
select type_code from tb2
where exists
(select 1 from tb1
where left(tb2.type1,1) = right(tb1.code,1)
and tb2.type2 = left(tb1.code,1) )

--删除测试环境
drop table tb1,tb2

/*--测试结果
type_code
----------
T1
T3
*/

热点排行