當前位置: 首頁>>代碼示例>>Java>>正文


Java DatabaseMeta.requiresCastToVariousForIsNull方法代碼示例

本文整理匯總了Java中org.pentaho.di.core.database.DatabaseMeta.requiresCastToVariousForIsNull方法的典型用法代碼示例。如果您正苦於以下問題:Java DatabaseMeta.requiresCastToVariousForIsNull方法的具體用法?Java DatabaseMeta.requiresCastToVariousForIsNull怎麽用?Java DatabaseMeta.requiresCastToVariousForIsNull使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在org.pentaho.di.core.database.DatabaseMeta的用法示例。


在下文中一共展示了DatabaseMeta.requiresCastToVariousForIsNull方法的4個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: setLookup

import org.pentaho.di.core.database.DatabaseMeta; //導入方法依賴的package包/類
public void setLookup(RowMetaInterface rowMeta) throws KettleDatabaseException
{
    data.lookupParameterRowMeta = new RowMeta();
    data.lookupReturnRowMeta = new RowMeta();
    
    DatabaseMeta databaseMeta = meta.getDatabaseMeta();
    
    String sql = "SELECT ";

    for (int i = 0; i < meta.getUpdateLookup().length; i++)
    {
        if (i != 0) sql += ", ";
        sql += databaseMeta.quoteField(meta.getUpdateLookup()[i]);
        data.lookupReturnRowMeta.addValueMeta( rowMeta.searchValueMeta(meta.getUpdateStream()[i]).clone() );
    }

    sql += " FROM " + data.schemaTable + " WHERE ";

    for (int i = 0; i < meta.getKeyLookup().length; i++)
    {
        if (i != 0){
        	sql += " AND ";
        } 
        
        sql += " ( ( ";
        
        sql += databaseMeta.quoteField(meta.getKeyLookup()[i]);
        if ("BETWEEN".equalsIgnoreCase(meta.getKeyCondition()[i]))
        {
            sql += " BETWEEN ? AND ? ";
            data.lookupParameterRowMeta.addValueMeta( rowMeta.searchValueMeta(meta.getKeyStream()[i]) );
            data.lookupParameterRowMeta.addValueMeta( rowMeta.searchValueMeta(meta.getKeyStream2()[i]) );
        }
        else
        {
            if ("IS NULL".equalsIgnoreCase(meta.getKeyCondition()[i]) || "IS NOT NULL".equalsIgnoreCase(meta.getKeyCondition()[i]))
            {
                sql += " " + meta.getKeyCondition()[i] + " ";
            }
            else if ("= ~NULL".equalsIgnoreCase(meta.getKeyCondition()[i])){
            	
            	sql += " IS NULL AND ";
                
            	if (databaseMeta.requiresCastToVariousForIsNull()) {
                    sql += " CAST(? AS VARCHAR(256)) IS NULL ";
                }
                else{
                    sql += " ? IS NULL ";
                }
            	// null check
                data.lookupParameterRowMeta.addValueMeta( rowMeta.searchValueMeta(meta.getKeyStream()[i]) );
                sql += " ) OR ( "+ databaseMeta.quoteField(meta.getKeyLookup()[i])+" = ? ";
                // equality check, cloning so auto-rename because of adding same fieldname does not cause problems
                data.lookupParameterRowMeta.addValueMeta( rowMeta.searchValueMeta(meta.getKeyStream()[i]).clone() );
            	
            }
            else
            {
                sql += " " + meta.getKeyCondition()[i] + " ? ";
                data.lookupParameterRowMeta.addValueMeta( rowMeta.searchValueMeta(meta.getKeyStream()[i]) );
            }
        }
        sql += " ) ) ";
    }
    
    try
    {
        if(log.isDetailed()) logDetailed("Setting preparedStatement to [" + sql + "]");
        data.prepStatementLookup = data.db.getConnection().prepareStatement(databaseMeta.stripCR(sql));
    }
    catch (SQLException ex)
    {
        throw new KettleDatabaseException("Unable to prepare statement for SQL statement [" + sql + "]", ex);
    }
}
 
開發者ID:yintaoxue,項目名稱:read-open-source-code,代碼行數:76,代碼來源:InsertUpdate.java

示例2: prepareUpdate

