我编写了一个存储过程(balloon_tip("test title", "test message")
),它应该通过用户的电子邮件返回所有用户的数据。这是我的存储过程:
MySQL
但是,它不是仅为具有指定电子邮件的用户返回所有数据,而是返回所有用户表。当我在没有存储过程的情况下运行相同的查询时,它仅返回具有指定电子邮件的用户的数据。这是查询:
-- Change Delimiter
DELIMITER //
-- Create Stored Procedure
CREATE DEFINER=`username`@`localhost` PROCEDURE GetUserByEmail(
IN Email VARCHAR(255)
)
BEGIN
SELECT * FROM user WHERE email = Email;
END//
-- Change Delimiter again
DELIMITER ;
答案 0 :(得分:1)
这是因为电子邮件是allways = to Email(列名不区分大小写)你应该把它改成这样的东西:
-- Change Delimiter
DELIMITER //
-- Create Stored Procedure
CREATE DEFINER=`username`@`localhost` PROCEDURE GetUserByEmail(
IN My_email VARCHAR(255)
)
BEGIN
SELECT * FROM user WHERE email = My_email;
END//
-- Change Delimiter again
DELIMITER ;