Chapter 5. Data Definition (DDL) Statements
DDL is the data definition language subset of Firebird’s SQL language. DDL statements are used to create, modify and delete database objects that have been created by users. When a DDL statement is committed, the metadata for the object are created, changed or deleted.
5.1. DATABASE
This section describes how to create a database, connect to an existing database, alter the file structure of a database and how to delete one.
It also explains how to back up a database in two quite different ways and how to switch the database to the copy-safe
mode for performing an external backup safely.
5.1.1. CREATE DATABASE
Used forCreating a new database
Available inDSQL, ESQL
Syntax
CREATE {DATABASE | SCHEMA} <filespec>
[<db_initial_option> [<db_initial_option> ...]]
[<db_config_option> [<db_config_option> ...]]
<db_initial_option> ::=
USER username
| PASSWORD 'password'
| ROLE rolename
| PAGE_SIZE [=] size
| LENGTH [=] num [PAGE[S]]
| SET NAMES 'charset'
<db_config_option> ::=
DEFAULT CHARACTER SET default_charset
[COLLATION collation] -- not supported in ESQL
| <sec_file>
| DIFFERENCE FILE 'diff_file' -- not supported in ESQL
<filespec> ::= "'" [server_spec]{filepath | db_alias} "'"
<server_spec> ::=
host[/{port | service}]:
| \\host\
| <protocol>://[host[:{port | service}]/]
<protocol> ::= inet | inet4 | inet6 | wnet | xnet
<sec_file> ::=
FILE 'filepath'
[LENGTH [=] num [PAGE[S]]
[STARTING [AT [PAGE]] pagenum]
Each db_initial_option and db_config_option can occur at most once, except sec_file, which can occur zero or more times.
CREATE DATABASE Statement Parameters| Parameter | Description |
|---|---|
filespec | File specification for primary database file |
server_spec | Remote server specification. Some protocols require specifying a hostname. Optionally includes a port number or service name. Required if the database is created on a remote server. |
filepath | Full path and file name including its extension. The file name must be specified according to the rules of the platform file system being used. |
db_alias | Database alias previously created in the |
host | Host name or IP address of the server where the database is to be created |
port | The port number where the remote server is listening (parameter RemoteServicePort in |
service | Service name.
Must match the parameter value of RemoteServiceName in |
username | Username of the owner of the new database.
The maximum length is 63 characters.
The username can optionally be enclosed in single or double quotes.
When a username is enclosed in double quotes, it is case-sensitive following the rules for quoted identifiers.
When enclosed in single quotes, it behaves as if the value was specified without quotes.
The user must be an administrator or have the |
password | Password of the user as the database owner.
When using the |
rolename | The name of the role whose rights should be taken into account when creating a database. The role name can be enclosed in single or double quotes. When the role name is enclosed in double quotes, it is case-sensitive following the rules for quoted identifiers. When enclosed in single quotes, it behaves as if the value was specified without quotes. |
size | Page size for the database, in bytes. Possible values are 4096, 8192, 16384 and 32768. The default page size is 8192. |
num | Maximum size of the primary database file, or a secondary file, in pages |
charset | Specifies the character set of the connection available to a client connecting after the database is successfully created. Single quotes are required. |
default_charset | Specifies the default character set for string data types |
collation | Default collation for the default character set |
sec_file | File specification for a secondary file |
pagenum | Starting page number for a secondary database file |
diff_file | File path and name for DIFFERENCE files (.delta files) for backup mode |
The CREATE DATABASE statement creates a new database.
You can use CREATE DATABASE or CREATE SCHEMA.
They are synonymous, but we recommend to always use CREATE DATABASE as this may change in a future version of Firebird.
A database may consist of one or several files. The first (main) file is called the primary file, subsequent files are called secondary file(s).
Nowadays, multi-file databases are considered an anachronism. It made sense to use multi-file databases on old file systems where the size of any file is limited. For instance, you could not create a file larger than 4 GB on FAT32.
The primary file specification is the name of the database file and its extension with the full path to it according to the rules of the OS platform file system being used. The database file must not exist at the moment the database is being created. If it does exist, you will get an error message, and the database will not be created.
If the full path to the database is not specified, the database will be created in one of the system directories. The particular directory depends on the operating system. For this reason, unless you have a strong reason to prefer that situation, always specify either the absolute path or an alias, when creating a database.
5.1.1.1. Using a Database Alias
You can use aliases instead of the full path to the primary database file.
Aliases are defined in the databases.conf file in the following format:
alias = filepathExecuting a CREATE DATABASE statement requires special consideration in the client application or database driver.
As a result, it is not always possible to execute a CREATE DATABASE statement.
Some drivers provide other ways to create databases.
For example, Jaybird provides the class org.firebirdsql.management.FBManager to programmatically create a database.
If necessary, you can always fallback to isql to create a database.
5.1.1.2. Creating a Database on a Remote Server
If you create a database on a remote server, you need to specify the remote server specification. The remote server specification depends on the protocol being used. If you use the TCP/IP protocol to create a database, the primary file specification should look like this:
host[/{port|service}]:{filepath | db_alias}If you use the Named Pipes protocol to create a database on a Windows server, the primary file specification should look like this:
\\host\{filepath | db_alias}Firebird also has a unified URL-like syntax for the remote server specification. In this syntax, the first part specifies the name of the protocol, then a host name or IP address, port number, and path of the primary database file, or an alias.
The following values can be specified as the protocol:
- inet
TCP/IP (first tries to connect using the IPv6 protocol, if it fails, then IPv4)
- inet4
TCP/IP v4
- inet6
TCP/IP v6
- wnet
NetBEUI or Named Pipes Protocol
- xnet
local protocol (does not include a host, port and service name)
<protocol>://[host[:{port | service}]/]{filepath | db_alias}5.1.1.3. Optional Parameters for CREATE DATABASE
USERandPASSWORDClauses for specifying the username and the password, respectively, of an existing user in the security database (
security4.fdbor whatever is configured in the SecurityDatabase configuration). You do not have to specify the username and password if theISC_USERandISC_PASSWORDenvironment variables are set. The user specified in the process of creating the database will be its owner. This will be important when considering database and object privileges.ROLEThe
ROLEclause specifies the name of the role (usuallyRDB$ADMIN), which will be taken into account when creating the database. The role must be assigned to the user in the applicable security database.PAGE_SIZEClause for specifying the database page size. This size will be set for the primary file and all secondary files of the database. If you specify the database page size less than 4,096, it will be automatically rounded up to 4,096. Other values not equal to either 4,096, 8,192, 16,384 or 32,768 will be changed to the closest smaller supported value. If the database page size is not specified, it is set to the default value of 8,192.
ⓘBigger Isn’t Always Better.Larger page sizes can fit more records on a single page, have wider indexes, and more indexes, but they will also waste more space for blobs (compare the wasted space of a 3KB blob on page size 4096 with one on 32768: +/- 1KB vs +/- 29KB), and increase memory consumption of the page cache.
LENGTHClause specifying the maximum size of the primary or secondary database file, in pages. When a database is created, its primary and secondary files will occupy the minimum number of pages necessary to store the system data, regardless of the value specified in the
LENGTHclause. TheLENGTHvalue does not affect the size of the only (or last, in a multi-file database) file. The file will keep increasing its size automatically when necessary.SET NAMESClause specifying the character set of the connection available after the database is successfully created. The character set
NONEis used by default. Notice that the character set should be enclosed in a pair of apostrophes (single quotes).DEFAULT CHARACTER SETClause specifying the default character set for creating data structures of string data types. Character sets are used for
CHAR,VARCHARandBLOB SUB_TYPE TEXTdata types. The character setNONEis used by default. It is also possible to specify the defaultCOLLATIONfor the default character set, making that collation sequence the default for the default character set. The default will be used for the entire database except where an alternative character set, with or without a specified collation, is used explicitly for a field, domain, variable, cast expression, etc.STARTING ATClause that specifies the database page number at which the next secondary database file should start. When the previous file is completely filled with data according to the specified page number, the system will start adding new data to the next database file.
DIFFERENCE FILEClause specifying the path and name for the file delta that stores any mutations to the database file after it has been switched to the
copy-safe
mode by theALTER DATABASE BEGIN BACKUPstatement. For the detailed description of this clause, seeALTER DATABASE.
5.1.1.4. Specifying the Database Dialect
Databases are created in Dialect 3 by default.
For the database to be created in SQL dialect 1, you will need to execute the statement SET SQL DIALECT 1 from script or the client application, e.g. in isql, before the CREATE DATABASE statement.
5.1.1.5. Who Can Create a Database
The CREATE DATABASE statement can be executed by:
Users with the
CREATE DATABASEprivilege
5.1.1.6. Examples Using CREATE DATABASE
Creating a database in Windows, located on disk D with a page size of 4,096. The owner of the database will be the user wizard. The database will be in Dialect , and will use
WIN1251as its default character set.SET SQL DIALECT 1;CREATE DATABASE 'D:\test.fdb'USER 'wizard' PASSWORD 'player'PAGE_SIZE = 4096 DEFAULT CHARACTER SET WIN1251;Creating a database in the Linux operating system with a page size of 8,192 (default). The owner of the database will be the user wizard. The database will be in Dialect 3 and will use
UTF8as its default character set, withUNICODE_CI_AIas the default collation.CREATE DATABASE '/home/firebird/test.fdb'USER 'wizard' PASSWORD 'player'DEFAULT CHARACTER SET UTF8 COLLATION UNICODE_CI_AI;Creating a database on the remote server
baseserver
with the path specified in the aliastest
that has been defined previously in the filedatabases.conf. The TCP/IP protocol is used. The owner of the database will be the user wizard. The database will be in Dialect 3 and will useUTF8as its default character set.CREATE DATABASE 'baseserver:test'USER 'wizard' PASSWORD 'player'DEFAULT CHARACTER SET UTF8;Creating a database in Dialect 3 with
UTF8as its default character set. The primary file will contain up to 10,000 pages with a page size of 8,192. As soon as the primary file has reached the maximum number of pages, Firebird will start allocating pages to the secondary filetest.fdb2. If that file is filled up to its maximum as well,test.fdb3becomes the recipient of all new page allocations. As the last file, it has no page limit imposed on it by Firebird. New allocations will continue for as long as the file system allows it or until the storage device runs out of free space. If aLENGTHparameter were supplied for this last file, it would be ignored.SET SQL DIALECT 3;CREATE DATABASE 'baseserver:D:\test.fdb'USER 'wizard' PASSWORD 'player'PAGE_SIZE = 8192DEFAULT CHARACTER SET UTF8FILE 'D:\test.fdb2'STARTING AT PAGE 10001FILE 'D:\test.fdb3'STARTING AT PAGE 20001;Creating a database in Dialect 3 with
UTF8as its default character set. The primary file will contain up to 10,000 pages with a page size of 8,192. As far as file size and the use of secondary files are concerned, this database will behave exactly like the one in the previous example.SET SQL DIALECT 3;CREATE DATABASE 'baseserver:D:\test.fdb'USER 'wizard' PASSWORD 'player'PAGE_SIZE = 8192LENGTH 10000 PAGESDEFAULT CHARACTER SET UTF8FILE 'D:\test.fdb2'FILE 'D:\test.fdb3'STARTING AT PAGE 20001;
See alsoSection 5.1.2, “ALTER DATABASE”, Section 5.1.3, “DROP DATABASE”
5.1.2. ALTER DATABASE
Used forAltering the file organisation of a database, toggling its copy-safe
state, managing encryption, and other database-wide configuration
Available inDSQL, ESQL — limited feature set
Syntax
ALTER {DATABASE | SCHEMA} <alter_db_option> [<alter_db_option> ...]
<alter_db_option> :==
<add_sec_clause>
| {ADD DIFFERENCE FILE 'diff_file' | DROP DIFFERENCE FILE}
| {BEGIN | END} BACKUP
| SET DEFAULT CHARACTER SET charset
| {ENCRYPT WITH plugin_name [KEY key_name] | DECRYPT}
| SET LINGER TO linger_duration
| DROP LINGER
| SET DEFAULT SQL SECURITY {INVOKER | DEFINER}
| {ENABLE | DISABLE} PUBLICATION
| INCLUDE <pub_table_filter> TO PUBLICATION
| EXCLUDE <pub_table_filter> FROM PUBLICATION
<add_sec_clause> ::= ADD <sec_file> [<sec_file> ...]
<sec_file> ::=
FILE 'filepath'
[STARTING [AT [PAGE]] pagenum]
[LENGTH [=] num [PAGE[S]]
<pub_table_filter> ::=
ALL
| TABLE table_name [, table_name ...]
Multiple files can be added in one ADD clause:
ALTER DATABASEADD FILE x LENGTH 8000FILE y LENGTH 8000FILE z
Multiple occurrences of add_sec_clause (ADD FILE clauses) are allowed;
an ADD FILE clause that adds multiple files (as in the example above) can be mixed with others that add only one file.
The statement was documented incorrectly in the old InterBase 6 Language Reference.
ALTER DATABASE Statement Parameters| Parameter | Description |
|---|---|
add_sec_clause | Adding a secondary database file |
sec_file | File specification for secondary file |
filepath | Full path and file name of the delta file or secondary database file |
pagenum | Page number from which the secondary database file is to start |
num | Maximum size of the secondary file in pages |
diff_file | File path and name of the .delta file (difference file) |
charset | New default character set of the database |
linger_duration | Duration of linger delay in seconds; must be greater than or equal to 0 (zero) |
plugin_name | The name of the encryption plugin |
key_name | The name of the encryption key |
pub_table_filter | Filter of tables to include to or exclude from publication |
table_name | Name (identifier) of a table |
The ALTER DATABASE statement can:
add secondary files to a database
switch a single-file database into and out of the
copy-safe
mode (DSQL only)set or unset the path and name of the delta file for physical backups (DSQL only)
SCHEMA is currently a synonym for DATABASE;
this may change in a future version, so we recommend to always use DATABASE
5.1.2.1. Who Can Alter the Database
The ALTER DATABASE statement can be executed by:
Users with the
ALTER DATABASEprivilege
5.1.2.2. Parameters for ALTER DATABASE
ADD (FILE)Adds secondary files to the database. It is necessary to specify the full path to the file and the name of the secondary file. The description for the secondary file is similar to the one given for the
CREATE DATABASEstatement.ADD DIFFERENCE FILESpecifies the path and name of the delta file that stores any mutations to the database whenever it is switched to the
copy-safe
mode. This clause does not actually add any file. It just overrides the default name and path of the .delta file. To change the existing settings, you should delete the previously specified description of the .delta file using theDROP DIFFERENCE FILEclause before specifying the new description of the delta file. If the path and name of the .delta file are not overridden, the file will have the same path and name as the database, but with the.deltafile extension.⚠CautionIf only a file name is specified, the .delta file will be created in the current directory of the server. On Windows, this will be the system directory — a very unwise location to store volatile user files and contrary to Windows file system rules.
DROP DIFFERENCE FILEDeletes the description (path and name) of the .delta file specified previously in the
ADD DIFFERENCE FILEclause. The file is not actually deleted.DROP DIFFERENCE FILEdeletes the path and name of the .delta file from the database header. Next time the database is switched to thecopy-safe
mode, the default values will be used (i.e. the same path and name as those of the database, but with the .delta extension).BEGIN BACKUPSwitches the database to the
copy-safe
mode.ALTER DATABASEwith this clause freezes the main database file, making it possible to back it up safely using file system tools, even if users are connected and performing operations with data. Until the backup state of the database is reverted to NORMAL, all changes made to the database will be written to the .delta (difference) file.☝ImportantDespite its syntax, a statement with the
BEGIN BACKUPclause does not start a backup process but just creates the conditions for doing a task that requires the database file to be read-only temporarily.END BACKUPSwitches the database from the
copy-safe
mode to the normal mode. A statement with this clause merges the .delta file with the main database file and restores the normal operation of the database. Once theEND BACKUPprocess starts, the conditions no longer exist for creating safe backups by means of file system tools.🛑WarningUse of
BEGIN BACKUPandEND BACKUPand copying the database files with filesystem tools, is not safe with multi-file databases! Use this method only on single-file databases.Making a safe backup with the gbak utility remains possible at all times, although it is not recommended running gbak while the database is in LOCKED or MERGE state.
SET DEFAULT CHARACTER SETChanges the default character set of the database. This change does not affect existing data or columns. The new default character set will only be used in subsequent DDL commands.
ENCRYPT WITHSee Encrypting a Database in the Security chapter.
DECRYPTSee Decrypting a Database in the Security chapter.
SET LINGER TOSets the linger-delay. The linger-delay applies only to Firebird SuperServer, and is the number of seconds the server keeps a database file (and its caches) open after the last connection to that database was closed. This can help to improve performance at low cost, when the database is opened and closed frequently, by keeping resources
warm
for the next connection.ⓘNoteThis mode can be useful for web applications - without a connection pool - where the connection to the database usually
lives
for a very short time.🛑WarningThe
SET LINGER TOandDROP LINGERclauses can be combined in a single statement, but the last clausewins
. For example,ALTER DATABASE SET LINGER TO 5 DROP LINGERwill set the linger-delay to 0 (no linger), whileALTER DATABASE DROP LINGER SET LINGER to 5will set the linger-delay to 5 seconds.DROP LINGERDrops the linger-delay (sets it to zero). Using
DROP LINGERis equivalent to usingSET LINGER TO 0.ⓘNoteDropping
LINGERis not an ideal solution for the occasional need to turn it off for some once-only condition where the server needs a forced shutdown. The gfix utility now has the-NoLingerswitch, which will close the specified database immediately after the last attachment is gone, regardless of theLINGERsetting in the database. TheLINGERsetting is retained and works normally the next time.The same one-off override is also available through the Services API, using the tag
isc_spb_prp_nolinger, e.g. (in one line):fbsvcmgr host:service_mgr user sysdba password xxxaction_properties dbname employee prp_nolinger🛑WarningThe
DROP LINGERandSET LINGER TOclauses can be combined in a single statement, but the last clausewins
.SET DEFAULT SQL SECURITYSpecifies the default
SQL SECURITYoption to apply at runtime for objects without the SQL Security property set. See also SQL Security in chapter Security.ENABLE PUBLICATIONEnables publication of this database for replication. Replication begins (or continues) with the next transaction started after this transaction commits.
DISABLE PUBLICATIONEnables publication of this database for replication. Replication is disabled immediately after commit.
EXCLUDE … FROM PUBLICATIONExcludes tables from publication. If
INCLUDE ALL TO PUBLICATIONclause is used, then all tables created afterwards will also be replicated, unless overridden explicitly in theCREATE TABLEstatement.INCLUDE … TO PUBLICATIONIncludes tables to publication. If
INCLUDE ALL TO PUBLICATIONclause is used, then all tables created afterwards will also be replicated, unless overridden explicitly in theCREATE TABLEstatement.
Other than the syntax, configuring Firebird for replication is not covered in this language reference.
All replication management commands are DDL statements and thus effectively executed at the transaction commit time.
5.1.2.3. Examples of ALTER DATABASE Usage
Adding a secondary file to the database. As soon as 30000 pages are filled in the previous primary or secondary file, the Firebird engine will start adding data to the secondary file
test4.fdb.ALTER DATABASEADD FILE 'D:\test4.fdb'STARTING AT PAGE 30001;Specifying the path and name of the delta file:
ALTER DATABASEADD DIFFERENCE FILE 'D:\test.diff';Deleting the description of the delta file:
ALTER DATABASEDROP DIFFERENCE FILE;Switching the database to the
copy-safe
mode:ALTER DATABASEBEGIN BACKUP;Switching the database back from the
copy-safe
mode to the normal operation mode:ALTER DATABASEEND BACKUP;Changing the default character set for a database to
WIN1251ALTER DATABASESET DEFAULT CHARACTER SET WIN1252;Setting a linger-delay of 30 seconds
ALTER DATABASESET LINGER TO 30;Encrypting the database with a plugin called
DbCryptALTER DATABASEENCRYPT WITH DbCrypt;Decrypting the database
ALTER DATABASEDECRYPT;
See alsoSection 5.1.1, “CREATE DATABASE”, Section 5.1.3, “DROP DATABASE”
5.1.3. DROP DATABASE
Used forDeleting the database to which you are currently connected
Available inDSQL, ESQL
Syntax
DROP DATABASE
The DROP DATABASE statement deletes the current database.
Before deleting a database, you have to connect to it.
The statement deletes the primary file, all secondary files and all shadow files.
Contrary to CREATE DATABASE and ALTER DATABASE, DROP SCHEMA is not a valid alias for DROP DATABASE.
This is intentional.
5.1.3.1. Who Can Drop a Database
The DROP DATABASE statement can be executed by:
Users with the
DROP DATABASEprivilege
5.1.3.2. Example of DROP DATABASE
Deleting the current database
DROP DATABASE;
See alsoSection 5.1.1, “CREATE DATABASE”, Section 5.1.2, “ALTER DATABASE”