douan3414 2013-06-06 18:09
浏览 32
已采纳

Mysql使用一对多关系加入非匹配表

I am trying to get all results from table 1 (Reports) and join the other two tables onto it (users) and (workorders)

Reports has keys relating to Users and Workorders but they are stored in csv values. I am trying to peform something similar to this psuedo code

`SELECT * 
FROM reports 
LEFT JOIN users ON reports = (WHERE users.userID IN (reports.users))
LEFT JOIN workorders ON reports = (WHERE workorder.status IN (reports.filters) 
AND reports.reportid = 10
`

reports.users and reports.filters look like "1,2,3,4,5,6"

  • 写回答

1条回答 默认 最新

  • doulechou0700 2013-06-06 18:12
    关注

    If I understand correctly (meaning that reports.users and reports.filters are strings of comma-delimited values), you need the FIND_IN_SET function for this:

    SELECT * from reports 
    LEFT JOIN users ON FIND_IN_SET(users.userID, reports.users)
    LEFT JOIN workorders ON FIND_IN_SET(workorder.status, reports.filters) 
      AND reports.reportid = 10
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥20 测距传感器数据手册i2c
  • ¥15 RPA正常跑,cmd输入cookies跑不出来
  • ¥15 求帮我调试一下freefem代码
  • ¥15 matlab代码解决,怎么运行
  • ¥15 R语言Rstudio突然无法启动
  • ¥15 关于#matlab#的问题:提取2个图像的变量作为另外一个图像像元的移动量,计算新的位置创建新的图像并提取第二个图像的变量到新的图像
  • ¥15 改算法,照着压缩包里边,参考其他代码封装的格式 写到main函数里
  • ¥15 用windows做服务的同志有吗
  • ¥60 求一个简单的网页(标签-安全|关键词-上传)
  • ¥35 lstm时间序列共享单车预测,loss值优化,参数优化算法