我对SQL很陌生,但我正在尽量减少代码重复。我正在开发一个游戏,它的服务器将使用MySQL C++连接器。我也将主持一个网站,将访问相同的数据库。它们都需要验证用户的身份。理想情况下,我希望编写一个存储过程,该存储过程接受用户名和散列,如果名称/密码匹配,则返回一个布尔值。
我不太擅长写查询,但是存储过程是新的领域。
有人能给我一个简单的MySQL存储过程示例,它使用这样的虚拟表:
Table Player
Column PlayerID (int, primary key, not null, auto increment)
Column PlayerUsername (varchar 25, not null)
Column PlayerPassword (varchar 25, not null)如何创建接受名称和密码的存储过程,如果用户名和密码与参数匹配的记录至少有1条,则返回true。
一旦我看到了存储过程的语法,我应该能够创建自己的存储过程。我的需求很基本。
发布于 2014-05-16 13:57:03
就像这样
DELIMITER //
DROP FUNCTION IF EXISTS MY_FUNCTION//
create function MY_FUNCTION(name varchar(255) CHARACTER SET utf8,
pwd varchar(255) CHARACTER SET utf8, )
RETURNS tinyint(1)
READS SQL DATA SQL SECURITY INVOKER
BEGIN
declare result tinyint(1);
SELECT if(count(*)>0,1,0) INTO result
FROM users
WHERE users.name=name and users.pwd=pwd;
RETURN result;
END//
DELIMITER ;https://stackoverflow.com/questions/23696196
复制相似问题