com.genexus.db.driver.GXDBMShana Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of gxclassR Show documentation
Show all versions of gxclassR Show documentation
Core classes for the runtime used by Java and Android apps generated with GeneXus
package com.genexus.db.driver;
import java.sql.*;
import java.util.Date;
import com.genexus.CommonUtil;
public class GXDBMShana implements GXDBMS
{
private boolean forceAutoCommit;
public ResultSet executeQuery(PreparedStatement stmt, boolean hold) throws SQLException
{
return stmt.executeQuery();
}
public int executeUpdate(PreparedStatement stmt) throws SQLException
{
return stmt.executeUpdate();
}
public boolean execute(PreparedStatement stmt) throws SQLException
{
return stmt.execute();
}
public int[] executeBatch(Statement stmt) throws SQLException
{
return stmt.executeBatch();
}
public boolean isAlive(GXConnection con)
{
try
{
serverDateTime(con);
}
catch (SQLException e)
{
return false;
}
return true;
}
public void setDatabaseName(String dbName)
{
}
public String getDatabaseName()
{
return "";
}
public void setInReorg()
{
forceAutoCommit = true;
}
public boolean DataTruncation(SQLException e)
{
if (e != null && e.getSQLState() != null)
{
return (e.getErrorCode() == 0 && (e.getSQLState().equals("01004") || e.getSQLState().equals("22001")));
}
return false;
}
private DataSource dataSource;
public void setDataSource(DataSource dataSource)
{
this.dataSource = dataSource;
}
public boolean EndOfFile(SQLException e)
{
return (e.getErrorCode() == 100);
}
public boolean ReferentialIntegrity(SQLException e)
{
return (e.getErrorCode() == 429);
}
public boolean DuplicateKeyValue(SQLException e)
{
return (e.getErrorCode() == 301) || // Unique constraint violated
(e.getErrorCode() == -10709); // Timeout
}
public boolean MaskedFileNotFound(SQLException e)
{
return (e.getErrorCode() == 1299); //No data found
}
public boolean ObjectLocked(SQLException e)
{
return false;
}
public boolean ObjectNotFound(SQLException e)
{
return (e.getErrorCode() == 1299); //No data found
}
public java.util.Date nullDate()
{
return CommonUtil.ymdhmsToT_noYL(1, 1, 1, 0, 0, 0);
}
public boolean useDateTimeInDate()
{
return false;
}
public boolean useCharInDate()
{
return false;
}
public void setConnectionProperties(java.util.Properties props)
{
if (forceAutoCommit)
{
props.put("relaxAutoCommit", "true" + dataSource.jdbcAS400Lib);
}
}
public void onConnection(GXConnection con) throws SQLException
{
}
public java.util.Date serverDateTime(GXConnection con) throws SQLException
{
ResultSet rslt = con.getStatement("_ServerDT_", "SELECT CURRENT_TIMESTAMP FROM DUMMY", false).executeQuery();
rslt.next();
Date value = rslt.getTimestamp(1);
rslt.close();
return value;
}
public String serverVersion(GXConnection con) throws SQLException
{
ResultSet rslt = con.getStatement("_ServerVERSION_", "SELECT VERSION FROM M_DATABASE", false).executeQuery();
rslt.next();
String value = rslt.getString(1);
rslt.close();
return value;
}
public String connectionPhysicalId(GXConnection con)
{
try
{
ResultSet rslt = con.getStatement("_ConnectionID_", "SELECT CURRENT_CONNECTION FROM DUMMY", false).executeQuery();
rslt.next();
String value = rslt.getString(1);
rslt.close();
return value;
}
catch (SQLException e)
{
return "";
}
}
public boolean getSupportsAutocommit()
{
return true;
}
public void commit(Connection con) throws SQLException
{
if (con.getAutoCommit() == false)
con.commit();
}
public void rollback(Connection con) throws SQLException
{
if (con.getAutoCommit() == false)
con.rollback();
}
public boolean useReadOnlyConnections()
{
return true;
}
public boolean ignoreConnectionError(SQLException e)
{
return false;
}
public boolean rePrepareStatement(SQLException e)
{
return (e.getErrorCode() == 1615);
}
public boolean getSupportsQueryTimeout()
{
return true;
}
public boolean useStreamsInNullLongVarchar()
{
return false;
}
public boolean useStreamsInLongVarchar()
{
return false;
}
public int getId()
{
return DBMS_HANA;
}
public int getLockRetryCount(int lockRetryCount, int waitRecord){
return lockRetryCount;
}
public boolean connectionClosed(SQLException e)
{
return (e.getSQLState() == "08S01");
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy