首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >内部加入mysql?

内部加入mysql?
EN

Stack Overflow用户
提问于 2014-03-17 09:01:33
回答 2查看 69关注 0票数 0

我想在用户名上进行内部连接,其中table1有如下数据:

代码语言:javascript
运行
复制
username    pass
apple       11
orange      22
banana      33

与table2一起使用的数据如下

代码语言:javascript
运行
复制
username    email 
tw-apple    apple@gmail.com
fb-orange   orange@gmail.com
reg-banana  banana@gmail.com

得到通行证和电子邮件。

代码语言:javascript
运行
复制
    SELECT * 
      FROM table1 
INNER JOIN table2 
        ON table2.(SUBSTRING(`username`,(LOCATE('-',`username`)+1)))=table1.username

也和

代码语言:javascript
运行
复制
table2.(SUBSTRING_INDEX(`username`, '-', -1))

需要帮助..。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2014-03-17 09:20:21

如果您使用的是MySQL,您可以只使用SUBSTRING_INDEX,而不是笨拙的仿真:

代码语言:javascript
运行
复制
  SELECT *,table2.username as uname
    FROM table1 
         INNER JOIN table2 
             ON table1.username = SUBSTRING_INDEX(table2.username,'-', -1);

SQL Fiddle (从@RagingBull窃取sqlfiddle模板)

票数 1
EN

Stack Overflow用户

发布于 2014-03-17 09:14:38

试试这个:

代码语言:javascript
运行
复制
  SELECT *,table2.username as uname
  FROM table1 INNER JOIN 
  table2 ON table1.username=(SUBSTRING(table2.username,(LOCATE('-', table2.username))+1))

结果:

代码语言:javascript
运行
复制
USERNAME    PASS    EMAIL               UNAME
apple       11      apple@gmail.com     tw-apple
orange      22      orange@gmail.com    fb-orange
banana      33      banana@gmail.com    reg-banana

SQL Fiddle中的结果。

阅读更多关于LocateSubstring的信息。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/22450188

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档