import org.pentaho.di.core.database.DatabaseMeta; //導入方法依賴的package包/類
public void prepareUpdate(RowMetaInterface rowMeta) throws KettleDatabaseException
{
    DatabaseMeta databaseMeta = meta.getDatabaseMeta();
    data.updateParameterRowMeta = new RowMeta();
    
    String sql = "UPDATE " + data.schemaTable + Const.CR;
    sql += "SET ";
    
    boolean comma=false;
    
    for (int i=0;i<meta.getUpdateLookup().length;i++)
    {
		if ( meta.getUpdate()[i].booleanValue() ) {
            if (comma) sql+= ",   ";
            else comma=true;
            
            sql += databaseMeta.quoteField(meta.getUpdateLookup()[i]);
            sql += " = ?" + Const.CR;
            data.updateParameterRowMeta.addValueMeta( rowMeta.searchValueMeta(meta.getUpdateStream()[i]).clone() );
		}
    }

    sql += "WHERE ";

    for (int i=0;i<meta.getKeyLookup().length;i++)
    {
        if (i!=0) sql += "AND   ";
        sql += " ( ( ";
        sql += databaseMeta.quoteField(meta.getKeyLookup()[i]);
        if ("BETWEEN".equalsIgnoreCase(meta.getKeyCondition()[i]))
        {
            sql += " BETWEEN ? AND ? ";
            data.updateParameterRowMeta.addValueMeta( rowMeta.searchValueMeta(meta.getKeyStream()[i]) );
            data.updateParameterRowMeta.addValueMeta( rowMeta.searchValueMeta(meta.getKeyStream2()[i]) );
        }
        else
        if ("IS NULL".equalsIgnoreCase(meta.getKeyCondition()[i]) || "IS NOT NULL".equalsIgnoreCase(meta.getKeyCondition()[i]))
        {
            sql += " "+meta.getKeyCondition()[i]+" ";
        }
        else if ("= ~NULL".equalsIgnoreCase(meta.getKeyCondition()[i])){
        	
        	sql += " IS NULL AND ";
            
        	if (databaseMeta.requiresCastToVariousForIsNull()) {
                sql += "CAST(? AS VARCHAR(256)) IS NULL";
            }
            else{
                sql += "? IS NULL";
            }
        	// null check
            data.updateParameterRowMeta.addValueMeta( rowMeta.searchValueMeta(meta.getKeyStream()[i]) );
            sql += " ) OR ( "+ databaseMeta.quoteField(meta.getKeyLookup()[i])+" = ?";
            // equality check, cloning so auto-rename because of adding same fieldname does not cause problems
            data.updateParameterRowMeta.addValueMeta( rowMeta.searchValueMeta(meta.getKeyStream()[i]).clone() );
        	
        }              
        else
        {
            sql += " "+meta.getKeyCondition()[i]+" ? ";
            data.updateParameterRowMeta.addValueMeta( rowMeta.searchValueMeta(meta.getKeyStream()[i]).clone() );
        }
        sql += " ) ) ";
    }

    try
    {
    	if(log.isDetailed()) logDetailed("Setting update preparedStatement to ["+sql+"]");
        data.prepStatementUpdate=data.db.getConnection().prepareStatement(databaseMeta.stripCR(sql));
    }
    catch(SQLException ex) 
    {
        throw new KettleDatabaseException("Unable to prepare statement for SQL statement [" + sql + "]", ex);
    }
}
 
開發者ID:yintaoxue,項目名稱:read-open-source-code,代碼行數:76,代碼來源:InsertUpdate.java

示例3: setLookup

import org.pentaho.di.core.database.DatabaseMeta; //導入方法依賴的package包/類
public void setLookup(RowMetaInterface rowMeta) throws KettleDatabaseException
{
    data.lookupParameterRowMeta = new RowMeta();
    data.lookupReturnRowMeta = new RowMeta();
    
    DatabaseMeta databaseMeta = meta.getDatabaseMeta();
    
    String sql = "SELECT ";

    for (int i = 0; i < meta.getUpdateLookup().length; i++)
    {
        if (i != 0) sql += ", ";
        sql += databaseMeta.quoteField(meta.getUpdateLookup()[i]);
        data.lookupReturnRowMeta.addValueMeta( rowMeta.searchValueMeta(meta.getUpdateStream()[i]) );
    }

    sql += " FROM " + data.schemaTable + " WHERE ";

    for (int i = 0; i < meta.getKeyLookup().length; i++)
    {
        if (i != 0){
        	sql += " AND ";
        } 
        
        sql += " ( ( ";
        
        sql += databaseMeta.quoteField(meta.getKeyLookup()[i]);
        if ("BETWEEN".equalsIgnoreCase(meta.getKeyCondition()[i]))
        {
            sql += " BETWEEN ? AND ? ";
            data.lookupParameterRowMeta.addValueMeta( rowMeta.searchValueMeta(meta.getKeyStream()[i]) );
            data.lookupParameterRowMeta.addValueMeta( rowMeta.searchValueMeta(meta.getKeyStream2()[i]) );
        }
        else
        {
            if ("IS NULL".equalsIgnoreCase(meta.getKeyCondition()[i]) || "IS NOT NULL".equalsIgnoreCase(meta.getKeyCondition()[i]))
            {
                sql += " " + meta.getKeyCondition()[i] + " ";
            }
            else if ("= ~NULL".equalsIgnoreCase(meta.getKeyCondition()[i])){
            	
            	sql += " IS NULL AND ";
                
            	if (databaseMeta.requiresCastToVariousForIsNull()) {
                    sql += "CAST(? AS VARCHAR(256)) IS NULL";
                }
                else{
                    sql += "? IS NULL";
                }
            	// null check
                data.lookupParameterRowMeta.addValueMeta( rowMeta.searchValueMeta(meta.getKeyStream()[i]) );
                sql += " ) OR ( "+ databaseMeta.quoteField(meta.getKeyLookup()[i])+" = ?";
                // equality check, cloning so auto-rename because of adding same fieldname does not cause problems
                data.lookupParameterRowMeta.addValueMeta( rowMeta.searchValueMeta(meta.getKeyStream()[i]).clone() );
            	
            }
            else
            {
                sql += " " + meta.getKeyCondition()[i] + " ? ";
                data.lookupParameterRowMeta.addValueMeta( rowMeta.searchValueMeta(meta.getKeyStream()[i]) );
            }
        }
        sql += " ) ) ";
    }
    
    try
    {
        if(log.isDetailed()) logDetailed("Setting preparedStatement to [" + sql + "]");
        data.prepStatementLookup = data.db.getConnection().prepareStatement(databaseMeta.stripCR(sql));
    }
    catch (SQLException ex)
    {
        throw new KettleDatabaseException("Unable to prepare statement for SQL statement [" + sql + "]", ex);
    }
    
}
 
