sql 语句如何实现多对多的模糊查询?
举例,有两个表:表1字段一字段二1b1c2d3e表2字段三字段四fbgA4c6Bbd5C我如何通过SQL语句获得如下表格:表3字段一字段四1A1B1C2C即:如果字段一在...
举例,有两个表:
表1
字段一 字段二
1 b
1 c
2 d
3 e
表2
字段三 字段四
fbg A
4c6 B
bd5 C
我如何通过SQL语句获得如下表格:
表3
字段一 字段四
1 A
1 B
1 C
2 C
即:
如果字段一在表1中对应行的字段2包含在表2中字段三的字符串中,则建立字段一和字段四之间的对应关系,否则不存在在生成的表三中。 展开
表1
字段一 字段二
1 b
1 c
2 d
3 e
表2
字段三 字段四
fbg A
4c6 B
bd5 C
我如何通过SQL语句获得如下表格:
表3
字段一 字段四
1 A
1 B
1 C
2 C
即:
如果字段一在表1中对应行的字段2包含在表2中字段三的字符串中,则建立字段一和字段四之间的对应关系,否则不存在在生成的表三中。 展开
4个回答
展开全部
oracle
select table1.col1,table2.col2
form table1 join table2 on instr(table1.col2 , table2.col1) <> 0
instr(str1,str2) 返回字符串str2在str1中的位置
如果是其他DB,你找一下相关函数替换下就行了
select table1.col1,table2.col2
form table1 join table2 on instr(table1.col2 , table2.col1) <> 0
instr(str1,str2) 返回字符串str2在str1中的位置
如果是其他DB,你找一下相关函数替换下就行了
追问
你的答案基本能解决我的问题,我用的是MYSQL数据库,VB编程语句。
只是现在又出来一个新的问题,查询的结果跟我想要的结果有点偏差。
我大致了解了一下,可能是因为我要查询的字段中含有"-"这个特殊字符。
而"-"在sql中貌似是通配字符的一种,不知道有没有办法解决这个问题?多谢!
追答
你百度下Mysql 强制转义吧,好像是这麼叫的,可以把’-‘就当做是’-‘,而不是通配符
展开全部
-- for M$SQL
select 字段一, 字段四
from 表1 a
join 表2 b on 1=1
and charindex(字段二, 字段三)>0
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
select 字段一, 字段四
from 表1 join 表2 on charindex(字段二, 字段三)>0
from 表1 join 表2 on charindex(字段二, 字段三)>0
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
select a.a,b.b from b join a on b.b like '%'+a.b+'%'
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询