All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.quinsoft.zeidon.dbhandler.AccessJdbcTranslator Maven / Gradle / Ivy

There is a newer version: 2.2.0
Show newest version
/**
    This file is part of the Zeidon Java Object Engine (Zeidon JOE).

    Zeidon JOE is free software: you can redistribute it and/or modify
    it under the terms of the GNU Lesser General Public License as published by
    the Free Software Foundation, either version 3 of the License, or
    (at your option) any later version.

    Zeidon JOE is distributed in the hope that it will be useful,
    but WITHOUT ANY WARRANTY; without even the implied warranty of
    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
    GNU Lesser General Public License for more details.

    You should have received a copy of the GNU Lesser General Public License
    along with Zeidon JOE.  If not, see .

    Copyright 2009-2015 QuinSoft
 */

package com.quinsoft.zeidon.dbhandler;



import org.joda.time.DateTime;

import com.quinsoft.zeidon.Task;
import com.quinsoft.zeidon.dbhandler.AbstractSqlHandler.SqlStatement;
import com.quinsoft.zeidon.domains.DateDomain;
import com.quinsoft.zeidon.domains.DateTimeDomain;
import com.quinsoft.zeidon.domains.Domain;
import com.quinsoft.zeidon.objectdefinition.AttributeDef;

/**
 * JDBC translator for MS Access DBs.  This extends the standard JDBC translator
 * and overrides the few methods as needed.
 *
 * @author DG
 *
 */
public class AccessJdbcTranslator extends StandardJdbcTranslator
{
    /**
     * @param task
     * @param application TODO
     */
    public AccessJdbcTranslator(Task task, JdbcHandler handler )
    {
        super( task, handler );
    }

    /* (non-Javadoc)
     * @see com.quinsoft.zeidon.dbhandler.JdbcDomainTranslator#getAttributeValue(java.lang.StringBuilder, com.quinsoft.zeidon.objectdefinition.DataField, com.quinsoft.zeidon.EntityInstance)
     */
    @Override
    public boolean appendSqlValue(SqlStatement stmt, StringBuilder buffer, Domain domain, AttributeDef attributeDef, Object value)
    {
        // If we're binding all the values we'll let the parent class handle it.
        if ( bindAllValues )
            return super.appendSqlValue( stmt, buffer, domain, attributeDef, value );

        if ( value == null )
            return super.appendSqlValue( stmt, buffer, domain, attributeDef, null );

        /*
         * Access dates are denoted in JDBC as date strings surrounded by '#'.
         * E.g. #2001-04-30#
         */

        if ( domain instanceof DateTimeDomain )
        {
            // Convert the value (likely a string) to a date.
            Object v = domain.convertExternalValue( getTask(), null, attributeDef, null, value );
            String str = dateTimeFormatter.print( (DateTime) v );
            buffer.append( "#" ).append( str ).append( "#" );
            return true;
        }

        if ( domain instanceof DateDomain )
        {
            // Convert the value (likely a string) to a date.
            Object v = domain.convertExternalValue( getTask(), null, attributeDef, null, value );
            String str = dateFormatter.print( (DateTime) v );
            buffer.append( "#" ).append( str ).append( "#" );
            return true;
        }

        return super.appendSqlValue( stmt, buffer, domain, attributeDef, value );
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy