os/persistentdata/persistentstorage/dbms/pcdbms/inc/D32DBMS.H
author sl
Tue, 10 Jun 2014 14:32:02 +0200
changeset 1 260cb5ec6c19
permissions -rw-r--r--
Update contrib.
     1 // Copyright (c) 1998-2009 Nokia Corporation and/or its subsidiary(-ies).
     2 // All rights reserved.
     3 // This component and the accompanying materials are made available
     4 // under the terms of "Eclipse Public License v1.0"
     5 // which accompanies this distribution, and is available
     6 // at the URL "http://www.eclipse.org/legal/epl-v10.html".
     7 //
     8 // Initial Contributors:
     9 // Nokia Corporation - initial contribution.
    10 //
    11 // Contributors:
    12 //
    13 // Description:
    14 //
    15 
    16 #if !defined(__D32DBMS_H__)
    17 #define __D32DBMS_H__
    18 
    19 #ifndef __S32STD_H__
    20 #include <s32std.h>
    21 #endif
    22 #ifndef __F32FILE_H__
    23 #include <f32file.h>
    24 #endif
    25 
    26 #ifndef SYMBIAN_ENABLE_SPLIT_HEADERS 
    27 	#include <d32dbmsconstants.h>
    28 #endif
    29 
    30 // other classes referenced
    31 class RFs;
    32 class CDbObject;
    33 class CDbRowConstraint;
    34 class CDbCursor;
    35 class CDbDatabase;
    36 class CDbIncremental;
    37 class CDbNotifier;
    38 class TDbColumn;
    39 class TDbColumnC;
    40 
    41 // classes defined
    42 class TDbCol;
    43 class CDbColSet;
    44 class TDbColSetIter;
    45 class TDbKeyCol;
    46 class CDbKey;
    47 class TDbBookmark;
    48 class TDbQuery;
    49 class RDbHandleBase;
    50 template<class T> class RDbHandle;
    51 class RDbRowConstraint;
    52 class RDbRowSet;
    53 class RDbColReadStream;
    54 class RDbColWriteStream;
    55 class TDbWindow;
    56 class RDbView;
    57 template<class T> class TUnion;
    58 class TDbLookupKey;
    59 class TDbSeekKey;
    60 template<TInt S> class TDbSeekMultiKey;
    61 class RDbTable;
    62 class CDbNames;
    63 class RDbDatabase;
    64 class RDbIncremental;
    65 class RDbUpdate;
    66 class RDbNotifier;
    67 class RDbs;
    68 class RDbNamedDatabase;
    69 class RDbStoreDatabase;
    70 
    71 /**
    72 The maximum length for a DBMS name: 64 characters.
    73 @publishedAll
    74 @released
    75 */
    76 const TInt KDbMaxName=0x40;
    77 
    78 /**
    79 The maximum length for a DBMS column name: 64 characters.
    80 @publishedAll
    81 @released
    82 */
    83 const TInt KDbMaxColName=KDbMaxName;
    84 
    85 /** 
    86 Represents a writable DBMS name. It maps to a modifiable buffer descriptor 
    87 with maximum size KDbMaxName.
    88 
    89 Notes:
    90 
    91 A DBMS name must begin with an alphabetic character, after which any alphabetic, 
    92 numeric or the _ (underscore) character may be used. DBMS names are also limited 
    93 to 64 characters in length.
    94 
    95 Table names must be unique within a database, and columns and indexes must 
    96 have unique names within the table to which they belong. For the purposes 
    97 of uniqueness and identification, the names are folded before comparison, 
    98 so two columns named column_one and Column_ONE are considered to have the 
    99 same name.
   100 
   101 @see TBuf 
   102 @publishedAll
   103 @released
   104 */
   105 typedef TBuf<KDbMaxName> TDbName;
   106 
   107 /** Represents a non-writeable DBMS name. It maps to a non modifiable buffer descriptor 
   108 with maximum size KDbMaxName.
   109 
   110 Notes:
   111 
   112 A DBMS name must begin with an alphabetic character, after which any alphabetic, 
   113 numeric or the _ (underscore) character may be used. DBMS names are also limited 
   114 to 64 characters in length.
   115 
   116 Table names must be unique within a database, and columns and indexes must 
   117 have unique names within the table to which they belong. For the purposes 
   118 of uniqueness and identification, the names are folded before comparison, 
   119 so two columns named column_one and Column_ONE are considered to have the 
   120 same name.
   121 
   122 @see TBufC 
   123 @publishedAll
   124 @released
   125 */
   126 typedef TBufC<KDbMaxName> TDbNameC;
   127 
   128 /** Represents a writable DBMS column name. It maps to a modifiable buffer descriptor 
   129 with maximum size KDbMaxColName.
   130 
   131 Notes:
   132 
   133 A DBMS name must begin with an alphabetic character, after which any alphabetic, 
   134 numeric or the _ (underscore) character may be used. DBMS names are also limited 
   135 to 64 characters in length.
   136 
   137 Table names must be unique within a database, and columns and indexes must 
   138 have unique names within the table to which they belong. For the purposes 
   139 of uniqueness and identification, the names are folded before comparison, 
   140 so two columns named column_one and Column_ONE are considered to have the 
   141 same name. 
   142 @publishedAll
   143 @released
   144 */
   145 typedef TBuf<KDbMaxColName> TDbColName;
   146 
   147 /** Represents a non-writable DBMS column name. It maps to a non-modifiable buffer 
   148 descriptor with maximum size KDbMaxColName.
   149 
   150 Notes:
   151 
   152 A DBMS name must begin with an alphabetic character, after which any alphabetic, 
   153 numeric or the _ (underscore) character may be used. DBMS names are also limited 
   154 to 64 characters in length.
   155 
   156 Table names must be unique within a database, and columns and indexes must 
   157 have unique names within the table to which they belong. For the purposes 
   158 of uniqueness and identification, the names are folded before comparison, 
   159 so two columns named column_one and Column_ONE are considered to have the 
   160 same name.
   161 
   162 @see TBufC 
   163 @publishedAll
   164 @released
   165 */
   166 typedef TBufC<KDbMaxColName> TDbColNameC;
   167 
   168 /** Specifies when DBMS objects require a column ordinal to identify a column in 
   169 a column set or in a rowset.
   170 
   171 Note that KDbNullColNo is a special value of TDbColNo used to indicate that 
   172 no such column exists. 
   173 @publishedAll
   174 @released
   175 */
   176 typedef TInt TDbColNo;
   177 
   178 /** 
   179 Indicates that a specified column does not exist. 
   180 @publishedAll
   181 @released
   182 */
   183 const TDbColNo KDbNullColNo=0;
   184 
   185 /** 
   186 A value returned by RDbRowSet::Count() when the number of rows cannot be determined.
   187 
   188 @see RDbRowSet 
   189 @publishedAll
   190 @released
   191 */
   192 const TInt KDbUndefinedCount=-1;
   193 
   194 /** 
   195 The length of a column is undefined. 
   196 @publishedAll
   197 @released
   198 */
   199 const TInt KDbUndefinedLength=-1;
   200 
   201 /** 
   202 The default text column length. This is equal to 50. 
   203 @publishedAll
   204 @released
   205 */
   206 const TInt KDbDefaultTextColLength=50;
   207 
   208 /** 
   209 Represents every supported column type. 
   210 @publishedAll
   211 @released
   212 */
   213 enum TDbColType
   214 	{
   215 	/** The column stores a single bit.
   216 	
   217 	Representation range: 0 to 1
   218 	
   219 	Storage: 1 bit
   220 	
   221 	Auto-increment: Yes
   222 	
   223 	Index key: Yes */
   224 	EDbColBit,
   225 
   226 	/** The column stores an 8-bit signed integer.
   227 	
   228 	Representation range: -2^7 to 2^7 - 1
   229 	
   230 	Storage: 1 byte
   231 	
   232 	Auto-increment: Yes
   233 	
   234 	Index key: Yes */
   235 	EDbColInt8,
   236 
   237 	/** The column stores an 8-bit unsigned integer.
   238 	
   239 	Representation range: 0 to 2^8-1
   240 	
   241 	Storage: 1 byte
   242 	
   243 	Auto-increment: Yes
   244 	
   245 	Index key: Yes */
   246 	EDbColUint8,
   247 
   248 	/** The column stores a 16-bit signed integer.
   249 	
   250 	Representation range: -2^15 to 2^15 - 1
   251 	
   252 	Storage: 2 bytes
   253 	
   254 	Auto-increment: Yes
   255 	
   256 	Index key: Yes */
   257 	EDbColInt16,
   258 
   259 	/** The column stores a 16-bit unsigned integer.
   260 	
   261 	Representation range: 0 to 2^16-1
   262 	
   263 	Storage: 2 bytes
   264 	
   265 	Auto-increment: Yes
   266 	
   267 	Index key: Yes */
   268 	EDbColUint16,
   269 
   270 	/** The column stores a 32-bit signed integer.
   271 	
   272 	Representation range: -2^31 to 2^31 - 1
   273 	
   274 	Storage: 4 bytes
   275 	
   276 	Auto-increment: Yes
   277 	
   278 	Index key: Yes */
   279 	EDbColInt32,
   280 
   281 	/** The column stores a 32-bit unsigned integer.
   282 	
   283 	Representation range: 0 to 2^32-1
   284 	
   285 	Storage: 4 bytes
   286 	
   287 	Auto-increment: Yes
   288 	
   289 	Index key: Yes */
   290 	EDbColUint32,
   291 
   292 	/** The column stores a 64-bit signed integer.
   293 	
   294 	Representation range: -2^63 to 2^63 - 1
   295 	
   296 	Storage: 8 bytes
   297 	
   298 	Auto-increment: No
   299 	
   300 	Index key: Yes */
   301 	EDbColInt64,
   302 
   303 	/** The column stores a 32-bit floating point value.
   304 	
   305 	Representation range: 1.4 X 10^-45 to 3.40282 X 10^38
   306 	
   307 	Storage: 4 bytes
   308 	
   309 	Auto-increment: No
   310 	
   311 	Index key: Yes */
   312 	EDbColReal32,
   313 
   314 	/** The column stores a 64-bit floating point value.
   315 	
   316 	Representation range: 2.2 X 10^-308 to 1.79769 X 10^308
   317 	
   318 	Storage: 8 bytes
   319 	
   320 	Auto-increment: No
   321 	
   322 	Index key: Yes */
   323 	EDbColReal64,
   324 
   325 	/** The column stores a date/time value.
   326 	
   327 	Representation range: 1/1/0 to 31/12/9999
   328 	
   329 	Storage: 8 bytes
   330 	
   331 	Auto-increment: No
   332 	
   333 	Index key: Yes */
   334 	EDbColDateTime,
   335 
   336 	/** The column stores a (short) variable length of non-Unicode text data.
   337 	
   338 	Representation range: 0 to 256 characters
   339 	
   340 	Storage: 0 to 256 bytes
   341 	
   342 	Auto-increment: No
   343 	
   344 	Index key: Yes */
   345 	EDbColText8,
   346 
   347 	/** The column stores a (short) variable length of Unicode text data.
   348 	
   349 	Representation range: 0 to 256 characters
   350 	
   351 	Storage: 0 to 512 bytes
   352 	
   353 	Auto-increment: No
   354 	
   355 	Index key: Yes */
   356 	EDbColText16,
   357 
   358 	/** The column stores a (short) variable length of untyped data.
   359 	
   360 	Representation range: 0 to 255 bytes
   361 	
   362 	Storage: 0 to 256 bytes
   363 	
   364 	Auto-increment: No
   365 	
   366 	Index key: No */
   367 	EDbColBinary,
   368 
   369 	/** The column stores a potentially large amount of non-Unicode text data.
   370 	
   371 	Representation range: 0 to 2^31 characters
   372 	
   373 	Storage: 0 to 2 Gbytes
   374 	
   375 	Auto-increment: No
   376 	
   377 	Index key: Truncated */
   378 	EDbColLongText8,
   379 
   380 	/** The column stores a potentially large amount of Unicode text data.
   381 	
   382 	Representation range: 0 to 2^30 characters
   383 	
   384 	Storage: 0 to 2 Gbytes
   385 	
   386 	Auto-increment: No
   387 	
   388 	Index key: Truncated */
   389 	EDbColLongText16,
   390 
   391 	/** The column stores a potentially large amount of untyped data.
   392 	
   393 	Representation range: 0 to 2^31 bytes
   394 	
   395 	Storage: 0 to 2 Gbytes
   396 	
   397 	Auto-increment: No
   398 	
   399 	Index key: No */
   400 	EDbColLongBinary,
   401 
   402 	/** This is equivalent to EDbColText8 if the build is narrow, and 
   403 	EDbColText16 if the build is Unicode. */
   404 	EDbColText=EDbColText16,
   405 
   406 	/** This is equivalent to EDbColLongText8 if the build is narrow, and 
   407 	EDbColLongText16 if the build is Unicode. */
   408 	EDbColLongText=EDbColLongText16
   409 	};
   410 
   411 /** 
   412 Represents different ways of comparing Text and LongText columns.
   413 
   414 This affects the ordering of indexes (see CDbKey), the evaluation of SQL 
   415 queries and matching row constraints (see TDbQuery). 
   416 @publishedAll
   417 @released
   418 */
   419 enum TDbTextComparison 
   420 	{
   421 	/** Use standard text comparison and ordering. */
   422 	EDbCompareNormal,
   423 	/** Use folded text for comparison and ordering. */
   424 	EDbCompareFolded,
   425 	/** Use collation for comparison and ordering. */
   426 	EDbCompareCollated
   427 	};
   428 
   429 /** 
   430 Defines a column in a table or rowset. 
   431 
   432 The data members are public because this is really a structure to group the 
   433 attributes of the column together. 
   434 
   435 Three non-default constructors are provided for convenience. 
   436 @publishedAll
   437 @released
   438 */
   439 class TDbCol
   440 	{
   441 	friend class CDbColSet;
   442 public:
   443 	enum {ENotNull=0x01,EAutoIncrement=0x02};
   444 public:
   445 	/** Constructs an uninitialised TDbCol. It is necessary because there are 
   446 	also non-default constructors in this class. */
   447 	inline TDbCol() {}
   448 	inline TDbCol(const TDbCol&);
   449 	inline TDbCol& operator=(const TDbCol&);
   450 	IMPORT_C TDbCol(const TDesC& aName,TDbColType aType);
   451 	IMPORT_C TDbCol(const TDesC& aName,TDbColType aType,TInt aMaxLength);
   452 	static inline TBool IsLong(TDbColType aType);
   453 private:
   454 	inline TDbCol(const TDesC& aName);
   455 public:
   456 	/** The column type. */
   457 	TDbColType iType;
   458 	/** The maximum length of data that can be stored in a Text or Binary 
   459 	column. */
   460 	TInt iMaxLength;
   461 	/** A set of flags describing other column attributes. This must be one 
   462 	of the anonymous enum values ENotNull or EAutoIncrement. */
   463 	TUint iAttributes;
   464 	/** The column name. */
   465 	TDbColNameC iName;
   466 	};
   467 
   468 /** Manages a set of column definitions which describe a table or rowset 
   469 structure. Column definitions can be added and removed. The set can be 
   470 iterated over, and ordinals for a column can be looked up.
   471 
   472 The class is not intended for user derivation. 
   473 @publishedAll
   474 @released
   475 */
   476 class CDbColSet : public CBase
   477 	{
   478 	friend class TDbColSetIter;
   479 public:
   480 	IMPORT_C CDbColSet();
   481 	IMPORT_C static CDbColSet* NewL();
   482 	IMPORT_C static CDbColSet* NewLC();
   483 	IMPORT_C ~CDbColSet();
   484 	inline const TDbCol& operator[](TDbColNo aCol) const;
   485 	IMPORT_C const TDbCol* Col(const TDesC& aColName) const;
   486 	IMPORT_C TDbColNo ColNo(const TDesC& aColName) const;
   487 	inline TInt Count() const;
   488 	inline void Clear();
   489 	IMPORT_C CDbColSet& AddL(const TDbCol& aCol);
   490 	IMPORT_C void Remove(const TDesC& aColName);
   491 private:
   492 	CArrayPakFlat<TDbCol> iColumns;
   493 	};
   494 
   495 /** 
   496 Provides a useful way to iterate over the contents of a column set. 
   497 @publishedAll
   498 @released
   499 */
   500 class TDbColSetIter
   501 	{
   502 public:
   503 	IMPORT_C TDbColSetIter(const CDbColSet& aColSet);
   504 	inline operator TAny* () const;
   505 	inline const TDbCol& operator*() const;
   506 	inline const TDbCol* operator->() const;
   507 	IMPORT_C TDbColSetIter& operator++();
   508 	inline TDbColSetIter operator++(TInt);
   509 	inline TDbColNo Col() const;
   510 private:
   511 	const TDbCol* iColumn;
   512 	TInt iIndex;
   513 	const CArrayPakFlat<TDbCol>* iArray;
   514 	};
   515 
   516 /** Defines a key column in an index.
   517 
   518 The data members are public as this is really a structure to group the 
   519 attributes of the key column together. Two non-default constructors are 
   520 provided for convenience. 
   521 @publishedAll
   522 @released
   523 */
   524 class TDbKeyCol
   525 	{
   526 public:
   527 	/** Specifies whether a key column in an index should be sorted in 
   528 	ascending or descending order. */
   529 	enum TOrder 
   530 		{
   531 		/** Use ascending order. */
   532 		EAsc,
   533 		/** Use descending order. */
   534 		EDesc
   535 		};
   536 public:
   537 	/** Constructs an uninitialised object. Default constructor. It is necessary 
   538 	because there are also non-default constructors in this class. */
   539 	inline TDbKeyCol() {}
   540 	inline TDbKeyCol(const TDbKeyCol&);
   541 	inline TDbKeyCol& operator=(const TDbKeyCol&);
   542 	IMPORT_C TDbKeyCol(const TDesC& aName,TOrder anOrder=EAsc);
   543 	IMPORT_C TDbKeyCol(const TDesC& aName,TInt aLength,TOrder anOrder=EAsc);
   544 public:
   545 	/** The maximum number of characters used to index Text or LongText 
   546 	columns. If equal to KDbUndefinedLength (the default), all the characters 
   547 	in the defined column will be used. */
   548 	TOrder iOrder;
   549 	/** The ordering of the key. */
   550 	TInt iLength;
   551 	/** The column name for the key. */
   552 	TDbColNameC iName;
   553 	};
   554 
   555 /** 
   556 Represents the definition of an index. The key may be unique or primary, it 
   557 can specify the sort of comparison which is made for Text columns, and it 
   558 has a list of columns which make up the key. The class is used to construct 
   559 and interrogate index keys.
   560 
   561 This class is not intended for user derivation. 
   562 @publishedAll
   563 @released
   564 */
   565 class CDbKey : public CBase
   566 	{
   567 public:
   568 	enum {EUnique=0x01,EPrimary=0x02};
   569 public:
   570 	IMPORT_C CDbKey();
   571 	IMPORT_C static CDbKey* NewL();
   572 	IMPORT_C static CDbKey* NewLC();
   573 	IMPORT_C ~CDbKey();
   574 	IMPORT_C CDbKey& AddL(const TDbKeyCol& aKeyCol);
   575 	IMPORT_C void Remove(const TDesC& aColName);
   576 	IMPORT_C void Clear();
   577 	inline TInt Count() const;
   578 	inline const TDbKeyCol& operator[](TInt aCol) const;
   579 	inline void MakeUnique();
   580 	inline TBool IsUnique() const;
   581 	inline void SetComparison(TDbTextComparison aComparison);
   582 	inline TDbTextComparison Comparison() const;
   583 	inline void MakePrimary();
   584 	inline TBool IsPrimary() const;
   585 private:
   586 	CArrayPakFlat<TDbKeyCol> iKeys;
   587 	TDbTextComparison iComparison;
   588 	TInt iAttributes;
   589 	};
   590 
   591 /** 
   592 Saves the current location of a rowset, enabling rapid navigation back to a 
   593 previously visited row or position in the set.
   594 
   595 Instances of this class are returned by RDbRowSet::Bookmark(), which can later 
   596 be passed to RDbRowSet::GotoL() to return to the row which was current at 
   597 the call to Bookmark().
   598 
   599 @see RDbRowSet::Bookmark()
   600 @see RDbRowSet::GotoL() 
   601 @publishedAll
   602 @released
   603 */
   604 class TDbBookmark
   605 	{
   606 	friend class RDbRowSet;
   607 public:
   608 	struct TMark
   609 	/** Stores a database bookmark. */
   610 		{
   611 		enum {ESize=8};
   612 		TUint32 iMark[ESize];
   613 		};
   614 private:
   615 	TMark iMark;
   616 	};
   617 
   618 /** 
   619 A wrapper for an SQL string combined with a text comparison mode.
   620 
   621 An instance of the class is used as a parameter to RDbView::Prepare(), 
   622 RDbRowSet::FindL() and RDbRowConstraint::Open().
   623 
   624 The evaluation of SQL queries or constraints depends on how Text columns are 
   625 compared so every SQL string is accompanied by a member of the TDbTextComparison 
   626 enumeration to indicate how comparison is done.
   627 
   628 If the SQL string contains a LIKE clause with * (asterisks) wildcard then the 
   629 characters between them must be no longer than length 255.
   630 If only one * exists then the length is taken from the start and to the end of
   631 the clause. However, if the clause contains a ? (question mark) wildcard
   632 within it then the characters between must be no longer than length 253. 
   633 
   634 @see TDbTextComparison
   635 @see RDbView::Prepare()
   636 @see RDbRowSet::FindL()
   637 @see RDbRowConstraint::Open() 
   638 @publishedAll
   639 @released
   640 */
   641 class TDbQuery
   642 	{
   643 public:
   644 	inline TDbQuery(const TDesC& aQuery,TDbTextComparison aComparison=EDbCompareNormal);
   645 	inline const TDesC& Query() const;
   646 	inline TDbTextComparison Comparison() const;
   647 private:
   648 	const TDesC& iQuery;
   649 	TDbTextComparison iComparison;
   650 	};
   651 
   652 /** 
   653 This class is internal and is not intended for use 
   654 @publishedAll
   655 @released
   656 */
   657 class RDbHandleBase
   658 	{
   659 public:
   660 	inline RDbHandleBase();
   661 	void Close();
   662 protected:
   663 	inline void Set(CDbObject* aObject);
   664 	CDbObject& Object() const;
   665 protected:
   666 	CDbObject* iObject;
   667 	};
   668 
   669 /** 
   670 This class is internal and is not intended for use. 
   671 @publishedAll
   672 @released
   673 */
   674 template <class T>
   675 class RDbHandle : public RDbHandleBase
   676 	{
   677 public:
   678 	inline T* operator=(T* aT);
   679 	inline T* operator->() const;
   680 	inline T& operator*() const;
   681 	inline T* operator()() const;
   682 	};
   683 
   684 /** 
   685 Represents a pre-compiled SQL search-condition, which can be used to 
   686 test against the current row in a rowset.
   687 
   688 The constraint is compiled against a specific rowset, and can only be matched 
   689 against the same rowset using the RDbRowSet::MatchL() function.
   690 
   691 @see RDbRowSet 
   692 @publishedAll
   693 @released
   694 */
   695 class RDbRowConstraint
   696 	{
   697 	friend class RDbRowSet;
   698 public:
   699 	IMPORT_C TInt Open(const RDbRowSet& aView,TDbQuery aCriteria);
   700 	IMPORT_C void Close();
   701 private:
   702 	RDbHandle<CDbRowConstraint> iConstraint;
   703 	};
   704 
   705 /** 
   706 An abstract base class that provides functionality which is shared between 
   707 SQL view objects and Table objects. This functionality includes most of the 
   708 cursor navigation, row retrieval and update behaviour of rowsets.
   709 
   710 Rowset objects do not provide the data for the rowset on which they operate. 
   711 It is the responsibility of the derived classes RDbView and RDbTable to specify 
   712 the data source.
   713 
   714 This class is not intended for user derivation. 
   715 @publishedAll
   716 @released
   717 */
   718 class RDbRowSet
   719 	{
   720 	friend class RDbRowConstraint;
   721 	friend class RDbColReadStream;
   722 	friend class RDbColWriteStream;
   723 public:
   724 	/** Specifies where the rowset should navigate to in the GotoL() function. 
   725 	Their use is encapsulated by the respective member functions FirstL(), 
   726 	NextL() etc. */
   727 	enum TPosition 
   728 		{
   729 		/** Move to the first row in the rowset. */
   730 		EFirst,
   731 		/** Move to the next row in the rowset. */
   732 		ENext,
   733 		/** Move to the previous row in the rowset. */
   734 		EPrevious,
   735 		/** Move to the last row in the rowset. */
   736 		ELast,
   737 		/** Move to the position before the first row in the rowset. */
   738 		EBeginning,
   739 		/** Move to the position after the last row in the rowset. */
   740 		EEnd
   741 		};
   742 
   743 	/** Specifies which operations can be performed on a rowset. */
   744 	enum TAccess 
   745 		{
   746 		/** All operations can be performed on the rowset. */
   747 		EUpdatable,
   748 		/** Row navigation and reading are permitted. */
   749 		EReadOnly,
   750 		/** Inserting new rows is the only valid operation on the rowset. */
   751 		EInsertOnly
   752 		};
   753 
   754 	/** Specifies the direction to search through the rowset when using the 
   755 	FindL() function. */
   756 	enum TDirection 
   757 		{
   758 		/** Search from the current row forwards through the set. */
   759 		EForwards,
   760 		/** Search from the current row backwards through the set. */
   761 		EBackwards
   762 		};
   763 
   764 	/** Specifies whether the CountL() function should ensure that it returns 
   765 	the exact value which may be a non-trivial task. */
   766 	enum TAccuracy 
   767 		{
   768 		/** Take the time, if necessary, to return the exact value. */
   769 		EEnsure,
   770 		/** Return any immediately available value. */
   771 		EQuick
   772 		};
   773 public:
   774 	IMPORT_C void Close();
   775 	IMPORT_C void Reset();
   776 //
   777 	IMPORT_C CDbColSet* ColSetL() const;
   778 	IMPORT_C TInt ColCount() const;
   779 	IMPORT_C TDbColType ColType(TDbColNo aCol) const;
   780 	IMPORT_C TDbCol ColDef(TDbColNo aCol) const;
   781 //
   782 	IMPORT_C TBool AtRow() const;
   783 	IMPORT_C TBool AtBeginning() const;
   784 	IMPORT_C TBool AtEnd() const;
   785 //
   786 	IMPORT_C TInt CountL(TAccuracy anAccuracy=EEnsure) const;
   787 	IMPORT_C TBool IsEmptyL() const;
   788 //
   789 	IMPORT_C TBool GotoL(TPosition aPosition);
   790 	inline void BeginningL();
   791 	inline void EndL();
   792 	inline TBool FirstL();
   793 	inline TBool LastL();
   794 	inline TBool NextL();
   795 	inline TBool PreviousL();
   796 //
   797 	IMPORT_C TDbBookmark Bookmark() const;
   798 	IMPORT_C void GotoL(const TDbBookmark& aMark);
   799 //
   800 	IMPORT_C TBool MatchL(const RDbRowConstraint& aConstraint);
   801 	IMPORT_C TInt FindL(TDirection aDirection,TDbQuery aCriteria);
   802 //
   803 	IMPORT_C void GetL();
   804 	IMPORT_C void InsertL();
   805 	IMPORT_C void InsertCopyL();
   806 	IMPORT_C void UpdateL();
   807 	IMPORT_C void PutL();
   808 	IMPORT_C void Cancel();
   809 	IMPORT_C void DeleteL();
   810 //
   811 	inline TBool IsColNull(TDbColNo aCol) const;
   812 	IMPORT_C TInt ColSize(TDbColNo aCol) const;
   813 	IMPORT_C TInt ColLength(TDbColNo aCol) const;
   814 //
   815 	IMPORT_C TInt8 ColInt8(TDbColNo aCol) const;
   816 	IMPORT_C TInt16 ColInt16(TDbColNo aCol) const;
   817 	IMPORT_C TInt32 ColInt32(TDbColNo aCol) const;
   818 	IMPORT_C TInt64 ColInt64(TDbColNo aCol) const;
   819 	inline TInt ColInt(TDbColNo aCol) const;
   820 	IMPORT_C TUint8 ColUint8(TDbColNo aCol) const;
   821 	IMPORT_C TUint16 ColUint16(TDbColNo aCol) const;
   822 	IMPORT_C TUint32 ColUint32(TDbColNo aCol) const;
   823 	inline TUint ColUint(TDbColNo aCol) const;
   824 	IMPORT_C TReal32 ColReal32(TDbColNo aCol) const __SOFTFP;
   825 	IMPORT_C TReal64 ColReal64(TDbColNo aCol) const __SOFTFP;
   826 	inline TReal ColReal(TDbColNo aCol) const;
   827 	IMPORT_C TTime ColTime(TDbColNo aCol) const;
   828 	IMPORT_C TPtrC8 ColDes8(TDbColNo aCol) const;
   829 	IMPORT_C TPtrC16 ColDes16(TDbColNo aCol) const;
   830 	IMPORT_C TPtrC ColDes(TDbColNo aCol) const;
   831 //
   832 	IMPORT_C void SetColNullL(TDbColNo aCol);
   833 	inline void SetColL(TDbColNo aCol,TInt aValue);
   834 	IMPORT_C void SetColL(TDbColNo aCol,TInt32 aValue);
   835 	IMPORT_C void SetColL(TDbColNo aCol,TInt64 aValue);
   836 	inline void SetColL(TDbColNo aCol,TUint aValue);
   837 	IMPORT_C void SetColL(TDbColNo aCol,TUint32 aValue);
   838 	IMPORT_C void SetColL(TDbColNo aCol,TReal32 aValue) __SOFTFP;
   839 	IMPORT_C void SetColL(TDbColNo aCol,TReal64 aValue) __SOFTFP;
   840 	IMPORT_C void SetColL(TDbColNo aCol,TTime aValue);
   841 	IMPORT_C void SetColL(TDbColNo aCol,const TDesC8& aValue);
   842 	IMPORT_C void SetColL(TDbColNo aCol,const TDesC16& aValue);
   843 private:
   844 	inline MStreamBuf* ColSourceL(TDbColNo aCol) const;
   845 	inline MStreamBuf* ColSinkL(TDbColNo aCol);
   846 	CDbCursor& CheckCol(TDbColNo aCol) const;
   847 	TDbColumnC ColumnC(TDbColNo aCol,TDbColType aType) const;
   848 	TDbColumn Column(TDbColNo aCol,TDbColType aType);
   849 protected:
   850 	RDbHandle<CDbCursor> iCursor;
   851 	};
   852 
   853 /** 
   854 Allows any column value to be read as stream data.
   855 
   856 Note that this is the only way to extract the contents of a Long column from 
   857 a rowset.
   858 
   859 Only one column in a rowset object can be opened for reading as a stream at 
   860 a time, and while it is open no column in the same rowset object may be set 
   861 using RDbColWriteStream.
   862 
   863 Null columns result in a read stream with no data. Small numeric columns are 
   864 maintained in memory as 32-bit values; hence reading a Uint8 column as a stream 
   865 results in 4 bytes of stream data, not 1. 
   866 @publishedAll
   867 @released
   868 */
   869 class RDbColReadStream : public RReadStream
   870 	{
   871 public:
   872 	IMPORT_C void OpenL(const RDbRowSet& aView,TDbColNo aCol);
   873 	IMPORT_C void OpenLC(const RDbRowSet& aView,TDbColNo aCol);
   874 	};
   875 
   876 /** 
   877 Writes Long columns when inserting or updating rows in a rowset. 
   878 
   879 Only one column in a rowset object can be opened for writing as a stream at 
   880 a time. 
   881 @publishedAll
   882 @released
   883 */
   884 class RDbColWriteStream : public RWriteStream
   885 	{
   886 public:
   887 	/** Constructs this object by invoking the default constructor for 
   888 	RWriteStream. */
   889 	inline RDbColWriteStream() {}
   890 	inline RDbColWriteStream(const MExternalizer<TStreamRef> &anExternalizer);
   891 	IMPORT_C void OpenL(RDbRowSet& aView,TDbColNo aCol);
   892 	IMPORT_C void OpenLC(RDbRowSet& aView,TDbColNo aCol);
   893 	};
   894 
   895 /** 
   896 Describes the desired shape of a view's pre-evaluation window.
   897 
   898 An instance of this class is passed to the RDbView object as part of the 
   899 Prepare() function. The different constructors for TDbWindow can specify a view:
   900 
   901 without pre-evaluation
   902 
   903 with full pre-evaluation
   904 
   905 with limited pre-evaluation.
   906 
   907 @see RDbView 
   908 @publishedAll
   909 @released
   910 */
   911 class TDbWindow
   912 	{
   913 public:
   914 	/** Denotes a full pre-evaluation window. */
   915 	enum TUnlimited 
   916 		{
   917 		/** No limit on how many rows may be in the window. */
   918 		EUnlimited=KMaxTInt
   919 		};
   920 	enum {ENone=0};
   921 public:
   922 	inline TDbWindow();
   923 	inline TDbWindow(TUnlimited);
   924 	IMPORT_C TDbWindow(TInt aForeSlots,TInt aRearSlots);
   925 	inline TInt Size() const;
   926 	inline TInt PreferredPos() const;
   927 private:
   928 	TInt iSize;
   929 	TInt iPreferredPos;
   930 	};
   931 #if defined(__NO_CLASS_CONSTS__)
   932 /**
   933 @publishedAll
   934 */
   935 #define KDbUnlimitedWindow TDbWindow(TDbWindow::EUnlimited)
   936 #else
   937 /**
   938 @publishedAll
   939 @released
   940 */
   941 const TDbWindow KDbUnlimitedWindow=TDbWindow(TDbWindow::EUnlimited);
   942 #endif
   943 
   944 /** 
   945 Generates rowsets from an SQL query. The query is prepared and evaluated 
   946 using the interface to this class, while the rowset is manipulated using the 
   947 RDbRowset base class.
   948 
   949 There are no special rules to consider when deriving from this class. 
   950 @publishedAll
   951 @released
   952 */
   953 class RDbView : public RDbRowSet
   954 	{
   955 public:
   956 	IMPORT_C TInt Prepare(RDbDatabase& aDatabase,const TDbQuery& aQuery,TAccess anAccess=EUpdatable);
   957 	IMPORT_C TInt Prepare(RDbDatabase& aDatabase,const TDbQuery& aQuery,const TDbWindow& aWindow);
   958 	IMPORT_C TInt Prepare(RDbDatabase& aDatabase,const TDbQuery& aQuery,const TDbWindow& aWindow,TAccess anAccess);
   959 	IMPORT_C TInt EvaluateAll();
   960 	IMPORT_C TInt Evaluate();
   961 //	IMPORT_C void Evaluate(TRequestStatus& aStatus);
   962 	IMPORT_C TBool Unevaluated() const;
   963 	};
   964 
   965 /** 
   966 This class is internal and is not intended for use. 
   967 @publishedAll
   968 @released
   969 */
   970 template <class T>
   971 class TUnion
   972 	{
   973 public:
   974 	inline operator const T&() const;
   975 	inline const T& operator()() const;
   976 	inline T& operator()();
   977 	inline void Set(const T& aT);
   978 private:
   979 	TUint8 iRep[sizeof(T)];
   980 	};
   981 
   982 /** 
   983 This class is internal and is not intended for use. 
   984 @publishedAll
   985 @released
   986 */
   987 class TDbLookupKey
   988 	{
   989 public:
   990 	struct SColumn
   991 		{
   992 		union
   993 			{
   994 			TInt32 iInt32;
   995 			TUint32 iUint32;
   996 			TUnion<TInt64> iInt64;
   997 			TReal32 iReal32;
   998 			TReal64 iReal64;
   999 			TUnion<TTime> iTime;
  1000 			struct {const TText8* iPtr;TInt iLength;} iDes8;
  1001 			struct {const TText16* iPtr;TInt iLength;} iDes16;
  1002 			};
  1003 		TDbColType iType;
  1004 		};
  1005 public:
  1006 	inline TDbLookupKey();
  1007 	inline TInt Count() const;
  1008 	inline const SColumn* First() const;
  1009 	void Add(TInt aKey);
  1010 	void Add(TUint aKey);
  1011 	void Add(TInt64 aKey);
  1012 	void Add(TReal32 aKey) __SOFTFP;
  1013 	void Add(TReal64 aKey) __SOFTFP;
  1014 	void Add(TTime aKey);
  1015 	void Add(const TDesC8& aKey);
  1016 	void Add(const TDesC16& aKey);
  1017 private:
  1018 	SColumn& NextKey();
  1019 private:
  1020 	TInt iCount;
  1021 	SColumn iKey[1];	// at least one
  1022 	};
  1023 
  1024 /** 
  1025 Database key value.
  1026 
  1027 The class encapsulates a key value which is passed to RDbTable::SeekL(), for 
  1028 lookup in the currently active index on that rowset.
  1029 
  1030 An instance of this class can store a key value of any type.
  1031 
  1032 Note that the class can only hold a single-column key. Use TDbSeekMultiKey 
  1033 for multi-column keys.
  1034 
  1035 @see TDbSeekMultiKey
  1036 @see RDbTable 
  1037 @publishedAll
  1038 @released
  1039 */
  1040 class TDbSeekKey
  1041 	{
  1042 	friend class RDbTable;
  1043 public:
  1044 	inline TDbSeekKey();
  1045 	inline TDbSeekKey(TInt aKey);
  1046 	inline TDbSeekKey(TUint aKey);
  1047 	inline TDbSeekKey(TInt64 aKey);
  1048 	inline TDbSeekKey(TReal32 aKey);
  1049 	inline TDbSeekKey(TReal64 aKey);
  1050 	inline TDbSeekKey(TTime aKey);
  1051 	inline TDbSeekKey(const TDesC8& aKey);
  1052 	inline TDbSeekKey(const TDesC16& aKey);
  1053 	IMPORT_C TDbSeekKey& Add(TInt aKey);
  1054 	IMPORT_C TDbSeekKey& Add(TUint aKey);
  1055 	IMPORT_C TDbSeekKey& Add(TInt64 aKey);
  1056 	IMPORT_C TDbSeekKey& Add(TReal32 aKey) __SOFTFP;
  1057 	IMPORT_C TDbSeekKey& Add(TReal64 aKey) __SOFTFP;
  1058 	IMPORT_C TDbSeekKey& Add(TTime aKey);
  1059 	IMPORT_C TDbSeekKey& Add(const TDesC8& aKey);
  1060 	IMPORT_C TDbSeekKey& Add(const TDesC16& aKey);
  1061 private:
  1062 	TDbLookupKey& Check();
  1063 protected:
  1064 	inline TDbSeekKey(TInt aKeys,TInt);
  1065 private:
  1066 	TInt iMaxKeys;
  1067 	TDbLookupKey iKey;
  1068 	};
  1069 
  1070 /** 
  1071 Database multi-column key value.
  1072 
  1073 The class extends the behaviour of TDbSeekKey by allowing multi-column indexes 
  1074 to be searched using multi-column key values.
  1075 
  1076 The template parameter S specifies the maximum number of column values that 
  1077 can be added to the key value.
  1078 
  1079 Use the TDbSeekKey::Add() members to append the values for each column in 
  1080 the key value. 
  1081 @publishedAll
  1082 @released
  1083 */
  1084 template<TInt S>
  1085 class TDbSeekMultiKey : public TDbSeekKey
  1086 	{
  1087 public:
  1088 	inline TDbSeekMultiKey();
  1089 private:
  1090 	TDbLookupKey::SColumn iExtraKeys[S-1];
  1091 	};
  1092 
  1093 /** 
  1094 Provides access to table data as a rowset, allowing manipulation of a named 
  1095 table in the database. Additionally, a named index can be used to order the 
  1096 rowset, and to provide fast key-based row retrieval from the table.
  1097 
  1098 There are no special rules to consider when deriving from this class. 
  1099 @publishedAll
  1100 @released
  1101 */
  1102 class RDbTable : public RDbRowSet
  1103 	{
  1104 public:
  1105 	/** Database table seek comparison types. */
  1106 	enum TComparison 
  1107 		{
  1108 		/** Retrieve the last row which is strictly less than the key value. */
  1109 		ELessThan,
  1110 		/** Retrieve the last row which is equal to or less than the key 
  1111 		value. */
  1112 		ELessEqual,
  1113 		/** Retrieve the first row which is equal to the key value. */
  1114 		EEqualTo,
  1115 		/** Retrieve the first row which is equal to or greater than the key 
  1116 		value. */
  1117 		EGreaterEqual,
  1118 		/** Retrieve the first row which is strictly greater than the key 
  1119 		value. */
  1120 		EGreaterThan
  1121 		};
  1122 public:
  1123 	IMPORT_C TInt Open(RDbDatabase& aDatabase,const TDesC& aName,TAccess anAccess=EUpdatable);
  1124 	inline TInt SetIndex(const TDesC& anIndex);
  1125 	inline TInt SetNoIndex();
  1126 	IMPORT_C TBool SeekL(const TDbSeekKey& aKey,TComparison aComparison=EEqualTo);
  1127 private:
  1128 	IMPORT_C TInt SetIndex(const TDesC* anIndex);
  1129 	};
  1130 
  1131 /**
  1132 @publishedAll
  1133 @released
  1134 */
  1135 class CDbNames : public CBase
  1136 	{
  1137 private:
  1138 	inline CDbNames();
  1139 public:
  1140 	static CDbNames* NewLC();
  1141 	~CDbNames();
  1142 	inline TInt Count() const;
  1143 	inline const TDesC& operator[](TInt anIndex) const;
  1144 	IMPORT_C void AddL(const TDesC& aName);
  1145 private:
  1146 	CArrayPakFlat<TDbNameC> iList;
  1147 	};
  1148 /**
  1149 @publishedAll
  1150 @released
  1151 */
  1152 typedef CDbNames CDbTableNames,CDbIndexNames,CDbDatabaseNames;
  1153 
  1154 /**
  1155 The maximum length for a generic DBMS string, which might be transferred from DBMS server
  1156 to the DBMS client using IPC.
  1157 @publishedAll
  1158 @released
  1159 */
  1160 const TInt KDbMaxStrLen = 256;
  1161 
  1162 /** 
  1163 Represents a generic read-only DBMS string. It maps to a non-modifiable buffer descriptor 
  1164 with maximum size KDbMaxStrLen.
  1165 
  1166 @see TBufC
  1167 @publishedAll
  1168 @released
  1169 */
  1170 typedef TBufC<KDbMaxStrLen> TDbStringC;
  1171 
  1172 /**
  1173 CDbStrings encapsulates functionality used for transferring an array of strings from 
  1174 DBMS server to the DBMS client. The maximal length of each element of the array is 
  1175 KDbMaxStrLen characters.
  1176 The typical usage pattern of CDbStrings class is:
  1177 @code
  1178 CDbStrings* strings = <a call of an exported DBMS method>;
  1179 TInt cnt = strings.Count();
  1180 for(TInt i=0;i<cnt;++i)
  1181 	{
  1182 	const TDesC& str = (*strings)[i];
  1183 	<do something with "str" variable>;
  1184 	}
  1185 delete strings;
  1186 @endcode
  1187 @publishedAll
  1188 @released
  1189 */
  1190 class CDbStrings : public CBase
  1191 	{
  1192 private:
  1193 	inline CDbStrings();
  1194 public:
  1195 	static CDbStrings* NewLC();
  1196 	virtual ~CDbStrings();
  1197 	inline TInt Count() const;
  1198 	inline const TDesC& operator[](TInt aIndex) const;
  1199 	void AddL(const TDesC& aStr);
  1200 private:
  1201 	CArrayPakFlat<TDbStringC> iList;
  1202 	};
  1203 
  1204 /**
  1205 Abstract class providing the functionality of a database.
  1206 
  1207 The source of the database and the implementation characteristics of a particular
  1208 database are provided by a class derived from RDbDatabase. 
  1209 
  1210 DBMS has one such implementation: the store database.
  1211 
  1212 This class is not intended for user derivation.
  1213 
  1214 Note: For functions (i.e. Execute) that take an Sql string, if the string
  1215 contains a LIKE clause with * (asterisks) wildcard then the 
  1216 characters between them must be no longer than length 255.
  1217 If only one * exists then the length is taken from the start and to the end of
  1218 the clause. However, if the clause contains a ? (question mark) wildcard
  1219 within it then the characters between must be no longer than length 253. 
  1220 
  1221 @publishedAll
  1222 @released
  1223 */
  1224 class RDbDatabase
  1225 	{
  1226 	friend class RDbView;
  1227 	friend class RDbTable;
  1228 	friend class RDbIncremental;
  1229 	friend class RDbUpdate;
  1230 	friend class RDbNotifier;
  1231 public:
  1232 	struct TSize {TInt iSize;TInt iUsage;};
  1233 public:
  1234 	IMPORT_C void Close();
  1235 	IMPORT_C TInt Destroy();
  1236 //
  1237 	IMPORT_C TBool IsDamaged() const;
  1238 	IMPORT_C TInt Recover();
  1239 //
  1240 	IMPORT_C TInt UpdateStats();
  1241 	IMPORT_C TSize Size() const;
  1242 	IMPORT_C TInt Compact();
  1243 	IMPORT_C TInt Begin();
  1244 	IMPORT_C TInt Commit();
  1245 	IMPORT_C void Rollback();
  1246 	IMPORT_C TBool InTransaction() const;
  1247 //
  1248 	inline TInt CreateTable(const TDesC& aName,const CDbColSet& aDef);
  1249 	inline TInt CreateTable(const TDesC& aName,const CDbColSet& aDef,const CDbKey& aPrimaryKey);
  1250 	IMPORT_C TInt DropTable(const TDesC& aName);
  1251 	IMPORT_C TInt AlterTable(const TDesC& aName,const CDbColSet& aNewDef);
  1252 	IMPORT_C TInt CreateIndex(const TDesC& aName,const TDesC& aTable,const CDbKey& aKey);
  1253  	IMPORT_C TInt DropIndex(const TDesC& aName,const TDesC& aTable);
  1254 //
  1255 	IMPORT_C TInt Execute(const TDesC& aSql,TDbTextComparison aComparison=EDbCompareNormal);
  1256 //
  1257 	IMPORT_C CDbTableNames* TableNamesL() const;
  1258 	IMPORT_C CDbColSet* ColSetL(const TDesC& aName) const;
  1259 	IMPORT_C CDbIndexNames* IndexNamesL(const TDesC& aTable) const;
  1260 	IMPORT_C CDbKey* KeyL(const TDesC& aName,const TDesC& aTable) const;
  1261 private:
  1262 	IMPORT_C TInt CreateTable(const TDesC& aName,const CDbColSet& aColSet,const CDbKey* aPrimaryKey);
  1263 protected:
  1264 	RDbHandle<CDbDatabase> iDatabase;
  1265 	};
  1266 
  1267 /** 
  1268 Provides the interface for performing long-running database operations in 
  1269 incremental steps, allowing application programs to remain responsive to other 
  1270 events.
  1271 
  1272 After an operation has begun, a standard interface is used to continue and 
  1273 complete all incremental operations. On successful return from one of the 
  1274 initiating functions, a step value is also returned. This gives the progress 
  1275 indication and is, initially, positive. This value should be passed into 
  1276 subsequent steps in the operation, each of which may decrement the value by 
  1277 some amount, although they are allowed to leave it unchanged. The value 
  1278 reaches zero, if, and only if the operation completes.
  1279 
  1280 While an incremental operation is in progress, the database cannot be used 
  1281 for any other operations such as opening tables or preparing views. 
  1282 
  1283 Starting an incremental operation also requires that no rowsets are open on 
  1284 the database and that no commit is pending for data manipulation transactions.
  1285 
  1286 If no explicit transaction has been started by the database, then an automatic 
  1287 transaction is begun when any incremental operation is started and is committed 
  1288 when complete or rolled back if the operation either fails or is abandoned 
  1289 prior to completion. 
  1290 @publishedAll
  1291 @released
  1292 */
  1293 class RDbIncremental
  1294 	{
  1295 public:
  1296 	IMPORT_C void Close();
  1297 	IMPORT_C TInt Next(TInt& aStep);
  1298 //	IMPORT_C void Next(TPckgBuf<TInt>& aStep,TRequestStatus& aStatus);
  1299 //
  1300 	IMPORT_C TInt Recover(RDbDatabase& aDatabase,TInt& aStep);
  1301 	IMPORT_C TInt Compact(RDbDatabase& aDatabase,TInt& aStep);
  1302 	IMPORT_C TInt DropTable(RDbDatabase& aDatabase,const TDesC& aTable,TInt& aStep);
  1303 	IMPORT_C TInt AlterTable(RDbDatabase& aDatabase,const TDesC& aTable,const CDbColSet& aNewDef,TInt& aStep);
  1304 	IMPORT_C TInt CreateIndex(RDbDatabase& aDatabase,const TDesC& aName,const TDesC& aTable,const CDbKey& aKey,TInt& aStep);
  1305 	IMPORT_C TInt DropIndex(RDbDatabase& aDatabase,const TDesC& aName,const TDesC& aTable,TInt& aStep);
  1306 	inline TInt Execute(RDbDatabase& aDatabase,const TDesC& aSql,TInt& aStep);
  1307 	IMPORT_C TInt Execute(RDbDatabase& aDatabase,const TDesC& aSql,TDbTextComparison aComparison,TInt& aStep);
  1308 	IMPORT_C TInt UpdateStats(RDbDatabase& aDatabase,TInt& aStep);
  1309 private:
  1310 	RDbHandle<CDbIncremental> iState;
  1311 	};
  1312 
  1313 /** 
  1314 Provides an interface to allow incremental execution of a DML (SQL data 
  1315 update) statement. 
  1316 
  1317 This class offers similar behaviour to the RDbIncremental class, in that it 
  1318 allows an application to perform long running operations while remaining 
  1319 responsive to events. However, unlike that class, RDbUpdate is restricted to 
  1320 executing DML statements.
  1321 
  1322 @see RDbIncremental 
  1323 @publishedAll
  1324 @released
  1325 */
  1326 class RDbUpdate
  1327 	{
  1328 public:
  1329 	IMPORT_C TInt Execute(RDbDatabase& aDatabase,const TDesC& aSql,TDbTextComparison aComparison=EDbCompareNormal);
  1330 	IMPORT_C void Close();
  1331 //
  1332 	IMPORT_C TInt Next();
  1333 //	IMPORT_C void Next(TRequestStatus& aStatus);
  1334 	IMPORT_C TInt RowCount() const;
  1335 private:
  1336 	RDbHandle<CDbIncremental> iUpdate;
  1337 	TPckgBuf<TInt> iRows;
  1338 	};
  1339 
  1340 /** 
  1341 Provides notification of database changes to clients.
  1342 
  1343 This is useful for shared databases. 
  1344 @publishedAll
  1345 @released
  1346 */
  1347 class RDbNotifier
  1348 	{
  1349 public:
  1350 	/** Defines the events which may be reported by a DBMS change notifier 
  1351 	through this RDbNotifier object.
  1352 
  1353 	Each enumerator corresponds to a distinct event type.
  1354 
  1355 	The changes are reported through a TRequestStatus object when an 
  1356 	outstanding notification request completes.
  1357 
  1358 	Notes
  1359 
  1360 	If further database events occur while a client is handling the completion 
  1361 	of a previous event, the notifier remembers the most significant event. The 
  1362 	order of importance is:
  1363 
  1364 	ERecover > ERollback > ECommit
  1365 
  1366 	where the symbol > means "is more important than" */
  1367 	enum TEvent 
  1368 		{
  1369 		/** The database has been closed. */
  1370 		EClose,
  1371 		/** All read locks have been removed. */
  1372 		EUnlock,
  1373 		/** A transaction has been committed. */
  1374 		ECommit,
  1375 		/** A transaction has been rolled back */
  1376 		ERollback,
  1377 		/** The database has been recovered */
  1378 		ERecover
  1379 		};
  1380 public:
  1381 	IMPORT_C TInt Open(RDbDatabase& aDatabase);
  1382 	IMPORT_C void Close();
  1383 //
  1384 //	IMPORT_C void NotifyUnlock(TRequestStatus& aStatus);
  1385 //	IMPORT_C void NotifyChange(TRequestStatus& aStatus);
  1386 	IMPORT_C void Cancel();
  1387 private:
  1388 	RDbHandle<CDbNotifier> iNotifier;
  1389 	};
  1390 
  1391 /** 
  1392 Client-server databases
  1393 
  1394 Represents a session with the DBMS server. A thread uses this class to set 
  1395 up a DBMS server session and this provides the basis for sharing databases 
  1396 with other threads. 
  1397 @publishedAll
  1398 @released
  1399 */
  1400 class RDbs //: public RSessionBase
  1401 	{
  1402 public:
  1403 	/**
  1404 	This enum is used in GetDatabasePolicy/GetTablePolicy/GetTablePolicies calls and specifies
  1405 	requested security policy type: read/write/schema.
  1406 	@publishedAll
  1407 	@released
  1408 	*/
  1409 	typedef enum {EReadPolicy, EWritePolicy, ESchemaPolicy} TPolicyType;
  1410 
  1411 public:
  1412 	IMPORT_C void Close();
  1413 //	IMPORT_C static TVersion Version();
  1414 	IMPORT_C TInt Connect();
  1415 	IMPORT_C CDbDatabaseNames* DatabaseNamesL(TDriveNumber aDrive, TUid aPolicyUid);
  1416 	IMPORT_C TInt CopyDatabase(const TDesC& aSrcDbName, const TDesC& aDestDbName, TUid aPolicyUid);
  1417 	IMPORT_C TInt DeleteDatabase(const TDesC& aDbName, TUid aPolicyUid);
  1418 //	IMPORT_C TInt GetDatabasePolicy(TUid aPolicyUid, TPolicyType aPolicyType, 
  1419 //									TSecurityPolicy& aDbPolicy);
  1420 //	IMPORT_C TInt GetTablePolicy(TUid aPolicyUid, const TDesC& aTableName, 
  1421 //								 TPolicyType aPolicyType, TSecurityPolicy& aTablePolicy);
  1422 //	IMPORT_C TInt GetTablePolicies(TUid aPolicyUid, const TDesC& aTableName, 
  1423 //								   TPolicyType aPolicyType, 
  1424 //								   TSecurityPolicy& aDbPolicy, TSecurityPolicy& aTablePolicy);
  1425 	//
  1426 	IMPORT_C void ResourceMark();
  1427 	IMPORT_C void ResourceCheck();
  1428 	IMPORT_C TInt ResourceCount();
  1429 	IMPORT_C void SetHeapFailure(TInt aTAllocFail,TInt aRate);
  1430 
  1431 	IMPORT_C TInt ReserveDriveSpace(TInt aDriveNo, TInt aSpace);
  1432 	IMPORT_C void FreeReservedSpace(TInt aDriveNo);
  1433 	IMPORT_C TInt GetReserveAccess(TInt aDriveNo);
  1434 	IMPORT_C TInt ReleaseReserveAccess(TInt aDriveNo);
  1435 
  1436 //	IMPORT_C TInt GetBackupPath(TSecureId aRequesterSid, const TDesC& aDbName, 
  1437 //								TUid aDbPolicyUid, TDes& aBackupPath);
  1438 //	IMPORT_C CDbStrings* BackupPathsL(TSecureId aRequesterSid, TUid aDbPolicyUid);
  1439 
  1440 private:
  1441 	TInt DoConnect();
  1442 	TInt SessionMessage(TInt aFunction);
  1443 //	TInt GetPolicy(TUid aPolicyUid, const TDesC& aTableName, 
  1444 //				   TUint aMask, TSecurityPolicy& aPolicy);
  1445 	};
  1446 
  1447 /**
  1448 Generic database implementation
  1449 @publishedAll
  1450 @released
  1451 */
  1452 class RDbNamedDatabase : public RDbDatabase
  1453 	{
  1454 public:
  1455 	/** Specifies which operations can be performed on a rowset. */
  1456 	enum TAccess 
  1457 	{
  1458 	EReadWrite,
  1459 	/** Row navigation and reading are permitted. */
  1460 	EReadOnly
  1461 	};
  1462 public:
  1463 	IMPORT_C TInt Create(RDbs& aDbs, const TDesC& aDatabase, const TDesC& aFormat);
  1464 	IMPORT_C TInt Create(RFs& aFs,const TDesC& aDatabase,const TDesC& aFormat=TPtrC());
  1465 	IMPORT_C TInt Replace(RFs& aFs,const TDesC& aDatabase,const TDesC& aFormat=TPtrC());
  1466 	IMPORT_C TInt Open(RFs& aFs,const TDesC& aDatabase,const TDesC& aFormat=TPtrC(),TAccess aMode=EReadWrite);
  1467 	IMPORT_C TInt Open(RDbs& aDbs,const TDesC& aDatabase,const TDesC& aFormat=TPtrC());
  1468 	};
  1469 
  1470 /**
  1471 DBMS Store database implementation
  1472 @publishedAll
  1473 @released
  1474 */
  1475 class RDbStoreDatabase : public RDbDatabase
  1476 	{
  1477 public:
  1478 	IMPORT_C TStreamId CreateL(CStreamStore* aStore);
  1479 	IMPORT_C void OpenL(CStreamStore* aStore,TStreamId anId);
  1480 	IMPORT_C static void CompressL(CStreamStore& aStore,TStreamId aId);
  1481 	IMPORT_C static void DecompressL(CStreamStore& aStore,TStreamId aId);
  1482 	};
  1483 
  1484 #include <d32dbms.inl>
  1485 #endif