DB->upgrade |
#include <db.h>int DB->upgrade(DB *db, const char *file, u_int32_t flags);
The DB->upgrade function upgrades all of the databases included in the file file, if necessary. If no upgrade is necessary, DB->upgrade always returns success.
Database upgrades are done in place and are destructive, e.g., if pages need to be allocated and no disk space is available, the database may be left corrupted. Backups should be made before databases are upgraded. See Upgrading databases for more information.
Unlike all other database operations, DB->upgrade may only be done on a system with the same byte-order as the database.
The flags parameter must be set to 0 or one of the following values:
As part of the upgrade from the Berkeley DB 3.0 release to the 3.1 release, the on-disk format of duplicate data items changed. To correctly upgrade the format requires applications specify if duplicate data items in the database are sorted or not. Specifying the DB_DUPSORT flag informs DB->upgrade that the duplicates are sorted, otherwise they are assumed to be unsorted. Incorrectly specifying the value of this flag may lead to database corruption.
Further, because the DB->upgrade function upgrades a physical file (including all of the databases it contains), it is not possible to use DB->upgrade to upgrade files where some of the databases it includes have sorted duplicate data items and some of the databases it includes have unsorted duplicate data items. If the file does not have more than a single database, or the databases do not support duplicate data items, or all of the databases that support duplicate data items support the same style of duplicates (either sorted or unsorted), DB->upgrade will work correctly as long as the DB_DUPSORT flag is correctly specified. Otherwise, the file cannot be upgraded using DB->upgrade, and must be upgraded manually by dumping and re-loading the databases.
The DB->upgrade function returns a non-zero error value on failure and 0 on success.
The DB->upgrade function is the underlying function used by the db_upgrade utility. See the db_upgrade utility source code for an example of using DB->upgrade in a IEEE/ANSI Std 1003.1 (POSIX) environment.
The DB->upgrade function may fail and return a non-zero error for the following conditions:
The database is not in the same byte-order as the system.
The DB->upgrade function may fail and return a non-zero error for errors specified for other Berkeley DB and C library or system functions. If a catastrophic error has occurred, the DB->upgrade function may fail and return DB_RUNRECOVERY, in which case all subsequent Berkeley DB calls will fail in the same way.