你看我有这个查询:
$sql = "INSERT INTO visitor( visitor_username, email, PASSWORD )
SELECT * FROM ( SELECT '$username', '$email','$password')
AS tmp WHERE NOT EXISTS
(SELECT admin.admin_username, admin.email FROM admin AS admin
WHERE admin.admin_username = '$username' OR admin.email = '$email'
UNION SELECT staff.staff_username, staff.email FROM staff
AS staff WHERE staff.staff_username = '$username' OR
staff.email = '$email' ) LIMIT 1";
基本上,如果值(visitor_username,email)在 admin/staff 表上不存在,我们插入值,它工作得很好而且很快,但一个好的解决方案并不总是带来彩虹。
如果我们无法在表中插入任何值,我会返回此错误消息
echo "User already exists. Please choose a different email address or username.";
由于我无法确定存在哪一个,因此我希望用户名或电子邮件地址有特定的案例返回错误。
我应该拆分查询(一个选择,然后插入)还是有其他方法我没有在网上找到在同一个查询中执行此操作?
我的目标是使用此查询返回特定的错误消息,例如:
“错误:用户名已存在”或“错误:电子邮件已存在”。
感谢您提前检查并尝试帮助我!