dream6120 2015-06-16 02:43
浏览 318
已采纳

mysql中的字符串拆分和子查询

first of all i have 1 table in database.

1)tags :

id    name
1     theme1=test1
2     theme1=test2
3     theme1=test3
4     theme2=test1
5     theme2=test2
6     theme2=test3

And i have bunch of id of tags in array. like 1,3.

Now,

1)select name from tags where id=1

result: theme1=test1

(now using wildcard)

2)select id from tags where name like 'theme_test1'

result : 1,4

(here 'theme_test1' need to take from query1)

I am getting output proper but need to use 2 query.I want to do this in single query.

Thanks

  • 写回答

4条回答 默认 最新

  • dsj60862 2015-06-16 03:08
    关注
    SELECT id FROM tags WHERE name LIKE ( 
        SELECT CONCAT(SUBSTRING(name,1,5),'__',SUBSTRING(name,8)) FROM tags WHERE id=1 
    )
    

    Returns 1,4

    But Two queries (or a refactor) might be a better option

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(3条)
编辑
预览

报告相同问题?

手机看
程序员都在用的中文IT技术交流社区

程序员都在用的中文IT技术交流社区

专业的中文 IT 技术社区,与千万技术人共成长

专业的中文 IT 技术社区,与千万技术人共成长

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

客服 返回
顶部