60 lines
1.3 KiB
MySQL
60 lines
1.3 KiB
MySQL
|
DELIMITER $$
|
||
|
CREATE OR REPLACE DEFINER=`root`@`localhost` PROCEDURE `vn`.`client_RandomList`(vNumber INT)
|
||
|
BEGIN
|
||
|
|
||
|
DECLARE i INT DEFAULT 0;
|
||
|
DECLARE c INT DEFAULT 0;
|
||
|
DECLARE maxClientFk INT;
|
||
|
|
||
|
DROP TEMPORARY TABLE IF EXISTS tmp.client;
|
||
|
|
||
|
CREATE TEMPORARY TABLE tmp.`client`
|
||
|
(id INT AUTO_INCREMENT,
|
||
|
clientFk INT,
|
||
|
isSelected TINYINT(1) NOT NULL DEFAULT 0,
|
||
|
PRIMARY KEY(id),
|
||
|
UNIQUE KEY clientFk (clientFk))
|
||
|
ENGINE = MEMORY;
|
||
|
|
||
|
INSERT INTO tmp.client(clientFk)
|
||
|
SELECT DISTINCT clientFk
|
||
|
FROM vn.invoiceOut
|
||
|
WHERE issued > TIMESTAMPADD(MONTH, -2, util.VN_CURDATE());
|
||
|
|
||
|
SELECT max(id) INTO maxClientFk
|
||
|
FROM tmp.client;
|
||
|
|
||
|
|
||
|
WHILE i < vNumber DO
|
||
|
|
||
|
SET i = i + 1;
|
||
|
|
||
|
WHILE c = 0 DO
|
||
|
|
||
|
SELECT id INTO c
|
||
|
FROM tmp.client
|
||
|
WHERE id = floor(RAND() * maxClientFk) + 1
|
||
|
AND isSelected = FALSE
|
||
|
LIMIT 1;
|
||
|
|
||
|
END WHILE;
|
||
|
|
||
|
-- SELECT i, maxClientFk, c;
|
||
|
|
||
|
UPDATE tmp.client
|
||
|
SET isSelected = TRUE
|
||
|
WHERE id = c;
|
||
|
|
||
|
SET c = 0;
|
||
|
|
||
|
END WHILE;
|
||
|
|
||
|
SELECT c.id, c.name FROM tmp.client tc
|
||
|
JOIN vn.client c ON c.id = tc.clientFk
|
||
|
WHERE isSelected
|
||
|
ORDER BY clientFk;
|
||
|
|
||
|
|
||
|
END$$
|
||
|
DELIMITER ;
|