繁体   English   中英

我如何从MySQL的存储过程的多个选择中仅返回一个记录集?

[英]How i return only one recordset from multiple select of a stored procedure in MySQL?

这是我的SProcedure

DELIMITER $$

DROP PROCEDURE IF EXISTS `etracking`.`validarAcceso` $$
CREATE PROCEDURE `etracking`.`validarAcceso` (IN pusuario VARCHAR(30),IN ppassword VARCHAR(10))
BEGIN

  DECLARE encontrado INT;
  SET encontrado = 0;
IF encontrado = 0 THEN
  SELECT usuarios_distribuidores.nombre, usuarios_distribuidores.apellido1,
  usuarios_distribuidores.apellido2, distribuidores.nombre, count(encontrado) FROM
  usuarios_distribuidores INNER JOIN distribuidores ON
  distribuidores.iddistribuidor =  usuarios_distribuidores.iddistribuidor
  WHERE email = pusuario AND password = ppassword;
END IF;

IF encontrado = 0 THEN
   SELECT * FROM usuarios_centro_acopio WHERE email = pusuario AND password = ppassword;

END IF;

IF encontrado = 0 THEN
  SELECT * FROM usuarios_admin WHERE email = pusuario AND password = ppassword;
END IF;

END $$

DELIMITER ;

将查询置于相同条件,以便可以使用union all

IF encontrado = 0 THEN

  SELECT usuarios_distribuidores.nombre, usuarios_distribuidores.apellido1,
  usuarios_distribuidores.apellido2, distribuidores.nombre, count(encontrado) FROM
  usuarios_distribuidores INNER JOIN distribuidores ON
  distribuidores.iddistribuidor =  usuarios_distribuidores.iddistribuidor
  WHERE email = pusuario AND password = ppassword;

  UNION ALL

  SELECT * FROM usuarios_centro_acopio WHERE email = pusuario AND password = ppassword;

  UNION ALL

  SELECT * FROM usuarios_admin WHERE email = pusuario AND password = ppassword;

END IF;

有2个选项。 您可以使用联合或联接。 这取决于您的结构。

 SELECT * FROM usuarios_centro_acopio WHERE email = pusuario AND password = ppassword
 UNION ALL
 SELECT * FROM usuarios_admin WHERE email = pusuario AND password = ppassword;

要么

 SELECT * FROM usuarios_centro_acopio c, usuarios_admin a WHERE c.email = a.email and cpassword = a.password and email = pusuario AND password = ppassword

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM