设为首页
收藏本站
开启辅助访问
切换到窄版
登录
立即注册
中问网首页
我的收藏
站长博客
搜索
搜索
本版
帖子
用户
第一问答网
»
论坛
›
中问网
›
问答
›
紧急求助,各位救我。
返回列表
发新帖
紧急求助,各位救我。
[复制链接]
11
|
8
|
2010-10-8 09:28:52
|
显示全部楼层
|
阅读模式
a:
col1col2
a 1
b 2
c3-4
b:
col1 col2
d 1
e 2-5
f3-6
要跑出col2列相同的值,‘-’两边有一个数字相同就算相同,怎么整。
结果
a:
col1 col2
a1
b2
c 3-4
还要B表不同的数据
回复
使用道具
举报
千问
|
2010-10-8 09:28:52
|
显示全部楼层
如果COL2列 只有一个 '-'分隔的话
可以把它分为两列然后再比较就可以了
select col1,
decode(instr(a.col2,'-'),
0,
a.col2,
substr(a.col2,0,instr(a.col2,'-')-1)) col3,
decode(instr(a.col2,'-'),
0,
a.col2,
substr(a.col2,instr(a.col2,'-')+1)) col4
from a
回复
使用道具
举报
千问
|
2010-10-8 09:28:52
|
显示全部楼层
nice
回复
使用道具
举报
千问
|
2010-10-8 09:28:52
|
显示全部楼层
原表不是只有两列,有十几列,并且比对完还要用剩余数据在用另一列比对,接下来还要B表的剩余数据,所以分成两行很麻烦。
回复
使用道具
举报
千问
|
2010-10-8 09:28:52
|
显示全部楼层
SQL问题务必随贴附上建表及模拟数据insert脚本,方便他人解答~
回复
使用道具
举报
千问
|
2010-10-8 09:28:52
|
显示全部楼层
不错!
回复
使用道具
举报
千问
|
2010-10-8 09:28:52
|
显示全部楼层
强
回复
使用道具
举报
千问
|
2010-10-8 09:28:52
|
显示全部楼层
这个思路不错
回复
使用道具
举报
千问
|
2010-10-8 09:28:52
|
显示全部楼层
直接用条件语句过滤:
SELECT *
FROM T, T1
WHERE T.COL2 = T1.COL2
OR (SUBSTR(T.COL2, 0, INSTR(T.COL2, '-') - 1) =
SUBSTR(T1.COL2, 0, INSTR(T1.COL2, '-') - 1) OR
SUBSTR(T.COL2, -1, INSTR(T.COL2, '-') - 1) =
SUBSTR(T1.COL2, -1, INSTR(T1.COL2, '-') - 1));
回复
使用道具
举报
返回列表
发新帖
高级模式
B
Color
Image
Link
Quote
Code
Smilies
您需要登录后才可以回帖
登录
|
立即注册
本版积分规则
发表回复
回帖后跳转到最后一页
千问
主题
0
回帖
4882万
积分
论坛元老
论坛元老, 积分 48824836, 距离下一级还需 -38824837 积分
论坛元老, 积分 48824836, 距离下一级还需 -38824837 积分
积分
48824836
加好友
发消息
回复楼主
返回列表
问答
热门排行