Date Class
The Date class specifies the abstraction for a SQL DATE
data item. The Date class also adds formatting and parsing operations to support the OCCI escape syntax for date values.
Since the SQL standard DATE
is a subset of Oracle Date, this class can be used to support both.
Objects from the Date class can be used as standalone class objects in client side numeric computations and also used to fetch from, and set to, the database.
Example 13-5 How to Get a Date from Database and Use it in Standalone Calculations
This example demonstrates a Date column value being retrieved from the database, a bind using a Date object, and a computation using a standalone Date object.
/* Create a connection */ Environment *env = Environment::createEnvironment(Environment::DEFAULT); Connection *conn = Connection(user, passwd, db); /* Create a statement and associate a DML statement to it */ string sqlStmt = "SELECT job-id, start_date from JOB_HISTORY where end_date = :x"; Statement *stmt = conn->createStatement(sqlStmt); /* Create a Date object and bind it to the statement */ Date edate(env, 2000, 9, 3, 23, 30, 30); stmt->setDate(1, edate); ResultSet *rset = stmt->executeQuery(); /* Fetch a date from the database */ while(rset->next()) { Date sd = rset->getDate(2); Date temp = sd; /*assignment operator */ /* Methods on Date */ temp.getDate(year, month, day, hour, minute, second); temp.setMonths(2); IntervalDS inter = temp.daysBetween(sd); . . }
Table 13-16 Summary of Date Methods
Method | Summary |
---|---|
|
|
Returns a |
|
Returns a |
|
Returns the number of days between the current |
|
Convert an external |
|
Convert the date from a given input string with format and NLS parameters specified. |
|
Returns the date and time components of the |
|
Returns a |
|
Returns |
|
Returns a |
|
Returns a |
|
Assigns the values of a date to another. |
|
Returns |
|
Returns |
|
Returns |
|
Returns |
|
Returns |
|
Returns |
|
Sets the date from the date components input. |
|
Sets the object state to |
|
Converts the |
|
Returns the |
|
Returns a |
Date()
Date
class constructor.
Syntax | Description |
---|---|
Date(); |
Creates a |
Date( const Date &srcDate); |
Creates a copy of a |
Date( const Environment *envp, int year = 1, unsigned int month = 1, unsigned int day = 1, unsigned int hour = 0, unsigned int minute = 0, unsigned int seconds = 0); |
Creates a |
Parameter | Description |
---|---|
year |
-4712 to 9999, except 0 |
month |
1 to 12 |
day |
1 to 31 |
minutes |
0 to 59 |
seconds |
0 to 59 |
addDays()
Adds a specified number of days to the Date
object and returns the new date.
Syntax
Date addDays( int val) const;
Parameter | Description |
---|---|
val |
The number of days to be added to the current |
addMonths()
Adds a specified number of months to the Date
object and returns the new date.
Syntax
Date addMonths( int val) const;
Parameter | Description |
---|---|
val |
The number of months to be added to the current |
daysBetween()
Returns the number of days between the current Date
object and the date specified
.
Syntax
IntervalDS daysBetween( const Date &date) const;
Parameter | Description |
---|---|
date |
The date to be used to compute the days between. |
fromBytes()
Converts a Bytes
object to a Date
object.
Syntax
void fromBytes( const Bytes &byteStream, const Environment *envp = NULL);
Parameter | Description |
---|---|
byteStream |
|
envp |
The OCCI environment. |
fromText()
Sets Date
object to value represented by a string
or UString
.
The value is interpreted based on the fmt
and nlsParam
parameters. In cases where nlsParam
is not passed, the Globalization Support settings of the envp
parameter are used.
See Also:
Oracle Database SQL Language Reference for information on TO_DATE
Syntax | Description |
---|---|
void fromText( const string &datestr, const string &fmt = "", const string &nlsParam = "", const Environment *envp = NULL); |
Sets |
void fromText( const UString &datestr, const UString &fmt, const UString &nlsParam, const Environment *envp = NULL); |
Sets |
Parameter | Description |
---|---|
envp |
The OCCI environment. |
datestr |
The date string to be converted to a |
fmt |
The format string; default is |
nlsParam |
The NLS parameters string. If |
getDate()
Returns the date in the form of the date components year, month, day, hour, minute, seconds.
Syntax
void getDate( int &year, unsigned int &month, unsigned int &day, unsigned int &hour, unsigned int &min, unsigned int &seconds) const;
Parameter | Description |
---|---|
year |
The year component of the date. |
month |
The month component of the date. |
day |
The day component of the date. |
hour |
The hour component of the date. |
min |
The minutes component of the date. |
seconds |
The seconds component of the date. |
getSystemDate()
Returns the system date.
Syntax
static Date getSystemDate( const Environment *envp);
Parameter | Description |
---|---|
envp |
The environment in which the system date is returned. |
isNull()
Tests whether the Date
is NULL
. If the Date
is NULL
, TRUE
is returned; otherwise, FALSE
is returned.
Syntax
bool isNull() const;
lastDay()
Returns a date representing the last day of the current month.
Syntax
Date lastDay() const;
nextDay()
Returns a date representing the day after the day of the week specified.
See Also:
Oracle Database SQL Language Reference for information on TO_DATE
Syntax | Description |
---|---|
Date nextDay( const string &dow) const; |
Returns a date representing the day after the day of the week specified. |
Date nextDay( const UString &dow) const; |
Returns a date representing the day after the day of the week specified.; globalization enabled. The parameter should be in the character set associated with the environment from which the date was created. |
Parameter | Description |
---|---|
dow |
A string representing the day of the week. |
operator=()
Assigns the date object on the right side of the equal (=) sign to the date object on the left side of the equal (=) sign.
Syntax
Date& operator=( const Date &d);
Parameter | Description |
---|---|
date |
The date object that is assigned. |
operator==()
Compares the dates specified. If the dates are equal, TRUE
is returned; otherwise, FALSE
is returned.
Syntax
bool operator==( const Date &first, const Date &second);
Parameter | Description |
---|---|
first |
The first date to be compared. |
second |
The second date to be compared. |
operator!=()
Compares the dates specified. If the dates are not equal then TRUE
is returned; otherwise, FALSE
is returned.
Syntax
bool operator!=( const Date &first, const Date &second);
Parameter | Description |
---|---|
first |
The first date to be compared. |
second |
The second date to be compared. |
operator>()
Compares the dates specified. If the first date is in the future relative to the second date then TRUE
is returned; otherwise, FALSE
is returned. If either date is NULL
then FALSE
is returned. If the dates are of different type, then FALSE
is returned.
Syntax
bool operator>( const Date &first, const Date &second);
Parameter | Description |
---|---|
first |
The first date to be compared. |
second |
The second date to be compared. |
operator>=()
Compares the dates specified. If the first date is in the future relative to the second date or the dates are equal then TRUE
is returned; otherwise, FALSE
is returned. If either date is NULL
then FALSE
is returned. If the dates are of a different type, then FALSE
is returned.
Syntax
bool operator>=( const Date &first, const Date &second);
Parameter | Description |
---|---|
first |
The first date to be compared. |
second |
The second date to be compared. |
operator<()
Compares the dates specified. If the first date precedes the second date, then TRUE
is returned; otherwise, FALSE
is returned. If either date is NULL
then FALSE
is returned. If the dates are of a different type, then FALSE
is returned.
Syntax
bool operator<( const Date &first, const Date &second);
Parameter | Description |
---|---|
first |
The first date to be compared. |
second |
The second date to be compared. |
operator<=()
Compares the dates specified. If the first date precedes the second date or the dates are equal then TRUE
is returned; otherwise, FALSE
is returned. If either date is NULL
then FALSE
is returned. If the dates are of a different type, then FALSE
is returned.
Syntax
bool operator<=( const Date &first, const Date &second);
Parameter | Description |
---|---|
first |
The first date to be compared. |
second |
The second date to be compared. |
setDate()
Sets the date to the values specified.
Syntax
void setDate( int year = 1, unsigned int month = 1, unsigned int day = 1, unsigned int hour = 0, unsigned int minute = 0, unsigned int seconds = 0);
Parameter | Description |
---|---|
year |
The argument specifying the year value. Valid values are |
month |
The argument specifying the month value. Valid values are |
day |
The argument specifying the day value. Valid values are 1 through 31. |
hour |
The argument specifying the hour value. Valid values are 0 through 23. |
min |
The argument specifying the minutes value. Valid values are 0 through 59. |
seconds |
The argument specifying the seconds value. Valid values are 0 through 59. |
toText()
Returns a string
or UString
with the value of this date formatted using fmt
and nlsParam
.
The value is interpreted based on the fmt
and nlsParam
parameters. In cases where nlsParam
is not passed, the Globalization Support settings of the envp
parameter are used.
See Also:
Oracle Database SQL Language Reference for information on TO_DATE
Syntax | Description |
---|---|
string toText( const string &fmt = "", const string &nlsParam = "") const; |
Returns a |
UString toText( const UString &fmt, const UString &nlsParam) const; |
Returns a |
Parameter | Description |
---|---|
fmt |
The format string; default is |
nlsParam |
The NLS parameters string. If |
toZone()
Returns Date
value converted from one time zone to another.
Syntax
Date toZone( const string &zone1, const string &zone2) const;
Parameter | Description |
---|---|
zone1 |
A string representing the time zone to be converted from. |
zone2 |
A string representing the time zone to be converted to. |
Valid time zone codes are:
Zone code | Value |
---|---|
|
Atlantic Standard or Daylight Time |
|
Bering Standard or Daylight Time |
|
Central Standard or Daylight Time |
|
Eastern Standard or Daylight Time |
|
Greenwich Mean Time |
|
Alaska-Hawaii Standard Time or Daylight Time |
|
Mountain Standard or Daylight Time |
|
Newfoundland Standard Time |
|
Pacific Standard or Daylight Time |
|
Yukon Standard or Daylight Time |