|
|
Classification: |
C++ |
Category: |
DBMS |
Created: |
10/19/2000 |
Modified: |
06/12/2001 |
Number: |
FAQ-0528 |
Platform: |
ER5 |
|
Question: How do I access data within an EDbColLongText DBMS column ?
Answer: The only way to extract the contents of a long column from a RDbRowSet is by using an RDbColReadStream.
Similarly the RDbColWriteStream should be used to set the contents of the long column within the rowset.
Only one column in a rowset object can be opened for reading as a stream at a time, and while it is open no column in the same rowset object may be set using RDbColWriteStream.
The following example demonstrates creating a database table, using an RDbColWriteStream to set the contents of a long column and an RDbColWriteStream to extract the contents of a long column in a rowset.
_LIT(KComposer1, "Elgar"); _LIT(KCol1, "Artist"); _LIT(KCol2, "Notes"); _LIT(KTable, "CDs");
// Create the database table
LOCAL_C void doCreateTableL(RDbDatabase& aDatabase) {
// Create a table definition CDbColSet* columns=CDbColSet::NewLC();
// add the columns columns->AddL(TDbCol(KCol1,EDbColText)); columns->AddL(TDbCol(KCol2,EDbColLongText));
// Create a table User::LeaveIfError(aDatabase.CreateTable(KTable,*columns)); // cleanup the column set CleanupStack::PopAndDestroy(); }
// Add data
LOCAL_C void doAddDataL(const TDesC& aDatabaseFileName) { _LIT(KSQLStatement,"select Artist,Notes from CDs order by Artist");
// Open the file store CFileStore* store = CFileStore::OpenLC(fsSession,aDatabaseFileName,EFileRead|EFileWrite);
// open the database from the root stream RDbStoreDatabase database; database.OpenL(store,store->Root());
// create a view on the database RDbView view; User::LeaveIfError(view.Prepare(database,TDbQuery(KSQLStatement,EDbCompareNormal))); User::LeaveIfError(view.EvaluateAll());
// Get the structure of rowset CDbColSet* colSet = view.ColSetL();
// insert a row view.InsertL();
view.SetColL(colSet->ColNo(KCol1),KComposer1); // Artist
// Use the stream RDbColWriteStream out; TDbColNo col = colSet->ColNo(KCol2); // Ordinal position of long column
out.OpenLC(view, col); out.WriteL(_L("Some additional comment here.")); out.Close();
CleanupStack::PopAndDestroy(); // out
view.PutL();
// close the view view.Close(); // close the database database.Close();
// Do not commit store: database has taken control of commit CleanupStack::PopAndDestroy();
delete colSet;
}
// Display the data
LOCAL_C void doShowL(RDbRowSet& aSet) { _LIT(KRowFormatter, "\n %S, Notes: %S \n");
// Get the structure of the rowset CDbColSet* colSet = aSet.ColSetL();
// iterate across the row set for (aSet.FirstL();aSet.AtRow();aSet.NextL()) { // retrieve the row aSet.GetL(); // while the rowset is on this row, can use a TPtrC to // refer to any text columns TPtrC artist=aSet.ColDes(colSet->ColNo(KCol1)); // and a stream for long columns RDbColReadStream in; TDbColNo col = colSet->ColNo(KCol2); // Ordinal position of long column
TBuf<256> notes; // Buffer for out notes in.OpenLC(aSet, col); in.ReadL(notes, aSet.ColLength(col)); in.Close();
CleanupStack::PopAndDestroy(); // in
// Display the artist and notes console->Printf(KRowFormatter,&artist, ¬es); }
delete colSet; } |
|
|