org.apache.cayenne.dba.hsqldb.HSQLDBNoSchemaAdapter Maven / Gradle / Ivy
/*****************************************************************
* 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.cayenne.dba.hsqldb;
import org.apache.cayenne.map.DbEntity;
/**
* A flavor of HSQLDBAdapter that implements workarounds for some old driver limitations.
*
* @since 1.2
* @author Mike Kienenberger
*/
public class HSQLDBNoSchemaAdapter extends HSQLDBAdapter {
/**
* Generate unqualified name without schema.
*
* @since 1.2
*/
protected String getTableName(DbEntity entity)
{
return entity.getName();
}
/**
* Generate unqualified name.
*
* @since 1.2
*/
protected String getSchemaName(DbEntity entity) {
return "";
}
/**
* Returns a SQL string to drop a table corresponding to ent
DbEntity.
*
* @since 1.2
*/
public String dropTable(DbEntity ent) {
// hsqldb doesn't support schema namespaces, so remove if found
return "DROP TABLE " + getTableName(ent);
}
/**
* Uses unqualified entity names.
*
* @since 1.2
*/
public String createTable(DbEntity ent) {
String sql = super.createTable(ent);
// hsqldb doesn't support schema namespaces, so remove if found
String fqnCreate = "CREATE CACHED TABLE " + super.getTableName(ent) + " (";
if (sql != null && sql.toUpperCase().startsWith(fqnCreate)) {
sql = "CREATE CACHED TABLE "
+ getTableName(ent)
+ " ("
+ sql.substring(fqnCreate.length());
}
return sql;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy