sql >> Databáze >  >> RDS >> Mysql

Mysql dynamicky vytváří řetězec dotazu v uložené proceduře založené na logice

Řešením je použít příkaz execute a concat:

CREATE DEFINER=`root`@`localhost` PROCEDURE `test`(input VARCHAR(15))
BEGIN
SET @input = input;

if @input="asc" then
    SET @sort = " order by ActivityLogKey asc";
elseif @input = "desc" then
    SET @sort = " order by ActivityLogKey desc";
else
    SET @sort ="";
end if;

SET @query = CONCAT('select * from activitylog ',@sort,' limit 0, 5');

PREPARE stmt FROM @query;
EXECUTE stmt;
DEALLOCATE PREPARE stmt;

END



  1. Jak HOUR() funguje v MariaDB

  2. PHP změní čárku na <br />

  3. Vyberte poslední záznam v tabulce (pole datum a čas)

  4. Jak určit hodnoty pro chybějící měsíce na základě dat z předchozích měsíců v T-SQL