All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.empire.db.hsql.DBDatabaseDriverHSql Maven / Gradle / Ivy

There is a newer version: 3.2.0
Show newest version
/*
 * Licensed to the Apache Software Foundation (ASF) under one
 * or more contributor license agreements.  See the NOTICE file
 * distributed with this work for additional information
 * regarding copyright ownership.  The ASF licenses this file
 * to you under the Apache License, Version 2.0 (the
 * "License"); you may not use this file except in compliance
 * with the License.  You may obtain a copy of the License at
 *
 *  http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing,
 * software distributed under the License is distributed on an
 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
 * KIND, either express or implied.  See the License for the
 * specific language governing permissions and limitations
 * under the License.
 */
package org.apache.empire.db.hsql;

import java.sql.Connection;
import java.util.GregorianCalendar;

import org.apache.empire.data.DataType;
import org.apache.empire.db.DBCmdType;
import org.apache.empire.db.DBCommand;
import org.apache.empire.db.DBDDLGenerator;
import org.apache.empire.db.DBDatabase;
import org.apache.empire.db.DBDatabaseDriver;
import org.apache.empire.db.DBDriverFeature;
import org.apache.empire.db.DBObject;
import org.apache.empire.db.DBSQLScript;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;


/**
 * This class provides support for the HSQLDB database system.
* * * */ public class DBDatabaseDriverHSql extends DBDatabaseDriver { private final static long serialVersionUID = 1L; private static final Logger log = LoggerFactory.getLogger(DBDatabaseDriverHSql.class); /** * Defines the HSQLDB command type. */ public static class DBCommandHSql extends DBCommand { private static final long serialVersionUID = 1L; /** * @param db the database * @see org.apache.empire.db.DBCommand */ public DBCommandHSql(DBDatabase db) { super(db); } } private DBDDLGenerator ddlGenerator = null; // lazy creation /** * Constructor for the HSQLDB database driver. */ public DBDatabaseDriverHSql() { // Add "count" to list of reserved keywords reservedSQLKeywords.add("count"); } /** * Creates a new HSQLDB command object. * * @return the new DBCommandHSql object */ @Override public DBCommand createCommand(DBDatabase db) { if (db == null) return null; // create command object return new DBCommandHSql(db); } /** * Returns whether or not a particular feature is supported by this driver * @param type type of requested feature. @see DBDriverFeature * @return true if the features is supported or false otherwise */ @Override public boolean isSupported(DBDriverFeature type) { switch (type) { // return support info case CREATE_SCHEMA: return false; case SEQUENCES: return true; default: // All other features are not supported by default return false; } } /** * Gets an sql phrase template for this database system.
* @see DBDatabaseDriver#getSQLPhrase(int) * @return the phrase template */ @Override public String getSQLPhrase(int phrase) { switch (phrase) { // sql-phrases case SQL_NULL_VALUE: return "null"; case SQL_PARAMETER: return " ? "; case SQL_RENAME_TABLE: return " "; case SQL_RENAME_COLUMN: return " AS "; case SQL_DATABASE_LINK: return "@"; case SQL_QUOTES_OPEN: return "\""; case SQL_QUOTES_CLOSE: return "\""; case SQL_CONCAT_EXPR: return "concat(?, {0})"; // " + " leads to problems if operands are case when statements that return empty string // data types case SQL_BOOLEAN_TRUE: return String.valueOf(Boolean.TRUE); case SQL_BOOLEAN_FALSE: return String.valueOf(Boolean.FALSE); case SQL_CURRENT_DATE: return "CURRENT_DATE"; case SQL_DATE_PATTERN: return "yyyy-MM-dd"; case SQL_DATE_TEMPLATE: return "'{0}'"; case SQL_CURRENT_DATETIME: return "CURRENT_TIMESTAMP"; case SQL_DATETIME_PATTERN: return "yyyy-MM-dd HH:mm:ss.S"; case SQL_DATETIME_TEMPLATE: return "'{0}'"; // functions case SQL_FUNC_COALESCE: return "coalesce(?, {0})"; case SQL_FUNC_SUBSTRING: return "substr(?, {0})"; case SQL_FUNC_SUBSTRINGEX: return "substr(?, {0}, {1})"; case SQL_FUNC_REPLACE: return "replace(?, {0}, {1})"; case SQL_FUNC_REVERSE: return "?"; // "reverse(?)"; case SQL_FUNC_STRINDEX: return "locate({0}, ?)"; case SQL_FUNC_STRINDEXFROM: return "locate({0}, ?, {1})"; case SQL_FUNC_UPPER: return "ucase(?)"; case SQL_FUNC_LOWER: return "lcase(?)"; case SQL_FUNC_LENGTH: return "length(?)"; case SQL_FUNC_TRIM: return "trim(?)"; case SQL_FUNC_LTRIM: return "ltrim(?)"; case SQL_FUNC_RTRIM: return "rtrim(?)"; case SQL_FUNC_ESCAPE: return "? escape '{0}'"; // Numeric case SQL_FUNC_ABS: return "abs(?)"; case SQL_FUNC_ROUND: return "round(?,{0})"; case SQL_FUNC_TRUNC: return "truncate(?,{0})"; case SQL_FUNC_CEILING: return "ceiling(?)"; case SQL_FUNC_FLOOR: return "floor(?)"; // Date case SQL_FUNC_DAY: return "day(?)"; case SQL_FUNC_MONTH: return "month(?)"; case SQL_FUNC_YEAR: return "year(?)"; // Aggregation case SQL_FUNC_SUM: return "sum(?)"; case SQL_FUNC_MAX: return "max(?)"; case SQL_FUNC_MIN: return "min(?)"; case SQL_FUNC_AVG: return "avg(?)"; // Others case SQL_FUNC_DECODE: return "case ?{0} end"; case SQL_FUNC_DECODE_SEP: return " "; case SQL_FUNC_DECODE_PART: return "when {0} then {1}"; case SQL_FUNC_DECODE_ELSE: return "else {0}"; // Not defined default: log.error("SQL phrase " + phrase + " is not defined!"); return "?"; } } /** * @see DBDatabaseDriver#getConvertPhrase(DataType, DataType, Object) */ @Override public String getConvertPhrase(DataType destType, DataType srcType, Object format) { switch (destType) { /* * case DBExpr.DT_BOOL: return "convert(bit, ?)"; case DBExpr.DT_INTEGER: return "convert(int, ?)"; case * DBExpr.DT_DECIMAL: return "convert(decimal, ?)"; case DBExpr.DT_NUMBER: return "convert(float, ?)"; case * DBExpr.DT_DATE: return "convert(datetime, ?, 111)"; case DBExpr.DT_DATETIME: return "convert(datetime, ?, 120)"; */ // Convert to text case TEXT: case CHAR: if (format != null) { // Convert using a format string if (srcType == DataType.INTEGER || srcType == DataType.AUTOINC) { log.error("getConvertPhrase: unknown type " + destType); return "?"; } else { return "to_char(?, '"+format.toString()+"')"; } } return "convert(?, CHAR)"; case INTEGER: { return "convert(?, BIGINT)"; } case DECIMAL: { return "convert(?, DECIMAL)"; } case FLOAT: { return "convert(?, DOUBLE)"; } // Unknown Type default: log.error("getConvertPhrase: unknown type (" + String.valueOf(destType)); return "?"; } } /** * @see DBDatabaseDriver#getNextSequenceValue(DBDatabase, String, int, Connection) */ @Override public Object getNextSequenceValue(DBDatabase db, String seqName, int minValue, Connection conn) { //Use Oracle Sequences StringBuilder sql = new StringBuilder(80); sql.append("SELECT "); sql.append("NEXT VALUE FOR "); db.appendQualifiedName(sql, seqName, detectQuoteName(seqName)); sql.append(" FROM INFORMATION_SCHEMA.SYSTEM_SEQUENCES WHERE SEQUENCE_NAME='"+ seqName.toUpperCase() + "'"); Object val = db.querySingleValue(sql.toString(), null, conn); if (val == null) { // Error! log.error("getNextSequenceValue: Invalid sequence value for sequence " + seqName); } // Done return val; } /** * Overridden. Returns a timestamp that is used for record updates created by the database server. * * @return the current date and time of the database server. */ @Override public java.sql.Timestamp getUpdateTimestamp(Connection conn) { // Default implementation GregorianCalendar cal = new GregorianCalendar(); return new java.sql.Timestamp(cal.getTimeInMillis()); } /** * @see DBDatabaseDriver#getDDLScript(DBCmdType, DBObject, DBSQLScript) */ @Override public void getDDLScript(DBCmdType type, DBObject dbo, DBSQLScript script) { if (ddlGenerator==null) ddlGenerator = new HSqlDDLGenerator(this); // forward request ddlGenerator.getDDLScript(type, dbo, script); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy