DB->upgrade

APIRef

#include <db.h>

int DB->upgrade(DB *db, const char *name, u_int32_t flags);

Description

The DB->upgrade function upgrades the database represented by name, if necessary. If no upgrade is necessary, DB->upgrade returns successfully.

The flags parameter is currently unused, and must be set to 0.

Note: 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.

The DB->upgrade function returns a non-zero error value on failure and 0 on success.

Environment Variables

DB_HOME
If the dbenv argument to db_create was initialized using DBENV->open the environment variable DB_HOME may be used as the path of the database home for the interpretation of the dir. Specifically, DB->upgrade is affected by the configuration string value of DB_DATA_DIR.

Errors

If a fatal error occurs in Berkeley DB, the DB->upgrade function will fail and return DB_RUNRECOVERY, at which point all subsequent database calls will fail in the same way.

In addition, the DB->upgrade function may fail and return a non-zero error for the following conditions:

DB_OLD_VERSION
The database cannot be upgraded by this version of the Berkeley DB software.

In addition, 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.

See Also

db_create, DB->close, DB->cursor, DB->del, DB->err, DB->fd, DB->get, DB->get_byteswapped, DB->get_type, DB->join, DB->open, DB->put, DB->remove, DB->set_bt_compare, DB->set_bt_minkey, DB->set_bt_prefix, DB->set_cachesize, DB->set_dup_compare, DB->set_errcall, DB->set_errfile, DB->set_errpfx, DB->set_flags, DB->set_h_ffactor, DB->set_h_hash, DB->set_h_nelem, DB->set_lorder, DB->set_malloc, DB->set_pagesize, DB->set_paniccall, DB->set_realloc, DB->set_re_delim, DB->set_re_len, DB->set_re_pad, DB->set_re_source, DB->stat, DB->sync and DB->upgrade.

APIRef

Copyright Sleepycat Software