Package org.apache.derby.iapi.types
Class SQLTime
- java.lang.Object
-
- org.apache.derby.iapi.types.DataType
-
- org.apache.derby.iapi.types.SQLTime
-
- All Implemented Interfaces:
java.io.Externalizable,java.io.Serializable,java.lang.Comparable,Formatable,Storable,TypedFormat,DataValueDescriptor,DateTimeDataValue,Orderable
public final class SQLTime extends DataType implements DateTimeDataValue
This contains an instance of a SQL Time Our current implementation doesn't implement time precision so the fractional seconds portion of the time is always 0. The default when no time precision is specified is 0 fractional seconds. A SQL Time without timezone information is assumed to be in the local time zone. The local time is stored as is and doesn't change if the timezone changes. This is in conformance with the SQL99 standard. The SQL92 standard indicates that the time is in GMT and changes with the timezone. The SQL99 standard clarifies this to allow time without timezoned to be stored as the local time.Time is stored as two ints. The first int represents hour, minute, second and the second represents fractional seconds (currently 0 since we don't support time precision) encodedTime = -1 indicates null PERFORMANCE OPTIMIZATION: The java.sql.Time object is only instantiated on demand for performance reasons.
- See Also:
- Serialized Form
-
-
Field Summary
Fields Modifier and Type Field Description private static java.lang.String[]AM_PMprivate static char[]ANY_SEPARATORprivate static intBASE_MEMORY_USAGEprivate intencodedTimeprivate intencodedTimeFractionprivate static char[]END_OF_STRINGprivate static charIBM_EUR_SEPARATORprivate static char[]IBM_EUR_SEPARATOR_OR_END(package private) static charJIS_SEPARATORprivate static char[]US_OR_JIS_MINUTE_END-
Fields inherited from interface org.apache.derby.iapi.types.DataValueDescriptor
UNKNOWN_LOGICAL_LENGTH
-
Fields inherited from interface org.apache.derby.iapi.types.DateTimeDataValue
DAY_FIELD, DAY_INTERVAL, FRAC_SECOND_INTERVAL, HOUR_FIELD, HOUR_INTERVAL, MINUTE_FIELD, MINUTE_INTERVAL, MONTH_FIELD, MONTH_INTERVAL, QUARTER_INTERVAL, SECOND_FIELD, SECOND_INTERVAL, WEEK_INTERVAL, YEAR_FIELD, YEAR_INTERVAL
-
Fields inherited from interface org.apache.derby.iapi.types.Orderable
ORDER_OP_EQUALS, ORDER_OP_GREATEROREQUALS, ORDER_OP_GREATERTHAN, ORDER_OP_LESSOREQUALS, ORDER_OP_LESSTHAN
-
-
Constructor Summary
Constructors Modifier Constructor Description SQLTime()no-arg constructor required by FormattableprivateSQLTime(int encodedTime, int encodedTimeFraction)SQLTime(java.lang.String timeStr, boolean isJdbcEscape, LocaleFinder localeFinder)Construct a time from a string.SQLTime(java.lang.String timeStr, boolean isJdbcEscape, LocaleFinder localeFinder, java.util.Calendar cal)Construct a time from a string.SQLTime(java.sql.Time value)
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description DataValueDescriptorcloneValue(boolean forceMaterialization)Clone this DataValueDescriptor.booleancompare(int op, DataValueDescriptor other, boolean orderedNulls, boolean unknownRV)Compare this Orderable with a given Orderable for the purpose of qualification and sorting.intcompare(DataValueDescriptor other)Orderable interface(package private) static intcomputeEncodedTime(int hour, int minute, int second)(package private) static intcomputeEncodedTime(java.util.Calendar cal)Calculate the encoded time from a Calendar object encoded time is hour << 16 + min << 8 + sec this function is also used by SQLTimestampprivate intcomputeEncodedTime(java.util.Date value)Compute encoded time value Time is represented by hour << 16 + minute << 8 + seconds(package private) static intcomputeEncodedTime(java.util.Date value, java.util.Calendar currentCal)protected static java.lang.StringencodedTimeToString(int encodedTime)Get the String version from the encodedTime.intestimateMemoryUsage()Estimate the memory usage in bytes of the data value and the overhead of the class.NumberDataValuegetDate(NumberDataValue result)Get the day of the month.(package private) intgetEncodedTime()protected static intgetHour(int encodedTime)Get the encoded hour value (may be different than hour value for current timezone if value encoded in a different timezone)NumberDataValuegetHours(NumberDataValue result)Get the hour of the day out of a time or timestamp.intgetLength()Gets the length of the data value.protected static intgetMinute(int encodedTime)Get the encoded minute value (may be different than the minute value for current timezone if value encoded in a different timezone)NumberDataValuegetMinutes(NumberDataValue result)Get the minute of the hour out of a time or timestamp.NumberDataValuegetMonth(NumberDataValue result)Get the month number out of a date.DataValueDescriptorgetNewNull()Get a new null value of the same type as this data value.java.lang.ObjectgetObject()Gets the value in the data value descriptor as a int.protected static intgetSecond(int encodedTime)Get the encoded second value (may be different than the second value for current timezone if value encoded in a different timezone)NumberDataValuegetSeconds(NumberDataValue result)Get the second of the minute out of a time or timestamp.java.lang.StringgetString()Gets the value in the data value descriptor as a String.java.sql.TimegetTime(java.util.Calendar cal)Get the time value Since this is a JDBC object we use the JDBC definition we use the JDBC definition, see JDBC API Tutorial and Reference section 47.3.12 Date is set to Jan. 1, 1970(package private) static java.sql.TimegetTime(java.util.Calendar cal, int encodedTime, int nanos)Get a java.sql.Time object from an encoded time and nano-second value.java.sql.TimestampgetTimestamp(java.util.Calendar cal)Convert a SQL TIME to a JDBC java.sql.Timestamp.intgetTypeFormatId()Return my format identifier.java.lang.StringgetTypeName()Get the SQL name of the datatypeNumberDataValuegetYear(NumberDataValue result)Get the year number out of a date.inthashCode()booleanisNull()Check if the value is null.(package private) NumberDataValuenullValueInt()private voidparseTime(java.lang.String timeStr, boolean isJdbcEscape, LocaleFinder localeFinder, java.util.Calendar cal)private voidparseTime(java.util.Date value)voidreadExternal(java.io.ObjectInput in)voidrestoreToNull()Restore this object to its (SQL)null value.protected voidsetFrom(DataValueDescriptor theValue)Set the value of this DataValueDescriptor based on the value of the specified DataValueDescriptor.voidsetInto(java.sql.PreparedStatement ps, int position)Adding this method to ensure that super class' setInto method doesn't get called that leads to the violation of JDBC spec( untyped nulls ) when batching is turned on.(package private) voidsetObject(java.lang.Object theValue)Set the value from a correctly typed Time object.(package private) static voidsetTimeInCalendar(java.util.Calendar cal, int encodedTime)Set the time portion of a date-time value into the passed in Calendar object from its encodedTime value.voidsetValue(java.lang.String theValue)Set the value of this DataValueDescriptor.voidsetValue(java.sql.Time value, java.util.Calendar cal)Set the value of this DataValueDescriptor.voidsetValue(java.sql.Timestamp value, java.util.Calendar cal)Set the value of this DataValueDescriptor.voidsetValueFromResultSet(java.sql.ResultSet resultSet, int colNumber, boolean isNullable)Set the value based on the value for the specified DataValueDescriptor from the specified ResultSet.DateTimeDataValuetimestampAdd(int intervalType, NumberDataValue intervalCount, java.sql.Date currentDate, DateTimeDataValue resultHolder)Add a number of intervals to a datetime value.NumberDataValuetimestampDiff(int intervalType, DateTimeDataValue time1, java.sql.Date currentDate, NumberDataValue resultHolder)Finds the difference between two datetime values as a number of intervals.(package private) static voidtimeToString(int hour, int minute, int second, java.lang.StringBuffer sb)Convert a time to a JDBC escape format stringjava.lang.StringtoString()private SQLTimestamptoTimestamp(java.sql.Date currentDate)inttypePrecedence()Each built-in type in JSQL has a precedence.voidwriteExternal(java.io.ObjectOutput out)-
Methods inherited from class org.apache.derby.iapi.types.DataType
checkHostVariable, cloneHolder, coalesce, compare, compare, compareTo, dataTypeConversion, equals, equals, flip, genericSetObject, getBoolean, getByte, getBytes, getDate, getDouble, getFloat, getInt, getLong, getShort, getStream, getTraceString, getTypeName, greaterOrEquals, greaterThan, hasStream, in, invalidFormat, isNotNull, isNullOp, lessOrEquals, lessThan, normalize, notEquals, outOfRange, readExternalFromArray, recycle, setBigDecimal, setInto, setObjectForCast, setToNull, setValue, setValue, setValue, setValue, setValue, setValue, setValue, setValue, setValue, setValue, setValue, setValue, setValue, setValue, setValue, setValue, setValue, throwLangSetMismatch, throwLangSetMismatch, typeToBigDecimal
-
Methods inherited from class java.lang.Object
clone, finalize, getClass, notify, notifyAll, wait, wait, wait
-
Methods inherited from interface org.apache.derby.iapi.types.DataValueDescriptor
checkHostVariable, cloneHolder, coalesce, compare, compare, equals, getBoolean, getByte, getBytes, getDate, getDouble, getFloat, getInt, getLong, getShort, getStream, getTraceString, greaterOrEquals, greaterThan, hasStream, in, isNotNull, isNullOp, lessOrEquals, lessThan, normalize, notEquals, readExternalFromArray, recycle, setBigDecimal, setInto, setObjectForCast, setToNull, setValue, setValue, setValue, setValue, setValue, setValue, setValue, setValue, setValue, setValue, setValue, setValue, setValue, setValue, setValue, setValue, setValue, typeToBigDecimal
-
-
-
-
Field Detail
-
encodedTime
private int encodedTime
-
encodedTimeFraction
private int encodedTimeFraction
-
BASE_MEMORY_USAGE
private static final int BASE_MEMORY_USAGE
-
IBM_EUR_SEPARATOR
private static final char IBM_EUR_SEPARATOR
- See Also:
- Constant Field Values
-
IBM_EUR_SEPARATOR_OR_END
private static final char[] IBM_EUR_SEPARATOR_OR_END
-
JIS_SEPARATOR
static final char JIS_SEPARATOR
- See Also:
- Constant Field Values
-
US_OR_JIS_MINUTE_END
private static final char[] US_OR_JIS_MINUTE_END
-
ANY_SEPARATOR
private static final char[] ANY_SEPARATOR
-
AM_PM
private static final java.lang.String[] AM_PM
-
END_OF_STRING
private static final char[] END_OF_STRING
-
-
Constructor Detail
-
SQLTime
public SQLTime()
no-arg constructor required by Formattable
-
SQLTime
public SQLTime(java.sql.Time value) throws StandardException- Throws:
StandardException
-
SQLTime
private SQLTime(int encodedTime, int encodedTimeFraction)
-
SQLTime
public SQLTime(java.lang.String timeStr, boolean isJdbcEscape, LocaleFinder localeFinder) throws StandardExceptionConstruct a time from a string. The allowed time formats are:- old ISO and IBM European standard: hh.mm[.ss]
- IBM USA standard: hh[:mm] {AM | PM}
- JIS and current ISO: hh:mm[:ss]
- Throws:
StandardException- if the syntax is invalid or the value is out of range
-
SQLTime
public SQLTime(java.lang.String timeStr, boolean isJdbcEscape, LocaleFinder localeFinder, java.util.Calendar cal) throws StandardExceptionConstruct a time from a string. The allowed time formats are:- old ISO and IBM European standard: hh.mm[.ss]
- IBM USA standard: hh[:mm] {AM | PM}
- JIS and current ISO: hh:mm[:ss]
- Throws:
StandardException- if the syntax is invalid or the value is out of range
-
-
Method Detail
-
estimateMemoryUsage
public int estimateMemoryUsage()
Description copied from interface:DataValueDescriptorEstimate the memory usage in bytes of the data value and the overhead of the class.- Specified by:
estimateMemoryUsagein interfaceDataValueDescriptor- Returns:
- the estimated memory usage
-
getString
public java.lang.String getString()
Description copied from interface:DataValueDescriptorGets the value in the data value descriptor as a String. Throws an exception if the data value is not a string.- Specified by:
getStringin interfaceDataValueDescriptor- Returns:
- The data value as a String.
-
getEncodedTime
int getEncodedTime()
-
getTimestamp
public java.sql.Timestamp getTimestamp(java.util.Calendar cal)
Convert a SQL TIME to a JDBC java.sql.Timestamp. Behaviour is to set the date portion of the Timestamp to the actual current date, which may not match the SQL CURRENT DATE, which remains fixed for the lifetime of a SQL statement. JDBC drivers (especially network client drivers) could not be expected to fetch the CURRENT_DATE SQL value on every query that involved a TIME value, so the current date as seen by the JDBC client was picked as the logical behaviour. See DERBY-1811.- Specified by:
getTimestampin interfaceDataValueDescriptor- Overrides:
getTimestampin classDataType- Parameters:
cal- calendar for object creation- Returns:
- The data value as a java.sql.Timestamp.
-
getObject
public java.lang.Object getObject()
Description copied from class:DataTypeGets the value in the data value descriptor as a int. Throws an exception if the data value is not receivable as a int.- Specified by:
getObjectin interfaceDataValueDescriptor- Overrides:
getObjectin classDataType- Returns:
- The data value as a int.
-
getLength
public int getLength()
Description copied from interface:DataValueDescriptorGets the length of the data value. The meaning of this is implementation-dependent. For string types, it is the number of characters in the string. For numeric types, it is the number of bytes used to store the number. This is the actual length of this value, not the length of the type it was defined as. For example, a VARCHAR value may be shorter than the declared VARCHAR (maximum) length.- Specified by:
getLengthin interfaceDataValueDescriptor- Returns:
- The length of the data value
-
getTypeName
public java.lang.String getTypeName()
Description copied from interface:DataValueDescriptorGet the SQL name of the datatype- Specified by:
getTypeNamein interfaceDataValueDescriptor- Returns:
- The SQL name of the datatype
-
getTypeFormatId
public int getTypeFormatId()
Return my format identifier.- Specified by:
getTypeFormatIdin interfaceTypedFormat- Returns:
- The identifier. (A UUID stuffed in an array of 16 bytes).
- See Also:
TypedFormat.getTypeFormatId()
-
writeExternal
public void writeExternal(java.io.ObjectOutput out) throws java.io.IOException- Specified by:
writeExternalin interfacejava.io.Externalizable- Throws:
java.io.IOException- error writing data
-
readExternal
public void readExternal(java.io.ObjectInput in) throws java.io.IOException- Specified by:
readExternalin interfacejava.io.Externalizable- Throws:
java.io.IOException- Thrown on error reading the object- See Also:
Externalizable.readExternal(java.io.ObjectInput)
-
cloneValue
public DataValueDescriptor cloneValue(boolean forceMaterialization)
Description copied from interface:DataValueDescriptorClone this DataValueDescriptor. Results in a new object that has the same value as this but can be modified independently.Even though the objects can be modified independently regardless of the value of
forceMaterialization, both the clone and the original may be dependent on the store state ifforceMaterializationis set tofalse. An example is if you need to access the value you just read usingcloneValueafter the current transaction has ended, or after the source result set has been closed.- Specified by:
cloneValuein interfaceDataValueDescriptor- Parameters:
forceMaterialization- any streams representing the data value will be materialized iftrue, the data value will be kept as a stream if possible iffalse- Returns:
- A clone of the
DataValueDescriptorwith the same initial value as this. - See Also:
DataValueDescriptor.cloneValue(boolean)
-
getNewNull
public DataValueDescriptor getNewNull()
Description copied from interface:DataValueDescriptorGet a new null value of the same type as this data value.- Specified by:
getNewNullin interfaceDataValueDescriptor- See Also:
DataValueDescriptor.getNewNull()
-
restoreToNull
public void restoreToNull()
Description copied from interface:StorableRestore this object to its (SQL)null value.- Specified by:
restoreToNullin interfaceStorable- See Also:
Storable.restoreToNull()
-
setValueFromResultSet
public void setValueFromResultSet(java.sql.ResultSet resultSet, int colNumber, boolean isNullable) throws java.sql.SQLException, StandardExceptionDescription copied from interface:DataValueDescriptorSet the value based on the value for the specified DataValueDescriptor from the specified ResultSet.- Specified by:
setValueFromResultSetin interfaceDataValueDescriptor- Parameters:
resultSet- The specified ResultSet.colNumber- The 1-based column # into the resultSet.isNullable- Whether or not the column is nullable (No need to call wasNull() if not)- Throws:
java.sql.SQLException- Thrown on errorStandardException- Thrown on error- See Also:
DataValueDescriptor.setValueFromResultSet(java.sql.ResultSet, int, boolean)
-
compare
public int compare(DataValueDescriptor other) throws StandardException
Orderable interface- Specified by:
comparein interfaceDataValueDescriptor- Parameters:
other- The Orderable to compare this one to.- Returns:
- <0 - this Orderable is less than other. 0 - this Orderable equals other. >0 - this Orderable is greater than other. The code should not explicitly look for -1, or 1.
- Throws:
StandardException- thrown on failure- See Also:
Orderable
-
compare
public boolean compare(int op, DataValueDescriptor other, boolean orderedNulls, boolean unknownRV) throws StandardExceptionDescription copied from interface:DataValueDescriptorCompare this Orderable with a given Orderable for the purpose of qualification and sorting. The caller gets to determine how nulls should be treated - they can either be ordered values or unknown values.- Specified by:
comparein interfaceDataValueDescriptor- Overrides:
comparein classDataType- Parameters:
op- Orderable.ORDER_OP_EQUALS means do an = comparison. Orderable.ORDER_OP_LESSTHAN means compare this < other. Orderable.ORDER_OP_LESSOREQUALS means compare this <= other.other- The DataValueDescriptor to compare this one to.orderedNulls- True means to treat nulls as ordered values, that is, treat SQL null as equal to null, and less than all other values. False means to treat nulls as unknown values, that is, the result of any comparison with a null is the UNKNOWN truth value.unknownRV- The return value to use if the result of the comparison is the UNKNOWN truth value. In other words, if orderedNulls is false, and a null is involved in the comparison, return unknownRV. This parameter is not used orderedNulls is true.- Returns:
- true if the comparison is true (duh!)
- Throws:
StandardException- thrown on error
-
parseTime
private void parseTime(java.util.Date value) throws StandardException- Throws:
StandardException
-
parseTime
private void parseTime(java.lang.String timeStr, boolean isJdbcEscape, LocaleFinder localeFinder, java.util.Calendar cal) throws StandardException- Throws:
StandardException
-
setObject
void setObject(java.lang.Object theValue) throws StandardExceptionSet the value from a correctly typed Time object.- Overrides:
setObjectin classDataType- Throws:
StandardException
-
setFrom
protected void setFrom(DataValueDescriptor theValue) throws StandardException
Description copied from class:DataTypeSet the value of this DataValueDescriptor based on the value of the specified DataValueDescriptor.- Overrides:
setFromin classDataType- Parameters:
theValue- The DataValueDescriptor that holds the value to which we want to set this DataValueDescriptor's value.- Throws:
StandardException
-
setValue
public void setValue(java.sql.Time value, java.util.Calendar cal) throws StandardExceptionDescription copied from class:DataTypeSet the value of this DataValueDescriptor. At DataType level just throws an error lower classes will override- Specified by:
setValuein interfaceDataValueDescriptor- Overrides:
setValuein classDataType- Parameters:
value- The Time value to set this DataValueDescriptor tocal- The time zone from the calendar is used to construct the database time value- Throws:
StandardException- thrown on failure.- See Also:
DataValueDescriptor.setValue(int)
-
setValue
public void setValue(java.sql.Timestamp value, java.util.Calendar cal) throws StandardExceptionDescription copied from class:DataTypeSet the value of this DataValueDescriptor. At DataType level just throws an error lower classes will override- Specified by:
setValuein interfaceDataValueDescriptor- Overrides:
setValuein classDataType- Parameters:
value- The Timestamp value to set this DataValueDescriptor tocal- The time zone from the calendar is used to construct the database timestamp value- Throws:
StandardException- thrown on failure.- See Also:
DataValueDescriptor.setValue(int)
-
setValue
public void setValue(java.lang.String theValue) throws StandardExceptionDescription copied from class:DataTypeSet the value of this DataValueDescriptor. At DataType level just throws an error lower classes will override- Specified by:
setValuein interfaceDataValueDescriptor- Overrides:
setValuein classDataType- Parameters:
theValue- The BigDecimal value to set this DataValueDescriptor to- Throws:
StandardException
-
nullValueInt
NumberDataValue nullValueInt()
-
getYear
public NumberDataValue getYear(NumberDataValue result) throws StandardException
Description copied from interface:DateTimeDataValueGet the year number out of a date.- Specified by:
getYearin interfaceDateTimeDataValue- Parameters:
result- The result of the previous call to this method, null if not called yet.- Returns:
- A NumberDataValue containing the year number.
- Throws:
StandardException- Thrown on error- See Also:
DateTimeDataValue.getYear(org.apache.derby.iapi.types.NumberDataValue)
-
getMonth
public NumberDataValue getMonth(NumberDataValue result) throws StandardException
Description copied from interface:DateTimeDataValueGet the month number out of a date.- Specified by:
getMonthin interfaceDateTimeDataValue- Parameters:
result- The result of the previous call to this method, null if not called yet.- Returns:
- A NumberDataValue containing the month number.
- Throws:
StandardException- Thrown on error- See Also:
DateTimeDataValue.getMonth(org.apache.derby.iapi.types.NumberDataValue)
-
getDate
public NumberDataValue getDate(NumberDataValue result) throws StandardException
Description copied from interface:DateTimeDataValueGet the day of the month.- Specified by:
getDatein interfaceDateTimeDataValue- Parameters:
result- The result of the previous call to this method, null if not called yet.- Returns:
- A NumberDataValue containing the day of the month.
- Throws:
StandardException- Thrown on error- See Also:
DateTimeDataValue.getDate(org.apache.derby.iapi.types.NumberDataValue)
-
getHours
public NumberDataValue getHours(NumberDataValue result) throws StandardException
Description copied from interface:DateTimeDataValueGet the hour of the day out of a time or timestamp.- Specified by:
getHoursin interfaceDateTimeDataValue- Parameters:
result- The result of the previous call to this method, null if not called yet.- Returns:
- A NumberDataValue containing the hour of the day.
- Throws:
StandardException- Thrown on error- See Also:
DateTimeDataValue.getHours(org.apache.derby.iapi.types.NumberDataValue)
-
getMinutes
public NumberDataValue getMinutes(NumberDataValue result) throws StandardException
Description copied from interface:DateTimeDataValueGet the minute of the hour out of a time or timestamp.- Specified by:
getMinutesin interfaceDateTimeDataValue- Parameters:
result- The result of the previous call to this method, null if not called yet.- Returns:
- A NumberDataValue containing the minute of the hour.
- Throws:
StandardException- Thrown on error- See Also:
DateTimeDataValue.getMinutes(org.apache.derby.iapi.types.NumberDataValue)
-
getSeconds
public NumberDataValue getSeconds(NumberDataValue result) throws StandardException
Description copied from interface:DateTimeDataValueGet the second of the minute out of a time or timestamp.- Specified by:
getSecondsin interfaceDateTimeDataValue- Parameters:
result- The result of the previous call to this method, null if not called yet.- Returns:
- A NumberDataValue containing the second of the minute.
- Throws:
StandardException- Thrown on error- See Also:
DateTimeDataValue.getSeconds(org.apache.derby.iapi.types.NumberDataValue)
-
toString
public java.lang.String toString()
- Overrides:
toStringin classjava.lang.Object
-
hashCode
public int hashCode()
- Overrides:
hashCodein classjava.lang.Object
-
typePrecedence
public int typePrecedence()
Description copied from class:DataTypeEach built-in type in JSQL has a precedence. This precedence determines how to do type promotion when using binary operators. For example, float has a higher precedence than int, so when adding an int to a float, the result type is float. The precedence for some types is arbitrary. For example, it doesn't matter what the precedence of the boolean type is, since it can't be mixed with other types. But the precedence for the number types is critical. The SQL standard requires that exact numeric types be promoted to approximate numeric when one operator uses both. Also, the precedence is arranged so that one will not lose precision when promoting a type.- Specified by:
typePrecedencein interfaceDataValueDescriptor- Overrides:
typePrecedencein classDataType- Returns:
- The precedence of this type.
- See Also:
DataValueDescriptor.typePrecedence()
-
isNull
public final boolean isNull()
Check if the value is null.
-
getTime
public java.sql.Time getTime(java.util.Calendar cal)
Get the time value Since this is a JDBC object we use the JDBC definition we use the JDBC definition, see JDBC API Tutorial and Reference section 47.3.12 Date is set to Jan. 1, 1970- Specified by:
getTimein interfaceDataValueDescriptor- Overrides:
getTimein classDataType- Parameters:
cal- calendar for object creation- Returns:
- The localized time value.
-
setTimeInCalendar
static void setTimeInCalendar(java.util.Calendar cal, int encodedTime)Set the time portion of a date-time value into the passed in Calendar object from its encodedTime value. Note that this is only the time down to a resolution of one second. Only the HOUR_OF_DAY, MINUTE and SECOND fields are modified. The remaining state of the Calendar is not modified.
-
getTime
static java.sql.Time getTime(java.util.Calendar cal, int encodedTime, int nanos)Get a java.sql.Time object from an encoded time and nano-second value. As required by JDBC the date component of the Time object will be set to Jan. 1, 1970- Parameters:
cal- Calendar to use for conversionencodedTime- Derby encoded time valuenanos- number of nano-seconds.- Returns:
- Valid Time object.
-
getHour
protected static int getHour(int encodedTime)
Get the encoded hour value (may be different than hour value for current timezone if value encoded in a different timezone)- Returns:
- hour value
-
getMinute
protected static int getMinute(int encodedTime)
Get the encoded minute value (may be different than the minute value for current timezone if value encoded in a different timezone)- Returns:
- minute value
-
getSecond
protected static int getSecond(int encodedTime)
Get the encoded second value (may be different than the second value for current timezone if value encoded in a different timezone)- Returns:
- second value
-
computeEncodedTime
static int computeEncodedTime(java.util.Calendar cal) throws StandardExceptionCalculate the encoded time from a Calendar object encoded time is hour << 16 + min << 8 + sec this function is also used by SQLTimestamp- Parameters:
cal- calendar with time set- Returns:
- encoded time
- Throws:
StandardException- if the time is not in the DB2 range
-
computeEncodedTime
static int computeEncodedTime(int hour, int minute, int second) throws StandardException- Throws:
StandardException
-
timeToString
static void timeToString(int hour, int minute, int second, java.lang.StringBuffer sb)Convert a time to a JDBC escape format string- Parameters:
hour-minute-second-sb- The resulting string is appended to this StringBuffer
-
encodedTimeToString
protected static java.lang.String encodedTimeToString(int encodedTime)
Get the String version from the encodedTime.- Returns:
- string value.
-
computeEncodedTime
private int computeEncodedTime(java.util.Date value) throws StandardExceptionCompute encoded time value Time is represented by hour << 16 + minute << 8 + seconds- Throws:
StandardException
-
computeEncodedTime
static int computeEncodedTime(java.util.Date value, java.util.Calendar currentCal) throws StandardException- Throws:
StandardException
-
setInto
public void setInto(java.sql.PreparedStatement ps, int position) throws java.sql.SQLException, StandardExceptionAdding this method to ensure that super class' setInto method doesn't get called that leads to the violation of JDBC spec( untyped nulls ) when batching is turned on.- Specified by:
setIntoin interfaceDataValueDescriptor- Overrides:
setIntoin classDataType- Throws:
java.sql.SQLException- thrown by the PreparedStatement objectStandardException- thrown by me accessing my value.
-
timestampAdd
public DateTimeDataValue timestampAdd(int intervalType, NumberDataValue intervalCount, java.sql.Date currentDate, DateTimeDataValue resultHolder) throws StandardException
Add a number of intervals to a datetime value. Implements the JDBC escape TIMESTAMPADD function.- Specified by:
timestampAddin interfaceDateTimeDataValue- Parameters:
intervalType- One of FRAC_SECOND_INTERVAL, SECOND_INTERVAL, MINUTE_INTERVAL, HOUR_INTERVAL, DAY_INTERVAL, WEEK_INTERVAL, MONTH_INTERVAL, QUARTER_INTERVAL, or YEAR_INTERVALintervalCount- The number of intervals to addcurrentDate- Used to convert time to timestampresultHolder- If non-null a DateTimeDataValue that can be used to hold the result. If null then generate a new holder- Returns:
- startTime + intervalCount intervals, as a timestamp
- Throws:
StandardException
-
toTimestamp
private SQLTimestamp toTimestamp(java.sql.Date currentDate) throws StandardException
- Throws:
StandardException
-
timestampDiff
public NumberDataValue timestampDiff(int intervalType, DateTimeDataValue time1, java.sql.Date currentDate, NumberDataValue resultHolder) throws StandardException
Finds the difference between two datetime values as a number of intervals. Implements the JDBC TIMESTAMPDIFF escape function.- Specified by:
timestampDiffin interfaceDateTimeDataValue- Parameters:
intervalType- One of FRAC_SECOND_INTERVAL, SECOND_INTERVAL, MINUTE_INTERVAL, HOUR_INTERVAL, DAY_INTERVAL, WEEK_INTERVAL, MONTH_INTERVAL, QUARTER_INTERVAL, or YEAR_INTERVALtime1-currentDate- Used to convert time to timestampresultHolder- If non-null a NumberDataValue that can be used to hold the result. If null then generate a new holder- Returns:
- the number of intervals by which this datetime is greater than time1
- Throws:
StandardException
-
-