開發者ID:yintaoxue,項目名稱:read-open-source-code,代碼行數:77,代碼來源:Update.java

示例4: prepareUpdate

import org.pentaho.di.core.database.DatabaseMeta; //導入方法依賴的package包/類
public void prepareUpdate(RowMetaInterface rowMeta) throws KettleDatabaseException
{
    DatabaseMeta databaseMeta = meta.getDatabaseMeta();
    data.updateParameterRowMeta = new RowMeta();
    
    String sql = "UPDATE " + data.schemaTable + Const.CR;
    sql += "SET ";

    for (int i=0;i<meta.getUpdateLookup().length;i++)
    {
        if (i!=0) sql+= ",   ";
        sql += databaseMeta.quoteField(meta.getUpdateLookup()[i]);
        sql += " = ?" + Const.CR;
        data.updateParameterRowMeta.addValueMeta( rowMeta.searchValueMeta(meta.getUpdateStream()[i]) );
    }

    sql += "WHERE ";

    for (int i=0;i<meta.getKeyLookup().length;i++)
    {
        if (i!=0) sql += "AND   ";
        sql += " ( ( ";
        sql += databaseMeta.quoteField(meta.getKeyLookup()[i]);
        if ("BETWEEN".equalsIgnoreCase(meta.getKeyCondition()[i]))
        {
            sql += " BETWEEN ? AND ? ";
            data.updateParameterRowMeta.addValueMeta( rowMeta.searchValueMeta(meta.getKeyStream()[i]) );
            data.updateParameterRowMeta.addValueMeta( rowMeta.searchValueMeta(meta.getKeyStream2()[i]) );
        }
        else if ("IS NULL".equalsIgnoreCase(meta.getKeyCondition()[i]) || "IS NOT NULL".equalsIgnoreCase(meta.getKeyCondition()[i]))
        {
            sql += " "+meta.getKeyCondition()[i]+" ";
        }
        else if ("= ~NULL".equalsIgnoreCase(meta.getKeyCondition()[i])){
        	
        	sql += " IS NULL AND ";
            
        	if (databaseMeta.requiresCastToVariousForIsNull()) {
                sql += "CAST(? AS VARCHAR(256)) IS NULL";
            }
            else{
                sql += "? IS NULL";
            }
        	// null check
            data.updateParameterRowMeta.addValueMeta( rowMeta.searchValueMeta(meta.getKeyStream()[i]) );
            sql += " ) OR ( "+ databaseMeta.quoteField(meta.getKeyLookup()[i])+" = ?";
            // equality check, cloning so auto-rename because of adding same fieldname does not cause problems
            data.updateParameterRowMeta.addValueMeta( rowMeta.searchValueMeta(meta.getKeyStream()[i]).clone() );
        	
        }            
        else
        {
            sql += " "+meta.getKeyCondition()[i]+" ? ";
            data.updateParameterRowMeta.addValueMeta( rowMeta.searchValueMeta(meta.getKeyStream()[i]) );
        }
        sql += " ) ) ";
    }
    try
    {            
    	if(log.isDetailed()) logDetailed("Setting update preparedStatement to ["+sql+"]");
        data.prepStatementUpdate=data.db.getConnection().prepareStatement(databaseMeta.stripCR(sql));
    }
    catch(SQLException ex) 
    {
        throw new KettleDatabaseException("Unable to prepare statement for SQL statement [" + sql + "]", ex);
    }
}
 
開發者ID:yintaoxue,項目名稱:read-open-source-code,代碼行數:68,代碼來源:Update.java


注:本文中的org.pentaho.di.core.database.DatabaseMeta.requiresCastToVariousForIsNull方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。