/******************************************************************************* * Copyright (c) 2013 hangum. * All rights reserved. This program and the accompanying materials * are made available under the terms of the GNU Lesser Public License v2.1 * which accompanies this distribution, and is available at * http://www.gnu.org/licenses/old-licenses/gpl-2.0.html * * Contributors: * hangum - initial API and implementation ******************************************************************************/ package com.hangum.tadpole.engine.sql.template; import com.hangum.tadpole.commons.libs.core.define.PublicTadpoleDefine; /** * MySQL 디비의 쿼리를 정의 합니다. * * @author hangum * */ public class MySQLDMLTemplate extends AbstractDMLTemplate { /** * mysql 을 수행할때 preference에서 정의한 쿼리가 초과 되었을때 sub query를 수행합니다. */ public static final String TMP_GET_PARTDATA = "SELECT tdb_a.* FROM (%s) tdb_a LIMIT %s,%s"; /** * explain */ public static final String TMP_EXPLAIN_EXTENDED = "explain extended "; /** * explain FORMAT=json (greate than 5.6) */ public static final String TMP_EXPLAIN_EXTENDED_JSON = "explain format=json "; public static final String TMP_DIALOG_CREATE_TABLE = "CREATE TABLE %s (id INT(11) UNSIGNED NOT NULL PRIMARY KEY AUTO_INCREMENT) " + PublicTadpoleDefine.LINE_SEPARATOR + " DEFAULT CHARACTER SET %s " + PublicTadpoleDefine.LINE_SEPARATOR + " DEFAULT COLLATE %s " + PublicTadpoleDefine.LINE_SEPARATOR + " ENGINE = %s"; /** table - mysql */ public static final String TMP_CREATE_TABLE_STMT = "CREATE TABLE {#schema#}.sample_table ( " + PublicTadpoleDefine.LINE_SEPARATOR + " id INT(11) default NULL auto_increment, " + PublicTadpoleDefine.LINE_SEPARATOR + " name char(60) default NULL, " + PublicTadpoleDefine.LINE_SEPARATOR + " PRIMARY KEY (id) " + PublicTadpoleDefine.LINE_SEPARATOR + ");"; /** view -mysql */ public static final String TMP_CREATE_VIEW_STMT = "CREATE VIEW {#schema#}.view_name AS " + PublicTadpoleDefine.LINE_SEPARATOR + " SELECT columns FROM {#schema#}.table_name;"; /** alter view template */ public static final String TMP_ALTER_VIEW_STMT = "ALTER ALGORITHM=UNDEFINED DEFINER='%s'@'%' " + PublicTadpoleDefine.LINE_SEPARATOR + " SQL SECURITY DEFINER VIEW '%s' AS " + PublicTadpoleDefine.LINE_SEPARATOR; /** index */ public static final String TMP_CREATE_INDEX_STMT = "CREATE INDEX index_name "+ PublicTadpoleDefine.LINE_SEPARATOR + " ON {#schema#}.table_name ( columns );"; /** constraints */ public static final String TMP_CREATE_CONSTRAINTS_STMT = "ALTER TABLE {#schema#}.sample_table ADD COLUMN `author` int(10) unsigned NOT NULL ; "+ PublicTadpoleDefine.LINE_SEPARATOR + "ALTER TABLE {#schema#}.sample_table ADD INDEX (author) ; "+ PublicTadpoleDefine.LINE_SEPARATOR + "ALTER TABLE {#schema#}.sample_table ADD FOREIGN KEY (author) REFERENCES `users` (`id`) ; "+ PublicTadpoleDefine.LINE_SEPARATOR; /** procedure */ public static final String TMP_CREATE_PROCEDURE_STMT = "CREATE PROCEDURE {#schema#}.simpleproc (OUT param1 INT) " + PublicTadpoleDefine.LINE_SEPARATOR + "BEGIN " + PublicTadpoleDefine.LINE_SEPARATOR + " SELECT COUNT(*) INTO param1 FROM {#schema#}.sample_table; " + PublicTadpoleDefine.LINE_SEPARATOR + "END;"; /** function */ public static final String TMP_CREATE_FUNCTION_STMT = "CREATE FUNCTION {#schema#}.hello (s CHAR(20)) RETURNS CHAR(50) " + PublicTadpoleDefine.LINE_SEPARATOR + "RETURN CONCAT('Hello, ', s, '!!!');"; /** trigger */ public static final String TMP_CREATE_TRIGGER_STMT = "CREATE TRIGGER {#schema#}.testref BEFORE INSERT ON {#schema#}.test1 " + PublicTadpoleDefine.LINE_SEPARATOR + "FOR EACH ROW BEGIN " + PublicTadpoleDefine.LINE_SEPARATOR + " INSERT INTO {#schema#}.test2 SET a2 = NEW.a1; " + PublicTadpoleDefine.LINE_SEPARATOR + " DELETE FROM {#schema#}.test3 WHERE a3 = NEW.a1; " + PublicTadpoleDefine.LINE_SEPARATOR + " UPDATE {#schema#}.test4 SET b4 = b4 + 1 WHERE a4 = NEW.a1; " + PublicTadpoleDefine.LINE_SEPARATOR + "END;"; }