Class Timestamp
- All Implemented Interfaces:
Serializable
,Cloneable
,Comparable<Date>
A thin wrapper around java.util.Date
that allows
the JDBC API to identify this as an SQL TIMESTAMP
value.
It adds the ability
to hold the SQL TIMESTAMP
fractional seconds value, by allowing
the specification of fractional seconds to a precision of nanoseconds.
A Timestamp also provides formatting and
parsing operations to support the JDBC escape syntax for timestamp values.
The precision of a Timestamp object is calculated to be either:
19
, which is the number of characters in yyyy-mm-dd hh:mm:ss-
20 + s
, which is the number of characters in the yyyy-mm-dd hh:mm:ss.[fff...] ands
represents the scale of the given Timestamp, its fractional seconds precision.
Note: This type is a composite of a java.util.Date
and a
separate nanoseconds value. Only integral seconds are stored in the
java.util.Date
component. The fractional seconds - the nanos - are
separate. The Timestamp.equals(Object)
method never returns
true
when passed an object
that isn't an instance of java.sql.Timestamp
,
because the nanos component of a date is unknown.
As a result, the Timestamp.equals(Object)
method is not symmetric with respect to the
java.util.Date.equals(Object)
method. Also, the hashCode
method uses the underlying
java.util.Date
implementation and therefore does not include nanos in its computation.
Due to the differences between the Timestamp
class
and the java.util.Date
class mentioned above, it is recommended that code not view
Timestamp
values generically as an instance of
java.util.Date
. The
inheritance relationship between Timestamp
and java.util.Date
really
denotes implementation inheritance, and not type inheritance.
- Since:
- 1.1
- See Also:
-
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionboolean
Indicates whether thisTimestamp
object is later than the givenTimestamp
object.boolean
Indicates whether thisTimestamp
object is earlier than the givenTimestamp
object.int
Compares thisTimestamp
object to the givenTimestamp
object.int
Compares thisTimestamp
object to the givenDate
object.boolean
Tests to see if thisTimestamp
object is equal to the given object.boolean
Tests to see if thisTimestamp
object is equal to the givenTimestamp
object.static Timestamp
Obtains an instance ofTimestamp
from anInstant
object.int
getNanos()
Gets thisTimestamp
object'snanos
value.long
getTime()
Returns the number of milliseconds since January 1, 1970, 00:00:00 GMT represented by thisTimestamp
object.int
hashCode()
Returns a hash code value for this object.void
setNanos
(int n) Sets thisTimestamp
object'snanos
field to the given value.void
setTime
(long time) Sets thisTimestamp
object to represent a point in time that istime
milliseconds after January 1, 1970 00:00:00 GMT.Converts thisTimestamp
object to anInstant
.Converts thisTimestamp
object to aLocalDateTime
.toString()
Formats a timestamp in JDBC timestamp escape format.static Timestamp
Converts aString
object in JDBC timestamp escape format to aTimestamp
value.static Timestamp
valueOf
(LocalDateTime dateTime) Obtains an instance ofTimestamp
from aLocalDateTime
object, with the same year, month, day of month, hours, minutes, seconds and nanos date-time value as the providedLocalDateTime
.Methods declared in class java.util.Date
after, before, clone, getDate, getDay, getHours, getMinutes, getMonth, getSeconds, getTimezoneOffset, getYear, parse, setDate, setHours, setMinutes, setMonth, setSeconds, setYear, toGMTString, toLocaleString, UTC
-
Constructor Details
-
Timestamp
@Deprecated(since="1.2") public Timestamp(int year, int month, int date, int hour, int minute, int second, int nano) Deprecated.instead use the constructorTimestamp(long millis)
Constructs aTimestamp
object initialized with the given values.- Parameters:
year
- the year minus 1900month
- 0 to 11date
- 1 to 31hour
- 0 to 23minute
- 0 to 59second
- 0 to 59nano
- 0 to 999,999,999- Throws:
IllegalArgumentException
- if the nano argument is out of bounds
-
Timestamp
public Timestamp(long time) Constructs aTimestamp
object using a milliseconds time value. The integral seconds are stored in the underlying date value; the fractional seconds are stored in thenanos
field of theTimestamp
object.- Parameters:
time
- milliseconds since January 1, 1970, 00:00:00 GMT. A negative number is the number of milliseconds before January 1, 1970, 00:00:00 GMT.- See Also:
-
-
Method Details
-
setTime
-
getTime
-
valueOf
Converts aString
object in JDBC timestamp escape format to aTimestamp
value.- Parameters:
s
- timestamp in formatyyyy-[m]m-[d]d hh:mm:ss[.f...]
. The fractional seconds may be omitted. The leading zero formm
anddd
may also be omitted.- Returns:
- corresponding
Timestamp
value - Throws:
IllegalArgumentException
- if the given argument does not have the formatyyyy-[m]m-[d]d hh:mm:ss[.f...]
-
toString
-
getNanos
public int getNanos()Gets thisTimestamp
object'snanos
value.- Returns:
- this
Timestamp
object's fractional seconds component - See Also:
-
setNanos
public void setNanos(int n) Sets thisTimestamp
object'snanos
field to the given value.- Parameters:
n
- the new fractional seconds component- Throws:
IllegalArgumentException
- if the given argument is greater than 999999999 or less than 0- See Also:
-
equals
Tests to see if thisTimestamp
object is equal to the givenTimestamp
object.- Parameters:
ts
- theTimestamp
value to compare with- Returns:
true
if the givenTimestamp
object is equal to thisTimestamp
object;false
otherwise
-
equals
Tests to see if thisTimestamp
object is equal to the given object. This version of the methodequals
has been added to fix the incorrect signature ofTimestamp.equals(Timestamp)
and to preserve backward compatibility with existing class files. Note: This method is not symmetric with respect to theequals(Object)
method in the base class. -
before
Indicates whether thisTimestamp
object is earlier than the givenTimestamp
object.- Parameters:
ts
- theTimestamp
value to compare with- Returns:
true
if thisTimestamp
object is earlier;false
otherwise
-
after
public boolean after(
-
Timestamp(long millis)