com.frameworkset.orm.adapter.DBDerby Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of bboss-persistent Show documentation
Show all versions of bboss-persistent Show documentation
bboss is a j2ee framework include aop/ioc,mvc,persistent,taglib,rpc,event ,bean-xml serializable and so on.http://www.bbossgroups.com
/*
* Copyright 2008 biaoping.yin
*
* Licensed 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 com.frameworkset.orm.adapter;
/*
*
* Licensed 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.
*/
import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import com.frameworkset.orm.adapter.DB.PagineSql;
/**
* This is used to connect to an embedded Apache Derby Database using
* the supplied JDBC driver.
*
* @author Henning P. Schmiedehausen
* @version $Id: DBDerby.java,v 1.2 2005/01/31 19:43:55 tfischer Exp $
*/
public class DBDerby
extends DB
{
/**
* Empty constructor.
*/
protected DBDerby()
{
}
/**
* This method is used to ignore case.
*
* @param in The string to transform to upper case.
* @return The upper case string.
*/
public String toUpperCase(String str)
{
return new StringBuilder("UPPER(")
.append(str)
.append(")")
.toString();
}
/**
* This method is used to ignore case.
*
* @param in The string whose case to ignore.
* @return The string in a case that can be ignored.
*/
public String ignoreCase(String str)
{
return toUpperCase(str);
}
/**
* @see com.frameworkset.orm.adapter.DB#getIDMethodType()
*/
public String getIDMethodType()
{
return NO_ID_METHOD; // @todo IDENTITY;
}
/**
* @see com.frameworkset.orm.adapter.DB#getIDMethodSQL(Object obj)
*/
public String getIDMethodSQL(Object obj)
{
return ""; // @todo VALUES IDENTITY_VAL_LOCAL()";
}
/**
* Locks the specified table.
*
* @param con The JDBC connection to use.
* @param table The name of the table to lock.
* @exception SQLException No Statement could be created or executed.
*/
public void lockTable(Connection con, String table)
throws SQLException
{
Statement statement = con.createStatement();
StringBuilder stmt = new StringBuilder();
stmt.append("LOCK TABLE ")
.append(table).append(" IN EXCLUSIVE MODE");
statement.executeUpdate(stmt.toString());
}
/**
* Unlocks the specified table.
*
* @param con The JDBC connection to use.
* @param table The name of the table to unlock.
* @exception SQLException No Statement could be created or executed.
*/
public void unlockTable(Connection con, String table)
throws SQLException
{
}
/**
* This method is used to check whether the database supports
* limiting the size of the resultset.
*
* @return LIMIT_STYLE_DB2.
*/
public int getLimitStyle()
{
return DB.LIMIT_STYLE_DB2;
}
public int getSCROLLType(String dbdriver)
{
return ResultSet.TYPE_SCROLL_INSENSITIVE;
}
public int getCusorType(String dbdriver)
{
return ResultSet.CONCUR_READ_ONLY;
}
/**
* 获取指定数据的分页数据sql语句
* @param sql
* @return
*/
public PagineSql getDBPagineSql(String sql, long offset, int maxsize,boolean prepared,String orderby) {
StringBuilder ret = null;
if(prepared)
ret = new StringBuilder().append("SELECT * FROM (SELECT b.*, ROW_NUMBER () OVER (").append(orderby).append(") AS rownums FROM (").append(sql).append(") b) WHERE rownums <= ? and rownums >=?");
else
{
ret = new StringBuilder().append("SELECT * FROM (SELECT b.*, ROW_NUMBER () OVER (").append(orderby).append(") AS rownums FROM (").append(sql).append(") b) WHERE rownums <= ").append(offset + maxsize).append(" and rownums >=").append(offset + 1);
}
return new PagineSql(ret.toString(),offset + maxsize,offset + 1,offset, maxsize, prepared).setRebuilded(true);
//// return new StringBuilder(sql).append(" limit ").append(offset).append(",").append(maxsize).toString();
// StringBuilder newsql = new StringBuilder();
// if(prepared)
// {
// newsql.append("SELECT t.* FROM (SELECT res.* ,row_number() over(").append(orderby).append(") r FROM (").append(sql)
// .append(")) t where t.r <= ? and t.r >= ?");
//
//
// /**
// * StringBuilder ret = null;
// if(prepared)
// ret = new StringBuilder().append("select ss1.* from (select tt1.*,rownum rowno_ from (").append(sql).append(
// ") tt1 where rownum <= ?) ss1 where ss1.rowno_ >= ?");
// else
// ret = new StringBuilder("select ss1.* from (select tt1.*,rownum rowno_ from (").append(sql).append(
// ") tt1 where rownum <= ").append((offset + maxsize)).append(") ss1 where ss1.rowno_ >= ").append(
// (offset + 1));
// return new PagineSql(ret.toString(),offset + maxsize,offset + 1,offset, maxsize, prepared);
// */
// return new PagineSql(newsql.toString(),offset + maxsize,offset + 1,offset, maxsize, prepared);
// }
// else
// {
// newsql.append("SELECT t.* FROM (SELECT res.* ,row_number() over(").append(orderby).append(") r FROM (").append(sql)
// .append(")) t where t.r <= ").append(offset + maxsize).append(" and t.r >= ").append(offset + 1).append("");
// return new PagineSql(newsql.toString(),offset + maxsize,offset + 1,offset, maxsize, prepared);
// }
}
public String getStringPagineSql(String sql,String orderby)
{
// StringBuilder newsql = new StringBuilder();
// newsql.append("SELECT t.* FROM (SELECT res.* ,row_number() over(").append(orderby).append(") r FROM (").append(sql)
// .append(")) t where t.r <= ? and t.r >= ?");
// return newsql.toString();
StringBuilder ret = new StringBuilder().append("SELECT * FROM (SELECT b.*, ROW_NUMBER () OVER (").append(orderby).append(") AS rownums FROM (").append(sql).append(") b) WHERE rownums <= ? and rownums >=?");
return ret.toString();
}
public String getStringPagineSql(String schema,String tablename,String pkname ,String columns,String orderby)
{
// StringBuilder newsql = new StringBuilder();
// newsql.append("SELECT t.* FROM (SELECT res.* ,row_number() over(").append(orderby).append(") r FROM (").append("SELECT ");
// if(columns != null && ! columns.equals(""))
// {
// newsql.append( columns);
// }
// else
// newsql.append("* ");
// newsql.append(" from ");
// if(schema != null && !schema.equals(""))
// newsql.append(schema).append(".");
// newsql.append( tablename)
// .append(")) t where t.r <= ? and t.r >= ?");
// return newsql.toString();
StringBuilder newsql = new StringBuilder().append("SELECT * FROM (SELECT b.*, ROW_NUMBER () OVER (").append(orderby).append(") AS rownums FROM (").append("SELECT ");
if(columns != null && ! columns.equals(""))
{
newsql.append( columns);
}
else
newsql.append("* ");
newsql.append(" from ");
if(schema != null && !schema.equals(""))
newsql.append(schema).append(".");
newsql.append( tablename).append(") b) WHERE rownums <= ? and rownums >=?");
return newsql.toString();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy