/*******************************************************************************
* 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:
* sun.han - Initial API and implementation
******************************************************************************/
package com.hangum.tadpole.engine.sql.template;
import com.hangum.tadpole.commons.libs.core.define.PublicTadpoleDefine;
/**
* Queries for Altibase
*
* @author sun.han
*/
public class AltibaseDMLTemplate extends AbstractDMLTemplate {
/**
* Altibase 수행할때 preference에서 정의한 쿼리가 초과 되었을때 sub query를 수행합니다.
*/
public static final String TMP_GET_PARTDATA = " %s 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 ";
/** table - Altibase */
public static final String TMP_CREATE_TABLE_STMT =
"CREATE TABLE table_name ( " + PublicTadpoleDefine.LINE_SEPARATOR +
" column_1 CHAR(100) NOT NULL, " + PublicTadpoleDefine.LINE_SEPARATOR +
" column_2 NCHAR(100), " + PublicTadpoleDefine.LINE_SEPARATOR +
" column_3 VARCHAR(100) DEFAULT 'varchar', " + PublicTadpoleDefine.LINE_SEPARATOR +
" column_4 NVARCHAR(100), " + PublicTadpoleDefine.LINE_SEPARATOR +
" column_5 SMALLINT, " + PublicTadpoleDefine.LINE_SEPARATOR +
" column_6 INTEGER NOT NULL, " + PublicTadpoleDefine.LINE_SEPARATOR +
" column_7 REAL, " + PublicTadpoleDefine.LINE_SEPARATOR +
" column_8 DOUBLE, " + PublicTadpoleDefine.LINE_SEPARATOR +
" column_9 NUMERIC, " + PublicTadpoleDefine.LINE_SEPARATOR +
" column_10 NUMBER, " + PublicTadpoleDefine.LINE_SEPARATOR +
" column_11 DECIMAL, " + PublicTadpoleDefine.LINE_SEPARATOR +
" column_12 FLOAT, " + PublicTadpoleDefine.LINE_SEPARATOR +
" column_13 DATE, " + PublicTadpoleDefine.LINE_SEPARATOR +
" column_14 BIT, " + PublicTadpoleDefine.LINE_SEPARATOR +
" column_15 BYTE, " + PublicTadpoleDefine.LINE_SEPARATOR +
" column_16 NIBBLE, " + PublicTadpoleDefine.LINE_SEPARATOR +
" column_17 BLOB, " + PublicTadpoleDefine.LINE_SEPARATOR +
" column_18 CLOB, " + PublicTadpoleDefine.LINE_SEPARATOR +
" PRIMARY KEY " + PublicTadpoleDefine.LINE_SEPARATOR +
" ( " + PublicTadpoleDefine.LINE_SEPARATOR +
" column_1, " + PublicTadpoleDefine.LINE_SEPARATOR +
" column_6 " + PublicTadpoleDefine.LINE_SEPARATOR +
" )" + PublicTadpoleDefine.LINE_SEPARATOR +
") /* TABLESPACE tablespace_name */;" + PublicTadpoleDefine.LINE_SEPARATOR;
/** view -Altibase */
public static final String TMP_CREATE_VIEW_STMT =
"CREATE OR REPLACE VIEW view_name AS " + PublicTadpoleDefine.LINE_SEPARATOR +
" SELECT column FROM table_name;";
/** alter view template */
public static final String TMP_ALTER_VIEW_STMT = "";
/** index */
public static final String TMP_CREATE_INDEX_STMT =
"CREATE INDEX index_name "+ PublicTadpoleDefine.LINE_SEPARATOR +
" ON table_name ( column_1, column_2 );";
/** procedure */
public static final String TMP_CREATE_PROCEDURE_STMT =
"CREATE OR REPLACE PROCEDURE procedure_name (param1 OUT NUMBER) IS" + PublicTadpoleDefine.LINE_SEPARATOR +
" BEGIN " + PublicTadpoleDefine.LINE_SEPARATOR +
" SELECT COUNT(*) INTO param1 FROM table_name; " + PublicTadpoleDefine.LINE_SEPARATOR +
" END;";
/** function */
public static final String TMP_CREATE_FUNCTION_STMT =
"CREATE OR REPLACE FUNCTION function_name " + PublicTadpoleDefine.LINE_SEPARATOR +
"( " + PublicTadpoleDefine.LINE_SEPARATOR +
" param_1 IN INTEGER " + PublicTadpoleDefine.LINE_SEPARATOR +
") " + PublicTadpoleDefine.LINE_SEPARATOR +
"RETURN INTEGER " + PublicTadpoleDefine.LINE_SEPARATOR +
"AS " + PublicTadpoleDefine.LINE_SEPARATOR +
" V1 NUMBER; " + PublicTadpoleDefine.LINE_SEPARATOR +
"BEGIN " + PublicTadpoleDefine.LINE_SEPARATOR +
" v1 := param_1; " + PublicTadpoleDefine.LINE_SEPARATOR +
" SYSTEM_.PRINTLN('V1 = [' || V1 || ']'); " + PublicTadpoleDefine.LINE_SEPARATOR +
" RETURN 1; " + PublicTadpoleDefine.LINE_SEPARATOR +
"END;";
/** trigger */
public static final String TMP_CREATE_TRIGGER_STMT =
"CREATE TRIGGER trigger_name " + PublicTadpoleDefine.LINE_SEPARATOR +
" AFTER INSERT ON table_name " + PublicTadpoleDefine.LINE_SEPARATOR +
" REFERENCING NEW ROW NEW_ROW " + PublicTadpoleDefine.LINE_SEPARATOR +
" FOR EACH ROW " + PublicTadpoleDefine.LINE_SEPARATOR +
"AS " + PublicTadpoleDefine.LINE_SEPARATOR +
" RTN INTEGER; " + PublicTadpoleDefine.LINE_SEPARATOR +
" BEGIN " + PublicTadpoleDefine.LINE_SEPARATOR +
" RTN := SENDMSG('127.0.0.1', 12345, 'insert into table_name : '||NEW_ROW.column_1||','||NEW_ROW.column_2, 1);" + PublicTadpoleDefine.LINE_SEPARATOR +
"END;";
}