【发布时间】:2011-08-29 07:13:33
【问题描述】:
我将我的数据库从一个用户表重新设计为多个用户表(按角色划分):tblStudents、tblTeachers、tblAdmin
登录时,我不想运行三个查询来检查用户是否存在于我的数据库中。所以我所做的就是将以下查询与union
select s.id as id, s.email as email, s.password as password, s.role as role from tblStudents s
union
select a.id as id, a.email as email, a.password as password, a.role as role from tblAdmin a
union
select t.id as id, t.email as email, t.password as password, t.role as role from tblTeachers t
这会选择所有表中相同的字段并为我很好地输出结果。
所以,我决定尝试一下,但由于某种原因,我的登录表单不起作用。对于我的登录表单,我添加了一个where 子句来检查电子邮件地址。我在我的数据库应用程序中运行了查询,令人惊讶的是,当我这样做时,例如 where email = "admin@admin.be"(此电子邮件存在于我的数据库中 tblAdmin),它还会从我的学生表中选择一条记录。
带有where子句:
select s.id as id, s.email as email, s.password as password, s.role as role from tblStudents s
union
select a.id as id, a.email as email, a.password as password, a.role as role from tblAdmin a
union
select t.id as id, t.email as email, t.password as password, t.role as role from tblTeachers t
where email = "admin@admin.be"
记录都是have id = 1,但我不明白为什么在我过滤管理员电子邮件地址时它会选择学生记录。为什么是这样?有人可以解释并为我提供更好的解决方案吗?我基本上只有一个登录表单,需要在多个表中进行选择以检查用户是否存在于我的数据库中。
【问题讨论】:
-
这似乎不是您的完整查询,因为其中没有过滤。你能发布整个查询吗?
-
认为这很清楚;用其他查询更新:)
-
我注意到您没有将字符串放在引号中。是不是打错字了?
-
如果您的意思是电子邮件 = 一个,是的,我忘记了;已编辑。
-
关于相关话题;尽量避免使用 "" 来引用你的字符串。不幸的是,MySQL 确实允许这样做,但是如果您必须迁移到另一个数据库,它会向您吐口水。使用 '' 是 SQL 标准,适用于 MySQL 和 其他所有内容。