
org.apache.ojb.broker.accesslayer.conversions.Calendar2TimestampFieldConversion Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of db-ojb Show documentation
Show all versions of db-ojb Show documentation
ObJectRelationalBridge (OJB) is an Object/Relational mapping tool that
allows transparent persistence for Java Objects against relational
databases.
The newest version!
package org.apache.ojb.broker.accesslayer.conversions;
/* Copyright 2004-2005 The Apache Software Foundation
*
* 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.Timestamp;
import java.util.Calendar;
import java.util.GregorianCalendar;
/**
* This implementation of the {@link FieldConversion} interface converts
* between {@link java.util.Calendar} and {@link java.sql.Timestamp}. When
* convert sql to java always a {@link java.util.GregorianCalendar} object
* is returned.
*
* @author Guillaume Nodet
* @version $Id: Calendar2TimestampFieldConversion.java,v 1.1 2007-08-24 22:17:31 ewestfal Exp $
*/
public class Calendar2TimestampFieldConversion implements FieldConversion
{
/**
* @see FieldConversion#javaToSql(Object)
*/
public Object javaToSql(Object source)
{
if (source instanceof Calendar)
{
// only valid >= JDK 1.4
// return new Date(((Calendar) source).getTimeInMillis());
return new Timestamp(((Calendar) source).getTime().getTime());
}
else
{
return source;
}
}
/**
* @see FieldConversion#sqlToJava(Object)
*/
public Object sqlToJava(Object source)
{
if (source instanceof Timestamp)
{
GregorianCalendar cal = new GregorianCalendar();
// only valid >= JDK 1.4
// cal.setTimeInMillis(((Date) source).getTime());
cal.setTime(((Timestamp) source));
return cal;
}
else
{
return source;
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy