MySQL外键查询返回空

标签 mysql sql foreign-keys

我有三个表

让我们来一个demo_organization ;

+--------------------+--------------+------+-----+---------+----------------+
| Field              | Type         | Null | Key | Default | Extra          |
+--------------------+--------------+------+-----+---------+----------------+
| id                 | int(11)      | NO   | PRI | NULL    | auto_increment |
| org_name           | varchar(100) | NO   |     | NULL    |                |
| org_type           | varchar(100) | NO   |     | NULL    |                |
| abn_acn_no         | varchar(100) | NO   |     | NULL    |                |
| org_url            | varchar(120) | NO   |     | NULL    |                |
| notes              | longtext     | NO   |     | NULL    |                |
| city               | varchar(100) | YES  |     | NULL    |                |

第二个是demo_user

mysql> desc demo_user ;
+--------------------+----------------+------+-----+---------+----------------+
| Field              | Type           | Null | Key | Default | Extra          |
+--------------------+----------------+------+-----+---------+----------------+
| id                 | int(11)        | NO   | PRI | NULL    | auto_increment |
| user_name          | varchar(100)   | NO   |     | NULL    |                |
| first_name         | varchar(100)   | NO   |     | NULL    |                |
| middle_name        | varchar(100)   | NO   |     | NULL    |                |
| last_name          | varchar(100)   | NO   |     | NULL    |                |
| image              | varchar(10000) | YES  |     | NULL    |                |
| password           | varchar(80)    | NO   |     | NULL    |                |
| role               | varchar(20)    | NO   |     | NULL    |                |
| org_name_id        | int(11)        | NO   | MUL | NULL    |                |
| timezone_id        | int(11)        | NO   | MUL | NULL    |                |

第三个是demo_meeting;看起来像

mysql> desc demo_meeting ;
+--------------------+--------------+------+-----+---------+----------------+
| Field              | Type         | Null | Key | Default | Extra          |
+--------------------+--------------+------+-----+---------+----------------+
| id                 | int(11)      | NO   | PRI | NULL    | auto_increment |
| name               | varchar(200) | NO   |     | NULL    |                |
| meetingID          | varchar(50)  | NO   |     | NULL    |                |
| venue_id           | int(11)      | YES  | MUL | NULL    |                |
| status             | int(11)      | YES  |     | NULL    |                |
| recurring_time     | varchar(50)  | NO   |     | NULL    |                |
| attendee_passwd    | varchar(100) | NO   |     | NULL    |                |
| moderator_passwd   | varchar(100) | NO   |     | NULL    |                |
| date_created       | datetime     | NO   |     | NULL    |                |
| start_time         | varchar(100) | NO   |     | NULL    |                |
| end_time           | varchar(100) | NO   |     | NULL    |                |
| meeting_duration   | varchar(100) | NO   |     | NULL    |                |
| meeting_datetime   | datetime     | YES  |     | NULL    |                |
| timezone           | varchar(50)  | NO   |     | NULL    |                |
| reminder           | tinyint(1)   | NO   |     | NULL    |                |
| duration           | varchar(20)  | NO   |     | NULL    |                |
| created_by_id      | int(11)      | NO   | MUL | NULL    |                |

第三张表created_by_id指的是demo_user表的A用户(外键)

而 org_name_id(demo_user table ) 指的是 demo_organization (demo_organization 表的外键)

已更新

mysql> desc demo_meetingroom;
+------------+--------------+------+-----+---------+----------------+
| Field      | Type         | Null | Key | Default | Extra          |
+------------+--------------+------+-----+---------+----------------+
| id         | int(11)      | NO   | PRI | NULL    | auto_increment |
| name       | varchar(100) | NO   |     | NULL    |                |
| type       | varchar(200) | NO   |     | NULL    |                |
| expired_on | varchar(100) | NO   |     | NULL    |                |
| user_id    | int(11)      | YES  | MUL | NULL    |                |
+------------+--------------+------+-----+---------+----------------+

现在我正在尝试获取特定组织的所有 session 。

我正在写一个类似

的查询
select meetingID ,type from demo_meeting as dm ,demo_meetingroom as dmr 
Where venue_id IS NOT NULL 
and dm.name = dmr.name 
AND created_by_id IN
  ( 
  SELECT id from demo_user WHERE org_name_id IN 
         (
         SELECT id from demo_organization where id =  
            (SELECT org_name_id from demo_user WHERE user_name = 'God') 
         )
   );

不幸的是它返回我空集(但有值(value))

请帮我看看我做错了什么?

最佳答案

JOIN 三个表而不是这些 IN。像这样的东西:

SELECT
  dm.meetingID, 
  dm.type
FROM  demo_meeting dm
INNER JOIN demo_user         u   ON dm.created_by_id = u.id
INNER JOIN demo_organization org ON u.org_name_id = org.id
WHERE u.user_name = 'God'
 AND  dm.venue_id IS NOT NULL

关于MySQL外键查询返回空,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12814063/

相关文章:

PHP mysql if/else 简写

php - MYSQL 查询简单数据范围

php - 如何在Mysql中按公式排序

java - 使用数据源未选择数据库 SQLException

mysql - SQL 中可以有 "null rows"吗?

c# - 两个不同的用户可以访问同一个数据库表以插入不同的数据吗?

sql - Liquibase 改变列约束

java - 如何在 Hibernate HQL 中使用 CONCAT_WS()

php - Magento - 无法重新索引产品价格 - 外键约束失败

mysql - 如果我在没有在 MySQL 中定义外键的情况下对数据库进行建模会怎样?