com.frameworkset.orm.adapter.DBElasticsearch Maven / Gradle / Ivy
/*
* 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 com.frameworkset.common.poolman.NestedSQLException;
import com.frameworkset.common.poolman.PreparedDBUtil;
import com.frameworkset.common.poolman.SQLExecutor;
import com.frameworkset.common.poolman.handle.NullRowHandler;
import com.frameworkset.orm.platform.PlatformMysqlImpl;
import com.frameworkset.util.SimpleStringUtil;
import org.frameworkset.util.annotations.DateFormateMeta;
import java.lang.reflect.Method;
import java.sql.*;
import java.text.SimpleDateFormat;
import java.util.Date;
/**
* This is used in order to connect to a MySQL database using the MM
* drivers. Simply comment the above and uncomment this code below and
* fill in the appropriate values for DB_NAME, DB_HOST, DB_USER,
* DB_PASS.
*
*
* http://www.worldserver.com/mm.mysql/
*
"jdbc:mysql://" + DB_HOST + "/" + DB_NAME + "?user=" +
* DB_USER + "&password=" + DB_PASS;
*
* @author Jon S. Stevens
* @author Brett McLaughlin
* @author Daniel Rall
* @version $Id: DBMM.java,v 1.13 2005/01/31 19:43:55 tfischer Exp $
*/
public class DBElasticsearch extends DBMM
{
private static final String serialUtilClass = "org.frameworkset.elasticsearch.serial.SerialUtil";
private static DateFormateMeta dateFormateMeta = null;
static {
try {
Class clazz = Class.forName(serialUtilClass);
Method getDateFormateMeta = clazz.getMethod("getDateFormateMeta");
dateFormateMeta = (DateFormateMeta) getDateFormateMeta.invoke(null);
}
catch (Exception e){
}
}
// /** A specialized date format for MySQL. */
// public static final String DATE_FORMAT = "yyyy-MM-dd HH:mm:ss";
private static final String defaultFiledTodateFormat = "yyyy-MM-dd'T'HH:mm:ss.SSS'Z'";
public String sysdate()
{
return "NOW";
}
/**
* Empty protected constructor.
*/
protected DBElasticsearch()
{
this.platform = new PlatformMysqlImpl();
FORMART_YEAR = "yyyy";
FORMART_MONTH = "MM";
FORMART_DAY = "dd";
FORMART_HOUR = "HH";
FORMART_MINUTE = "mm";
FORMART_SECOND = "%ss";
FORMART_ALL = "yyyy-MM-dd'T'HH:mm:ss.SSS'Z'";
FORMART_YEAR_MM_DD = "%yyyy-MM-dd";
FORMART_HH_MM_SS = "HH:mm:ss.SSS";
}
public boolean columnLableUpperCase(){
return false;
}
public String getDBCatalog(Connection con) throws SQLException{
return _getDBCatalog( con);
}
/**
* 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 in)
{
return in;
}
/**
* 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 in)
{
return in;
}
/**
* @see DB#getIDMethodType()
*/
public String getIDMethodType()
{
return AUTO_INCREMENT;
}
/**
* Returns the SQL to get the database key of the last row
* inserted, which in this case is SELECT
* LAST_INSERT_ID()
.
*
* @see DB#getIDMethodSQL(Object obj)
*/
public String getIDMethodSQL(Object obj)
{
return "SELECT LAST_INSERT_ID()";
}
/**
* 采用mysql官方生成主键方法,但是有并发干扰问题
* 例如,一个con来生成不同表的主键时,由于时间顺序问题可能出现以下情况:
* 第一个表执行了"UPDATE "+sequence +" SET id=LAST_INSERT_ID(id+1)",正要执行"SELECT LAST_INSERT_ID()"时
* 第二个表先于第一个表执行完"UPDATE "+sequence +" SET id=LAST_INSERT_ID(id+1)","SELECT LAST_INSERT_ID()"两步,第二个得到正确的主键值
* 最终第一个表在执行"SELECT LAST_INSERT_ID()"时,结果得到的是第二个表的主键值,导致不正确的结果出现。
*/
// public long getNextValue(String sequence,Connection con,String dbname) throws SQLException
// {
// long curValue = 0;
// PreparedDBUtil dbutil = new PreparedDBUtil();
// boolean flag = false;
// try {
//// if()
// if(con == null)
// {
// con = PreparedDBUtil.getConection(dbname);
//// System.out.println("getNextValue:"+con);
// flag = true;
// }
// dbutil.executeUpdate(dbname, "UPDATE "+sequence +" SET id=LAST_INSERT_ID(id+1)",con);
// dbutil.executeSelect(dbname,"SELECT LAST_INSERT_ID()",con);
// if(dbutil.size() <= 0)
// {
//// System.out.println("select " + this.generator + ".nextval from dual");
// throw new SQLException("[SELECT nextval('"+sequence+"')] from [" + dbname + "] failed:retrun records is 0.");
// }
// curValue = dbutil.getLong(0,0);
//
// return curValue;
//
// } catch (SQLException e) {
// throw e;
// }
// finally{
// if(flag )
// {
// if(con != null)con.close();
// }
// }
//
// }
private static final String sql_sequence = "select nextval(?) as pk";
public long getNextValue(String sequence,Connection con,String dbname) throws SQLException
{
// long curValue = 0;
PreparedDBUtil dbutil = new PreparedDBUtil();
dbutil.preparedSelect(dbname, sql_sequence);
dbutil.setString(1, sequence);
dbutil.executePrepared();
return dbutil.getLong(0, 0);
}
public long getNextValue(String seqfunctionname,String sequence,Connection con,String dbname) throws SQLException
{
// long curValue = 0;
PreparedDBUtil dbutil = new PreparedDBUtil();
if(seqfunctionname == null || seqfunctionname.equals(""))
dbutil.preparedSelect(dbname, sql_sequence);
else
dbutil.preparedSelect(dbname, "select " + seqfunctionname + "(?) as pk");
dbutil.setString(1, sequence);
dbutil.executePrepared();
return dbutil.getLong(0, 0);
}
/**
* 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(" WRITE");
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
{
Statement statement = con.createStatement();
statement.executeUpdate("UNLOCK TABLES");
}
/**
* This method is used to chek whether the database natively
* supports limiting the size of the resultset.
*
* @return True.
*/
public boolean supportsNativeLimit()
{
return true;
}
/**
* This method is used to chek whether the database natively
* supports returning results starting at an offset position other
* than 0.
*
* @return True.
*/
public boolean supportsNativeOffset()
{
return true;
}
/**
* This method is used to chek whether the database supports
* limiting the size of the resultset.
*
* @return LIMIT_STYLE_MYSQL.
*/
public int getLimitStyle()
{
return DB.LIMIT_STYLE_MYSQL;
}
public String to_char(String date,String format)
{
StringBuilder ret = new StringBuilder();
ret.append("date_format(")
.append(date)
.append(",'")
.append(format != null?format:FORMART_ALL)
.append("')");
return ret.toString();
}
public String to_char(String date)
{
return to_char(date,FORMART_ALL);
}
/**
* This method overrides the JDBC escapes used to format dates
* using a DateFormat
. As of version 2.0.11, the MM
* JDBC driver does not implement JDBC 3.0 escapes.
*
* @param date the date to format
* @return The properly formatted date String.
* @deprecated use to_date function.
*/
public String getDateString(Date date)
{
return to_date(date,this.date_format);
}
/**
* This method overrides the JDBC escapes used to format dates
* using a DateFormat
. As of version 2.0.11, the MM
* JDBC driver does not implement JDBC 3.0 escapes.
*
* @param date the date to format
* @return The properly formatted date String.
* @deprecated use to_date function.
*/
public String getDateString(Date date,String format)
{
return to_date(date,format);
}
/**
* This method overrides the JDBC escapes used to format dates
* using a DateFormat
. As of version 2.0.11, the MM
* JDBC driver does not implement JDBC 3.0 escapes.
*
* @param date the date to format
* @return The properly formatted date String.
* @deprecated use to_date function.
*/
public String getDateString(String date)
{
return to_date(date,this.date_format);
}
/**
* This method overrides the JDBC escapes used to format dates
* using a DateFormat
. As of version 2.0.11, the MM
* JDBC driver does not implement JDBC 3.0 escapes.
*
* @param date the date to format
* @return The properly formatted date String.
* @deprecated use to_date function.
*/
public String getDateString(String date,String format)
{
return to_date(date,format);
}
/**
* This method overrides the JDBC escapes used to format dates
* using a DateFormat
. As of version 2.0.11, the MM
* JDBC driver does not implement JDBC 3.0 escapes.
*
* @param date the date to format
* @return The properly formatted date String.
*/
public String to_date(Date date)
{
return to_date(date,this.date_format);
}
/**
* This method overrides the JDBC escapes used to format dates
* using a DateFormat
. As of version 2.0.11, the MM
* JDBC driver does not implement JDBC 3.0 escapes.
*
* @param date the date to format
* @return The properly formatted date String.
*/
public String to_date(Date date,String format)
{
if(date == null)
return null;
char delim = getStringDelimiter();
return (delim + new SimpleDateFormat(format == null?this.date_format:format).format(date) + delim);
}
/**
* This method overrides the JDBC escapes used to format dates
* using a DateFormat
. As of version 2.0.11, the MM
* JDBC driver does not implement JDBC 3.0 escapes.
*
* @param date the date to format
* @return The properly formatted date String.
*/
public String to_date(String date)
{
return to_date(date,this.date_format);
}
/**
* This method overrides the JDBC escapes used to format dates
* using a DateFormat
. As of version 2.0.11, the MM
* JDBC driver does not implement JDBC 3.0 escapes.
*
* @param date the date to format
* @return The properly formatted date String.
*/
public String to_date(String date,String format)
{
if(date == null)
return null;
char delim = getStringDelimiter();
return (delim + new SimpleDateFormat(format == null?this.date_format:format).format(SimpleStringUtil.stringToDate(date,format)) + delim);
}
/**
* This method is used to format any date string.
*
* @param date the Date to format
* @return The date formatted String for Oracle.
*/
public String filedToDateFunction(String date)
{
if(date == null)
return null;
// char delim = getStringDelimiter();
//str_to_date(a.end_time,'%Y%m%d %H:%i:%s')
return new StringBuilder().append("str_to_date(").append(date ).append(",'").append( defaultFiledTodateFormat).append("')").toString();
// return date;
}
/**
* This method is used to format any date string.
*
* @param date the Date to format
* @return The date formatted String for Oracle.
*/
public String filedToDateFunction(String date,String format)
{
if(date == null)
return null;
return new StringBuilder().append("str_to_date(").append(date ).append(",'").append( format).append("')").toString();
}
/**
* 数据库主键最大值的获取方法
*/
public String getIDMAXSql(String table_name,String table_id_name,String table_id_prefix,String type)
{
//SUBSTR(table_id_name,LENGTH(table_id_prefix))
String maxSql = "select max("+ table_id_name + ") from " + table_name;
if(type.equalsIgnoreCase("string") || type.equalsIgnoreCase("java.lang.string"))
{
if(table_id_prefix != null && !table_id_prefix.trim().equals(""))
{
maxSql = "select max(CAST(SUBSTRING(" + table_id_name + ",len(" + table_id_prefix + ") + 1) as DECIMAL))) from " + table_name;
}
else
{
maxSql = "select max(CAST(" + table_id_name + " as DECIMAL)) from " + table_name;
}
}
return maxSql;
}
/**
* 获取指定数据的分页数据sql语句
* @param sql
* @return
*/
public PagineSql getDBPagineSql(String sql, long offset, int maxsize,boolean prepared) {
// return new StringBuilder(sql).append(" limit ").append(offset).append(",").append(maxsize).toString();
StringBuilder newsql = null;
if(prepared)
newsql = new StringBuilder().append(sql).append(" limit ?,?");
else
newsql = new StringBuilder().append(sql).append(" limit ").append(offset).append(",").append(maxsize);
return new PagineSql(newsql.toString(),offset,(long)maxsize,offset, maxsize, prepared).setRebuilded(true);
}
public String getStringPagineSql(String sql)
{
StringBuilder newsql = new StringBuilder().append(sql).append(" limit ?,?");
return newsql.toString();
}
public String getStringPagineSql(String schema,String tablename,String pkname ,String columns)
{
StringBuilder sqlbuilder = new StringBuilder();
sqlbuilder.append("SELECT ");
if(columns != null && ! columns.equals(""))
{
sqlbuilder.append( columns);
}
else
sqlbuilder.append("* ");
sqlbuilder.append(" from ");
if(schema != null && !schema.equals(""))
sqlbuilder.append(schema).append(".");
sqlbuilder.append( tablename);
sqlbuilder.append( " limit ?,?");
return sqlbuilder.toString();
}
/**
* 获取指定数据的分页数据sql语句
* @param sql
* @return
*/
public PagineSql getDBPagineSql(String sql, long offset, int maxsize,boolean prepared,String orderBy) {
// return new StringBuilder(sql).append(" limit ").append(offset).append(",").append(maxsize).toString();
StringBuilder newsql = null;
if(prepared)
newsql = new StringBuilder().append(sql).append(" ").append(orderBy).append(" limit ?,?");
else
newsql = new StringBuilder().append(sql).append(" ").append(orderBy).append(" limit ").append(offset).append(",").append(maxsize);
return new PagineSql(newsql.toString(),offset,(long)maxsize,offset, maxsize, prepared).setRebuilded(true);
}
public String getStringPagineSql(String sql,String orderBy)
{
StringBuilder newsql = new StringBuilder().append(sql).append(" ").append(orderBy).append(" limit ?,?");
return newsql.toString();
}
public String getStringPagineSql(String schema,String tablename,String pkname ,String columns,String orderBy)
{
StringBuilder sqlbuilder = new StringBuilder();
sqlbuilder.append("SELECT ");
if(columns != null && ! columns.equals(""))
{
sqlbuilder.append( columns);
}
else
sqlbuilder.append("* ");
sqlbuilder.append(" from ");
if(schema != null && !schema.equals(""))
sqlbuilder.append(schema).append(".");
sqlbuilder.append( tablename);
sqlbuilder.append(" ").append(orderBy).append( " limit ?,?");
return sqlbuilder.toString();
}
public void queryByNullRowHandler(NullRowHandler handler,String dbname,String pageinestatement,long offset,int pagesize) throws SQLException
{
SQLExecutor.queryWithDBNameByNullRowHandler(handler, dbname, pageinestatement,offset,pagesize);
}
public void resetPostion( PreparedStatement statement,int startidx,int endidx,long offset,int maxsize) throws SQLException
{
statement.setLong(startidx, offset);
statement.setLong(endidx, maxsize);
}
public Object getLONGVARBINARY(CallableStatement cstmt,int parameterIndex) throws SQLException
{
return cstmt.getBlob(parameterIndex);
}
public Object getLONGVARCHAR(CallableStatement cstmt,int parameterIndex) throws SQLException
{
return cstmt.getClob(parameterIndex);
}
public Object getLONGVARCHAR(ResultSet res,int parameterIndex) throws SQLException
{
return res.getClob(parameterIndex);
}
public Object getLONGVARBINARY(ResultSet res,int parameterIndex) throws SQLException
{
return res.getBlob(parameterIndex);
}
public Object getLONGVARBINARY(CallableStatement cstmt,String parameterIndex) throws SQLException
{
return cstmt.getBlob(parameterIndex);
}
public Object getLONGVARCHAR(CallableStatement cstmt,String parameterIndex) throws SQLException
{
return cstmt.getClob(parameterIndex);
}
public Object getLONGVARCHAR(ResultSet res,String parameterIndex) throws SQLException
{
return res.getClob(parameterIndex);
}
public Object getLONGVARBINARY(ResultSet res,String parameterIndex) throws SQLException
{
return res.getBlob(parameterIndex);
}
public String concat(String ... concatString)
{
if(concatString == null || concatString.length == 0)
return "";
StringBuilder ret = new StringBuilder();
boolean i = false;
for(String token : concatString)
{
if(!i)
{
ret.append("concat(").append(token);
i = true;
}
else
{
ret.append( " , ").append(token);
}
}
ret.append(")");
return ret.toString();
}
public String disableFK(String table,String FKName)
{
StringBuilder ret = new StringBuilder();
ret.append("alter table ").append(table).append(" drop FOREIGN KEY ").append(FKName);
return ret.toString();
}
public String enableFK(String table,String FKName,String column,String FKTable,String FKColumn)
{
StringBuilder ret = new StringBuilder();
ret.append("alter table ").append(table).append(" add constraint ").append(FKName)
.append(" foreign key (").append(column).append(") references ").append(FKTable).append(" (").append(FKColumn).append(")");
return ret.toString();
}
public boolean neadGetGenerateKeys()
{
return true;
}
@Override
public void setObject(PreparedStatement statement, PreparedStatement statement_count, int parameterIndex, Object x) throws SQLException {
if(x != null) {
if (x instanceof String) {
statement.setString(parameterIndex, (String) x);
if (statement_count != null) {
statement_count.setString(parameterIndex, (String) x);
}
}
else if (x instanceof Integer ) {
statement.setInt(parameterIndex, (Integer) x);
if (statement_count != null) {
statement_count.setInt(parameterIndex, (Integer) x);
}
}
else if (x instanceof Long ) {
statement.setLong(parameterIndex, (Long) x);
if (statement_count != null) {
statement_count.setLong(parameterIndex, (Long) x);
}
}
else if (x instanceof Short ) {
statement.setShort(parameterIndex, (Short) x);
if (statement_count != null) {
statement_count.setShort(parameterIndex, (Short) x);
}
}
else if (x instanceof Double ) {
statement.setDouble(parameterIndex, (Double) x);
if (statement_count != null) {
statement_count.setDouble(parameterIndex, (Double) x);
}
}
else if (x instanceof Float ) {
statement.setFloat(parameterIndex, (Float) x);
if (statement_count != null) {
statement_count.setFloat(parameterIndex, (Float) x);
}
}
else if (x instanceof Date ) {
if(dateFormateMeta != null){
String dateStr = dateFormateMeta.toDateFormat().format((Date)x);
statement.setString(parameterIndex, dateStr);
if (statement_count != null) {
statement_count.setString(parameterIndex, dateStr);
}
}
else {
Long time = ((Date)x).getTime();
statement.setLong(parameterIndex,time);
if (statement_count != null) {
statement_count.setLong(parameterIndex, time);
}
}
}
else {
throw new NestedSQLException(x.getClass().getName() +" not supported");
}
}
else{
statement.setNull(parameterIndex, Types.VARCHAR);
if (statement_count != null) {
statement_count.setNull(parameterIndex, Types.VARCHAR);
}
}
}
}