Home » Developer & Programmer » Precompilers, OCI & OCCI » OCIDefineByPos && Retrieving a DATE column...
OCIDefineByPos && Retrieving a DATE column... [message #159971] |
Wed, 22 February 2006 08:27 |
Herode
Messages: 12 Registered: February 2006 Location: Isère (France, 38)
|
Junior Member |
|
|
Gentlemen,
Here is another bug (in my code, I mean...) I can't get rid off. I try to read a DATA column with the following code :
CString sz = "select create_time from road.lprofelev";
// prepare...
// execute...
// then define for output :
void* colDesc = NULL;
selectList lst;
OCIDefine* defH;
void* buf;
ub4 nameLg;
int nCol = 0;
st = ::OCIParamGet( m_pStmt, OCI_HTYPE_STMT, m_pErr, &colDesc, nCol + 1 );
st = ::OCIAttrGet( colDesc, OCI_DTYPE_PARAM, &lst.size, 0, OCI_ATTR_DATA_SIZE, m_pErr );
st = ::OCIAttrGet( colDesc, OCI_DTYPE_PARAM, &lst.type, 0, OCI_ATTR_DATA_TYPE, m_pErr );
st = ::OCIAttrGet( colDesc, OCI_DTYPE_PARAM, &buf, &nameLg, OCI_ATTR_NAME, m_pErr );
lst.colName.Format( "%.*s", nameLg, buf );
lst.size = 51;
// buffer for the DATE. Orale doc says that SQLT_DAT is char[ 7 ] but that's obviously a joke...
lst.m_buf = new char[ lst.size ];
st = ::OCIDefineByPos( m_pStmt, &defH, m_pErr, nCol + 1, lst.m_buf, lst.size, SQLT_STR, &lst.m_nullInd, 0, NULL, OCI_DEFAULT );
//and fetch...
st = ::OCIStmtFetch2( m_pStmt, m_pErr, 1, OCI_FETCH_NEXT, 1, OCI_DEFAULT );
cout << lst.colName.GetBuffer( 0 ) << " = " << (char*) lst.m_buf << endl;
The output gives me the YY/MM/DD date, but looses the timestamp (hours, minutes & so on).
NB : if the defining is made with :
st = ::OCIDefineByPos( m_pStmt, &defH, m_pErr, nCol + 1, lst.m_buf, lst.size, SQLT_STR, &lst.m_nullInd, &lst.size, NULL, OCI_DEFAULT );
the attribut lst.size ends with 8 inside (and not the initial 50).
What did I miss ????
|
|
|
Goto Forum:
Current Time: Wed Jan 22 23:03:00 CST 2025
|