37 lines
1.1 KiB
SQL
37 lines
1.1 KiB
SQL
disable_query_log;
|
|
|
|
CREATE DATABASE IF NOT EXISTS query_rewrite;
|
|
|
|
CREATE TABLE IF NOT EXISTS query_rewrite.rewrite_rules (
|
|
id INT NOT NULL AUTO_INCREMENT PRIMARY KEY,
|
|
pattern VARCHAR(10000) CHARACTER SET utf8 COLLATE utf8_bin NOT NULL,
|
|
pattern_database VARCHAR(20) CHARACTER SET utf8 COLLATE utf8_bin,
|
|
replacement VARCHAR(10000) CHARACTER SET utf8 COLLATE utf8_bin NOT NULL,
|
|
enabled ENUM('YES', 'NO') CHARACTER SET utf8 COLLATE utf8_bin NOT NULL
|
|
DEFAULT 'YES',
|
|
message VARCHAR(1000) CHARACTER SET utf8 COLLATE utf8_bin
|
|
) DEFAULT CHARSET = utf8 ENGINE = INNODB;
|
|
|
|
eval INSTALL PLUGIN rewriter SONAME '$REWRITER';
|
|
eval CREATE FUNCTION load_rewrite_rules RETURNS STRING SONAME '$REWRITER';
|
|
|
|
DELIMITER //;
|
|
|
|
CREATE PROCEDURE query_rewrite.flush_rewrite_rules()
|
|
BEGIN
|
|
DECLARE message_text VARCHAR(100);
|
|
COMMIT;
|
|
SELECT load_rewrite_rules() INTO message_text;
|
|
RESET QUERY CACHE;
|
|
IF NOT message_text IS NULL THEN
|
|
SIGNAL SQLSTATE '45000' SET MESSAGE_TEXT = message_text;
|
|
END IF;
|
|
END //
|
|
|
|
DELIMITER ;//
|
|
|
|
RESET QUERY CACHE;
|
|
|
|
enable_query_log;
|
|
echo # Query rewrite plugin was installed.;
|