Chapter 5. Data Definition (DDL) Statements
DDL is the data definition language subset of Firebird’s SQL language. DDL statements are used to create, alter and drop database objects. When a DDL statement is committed, the metadata for the object are created, altered 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 drop a database.
It also shows two methods to back up a database and how to switch the database to the copy-safe
mode for performing an external backup safely.
5.1.1. CREATE DATABASE
Creates 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}]:
| | <protocol>://[host[:{port | service}]/]
|
|<protocol> ::= inet | inet4 | inet6 | 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 ParametersParameter | 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 consists of one or more 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 = filepath
Executing 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 fall back 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}
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
- 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
USER
andPASSWORD
The username and the password of an existing user in the security database (
security5.fdb
or whatever is configured in the SecurityDatabase configuration). You do not have to specify the username and password if theISC_USER
andISC_PASSWORD
environment 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.ROLE
The name of the role (usually
RDB$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_SIZE
The desired 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, the default value of 8,192 is used.
ⓘ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.
LENGTH
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
LENGTH
clause. TheLENGTH
value 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 NAMES
The character set of the connection available after the database is successfully created. The character set
NONE
is used by default. Notice that the character set should be enclosed in a pair of apostrophes (single quotes).DEFAULT CHARACTER SET
The default character set for creating data structures of string data types. Character sets are used for
CHAR
,VARCHAR
andBLOB SUB_TYPE TEXT
data types. The character setNONE
is used by default. It is also possible to specify the defaultCOLLATION
for the default character set, making that collation 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 AT
The database page number at which the next secondary database file should start. When the previous file is fully filled with data according to the specified page number, the system will start adding new data to the next database file.
DIFFERENCE FILE
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 BACKUP
statement. For the detailed description of this clause, see Section 5.1.2, “ALTER DATABASE
”.
5.1.1.4. Specifying the Database Dialect
Databases are created in Dialect 3 by default.
For the database to be created in 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 DATABASE
privilege
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 1, and will use
WIN1251
as 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
UTF8
as its default character set, withUNICODE_CI_AI
as 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 useUTF8
as its default character set.|
CREATE DATABASE 'baseserver:test'
|USER 'wizard' PASSWORD 'player'
|DEFAULT CHARACTER SET UTF8;
Creating a database in Dialect 3 with
UTF8
as 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.fdb3
becomes 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 aLENGTH
parameter 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 = 8192
|DEFAULT CHARACTER SET UTF8
|FILE 'D:\test.fdb2'
|STARTING AT PAGE 10001
|FILE 'D:\test.fdb3'
|STARTING AT PAGE 20001;
Creating a database in Dialect 3 with
UTF8
as 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 = 8192
|LENGTH 10000 PAGES
|DEFAULT CHARACTER SET UTF8
|FILE '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
Alters the file organisation of a database, toggles its copy-safe
state, manages 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 DATABASE
|ADD FILE x LENGTH 8000
|FILE y LENGTH 8000
|FILE 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.
ALTER DATABASE
Statement ParametersParameter | 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 DATABASE
privilege
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 DATABASE
statement.ADD DIFFERENCE FILE
Specifies the path and name of the difference file (or, delta file) that stores any mutations to the database whenever it is switched to the
copy-safe
mode. This clause does not add a file, but it configures name and path of the delta file when the database is incopy-safe
mode. To change the existing setting, you should delete the previously specified description of the delta file using theDROP DIFFERENCE FILE
clause before specifying the new description of the delta file. If the path and name of the delta file are not configured, the file will have the same path and name as the database, but with the.delta
file extension.⚠CautionIf only a filename 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 FILE
Deletes the description (path and name) of the difference file specified previously in the
ADD DIFFERENCE FILE
clause. This does not delete a file, butDROP DIFFERENCE FILE
clears (resets) 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 BACKUP
Switches the database to the
copy-safe
mode.ALTER DATABASE
with 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 name, the
ALTER DATABASE BEGIN BACKUP
statement does not start a backup process, but only freezes the database, to create the conditions for doing a task that requires the database file to be read-only temporarily.END BACKUP
Switches the database from the
copy-safe
mode to the normal mode. A statement with this clause merges the difference file with the main database file and restores the normal operation of the database. Once theEND BACKUP
process starts, the conditions no longer exist for creating safe backups by means of file system tools.🛑WarningUse of
BEGIN BACKUP
andEND BACKUP
and 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 SET
Changes 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. To modify the default collation, use
ALTER CHARACTER SET
on the default character set of the database.ENCRYPT WITH
See Encrypting a Database in the Security chapter.
DECRYPT
See Decrypting a Database in the Security chapter.
SET LINGER TO
Sets 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.☞TipThis mode can be useful for web applications — without a connection pool — where connections to the database usually
live
for a very short time.🛑WarningThe
SET LINGER TO
andDROP LINGER
clauses can be combined in a single statement, but the last clausewins
. For example,ALTER DATABASE SET LINGER TO 5 DROP LINGER
will set the linger-delay to 0 (no linger), whileALTER DATABASE DROP LINGER SET LINGER to 5
will set the linger-delay to 5 seconds.DROP LINGER
Drops the linger-delay (sets it to zero). Using
DROP LINGER
is equivalent to usingSET LINGER TO 0
.ⓘNoteDropping
LINGER
is not an ideal solution for the occasional need to turn it off for once-only operations where the server needs a forced shutdown. The gfix utility now has the-NoLinger
switch, which will close the specified database immediately after the last attachment is gone, regardless of theLINGER
setting in the database. TheLINGER
setting 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 xxx
|action_properties dbname employee prp_nolinger
🛑WarningThe
DROP LINGER
andSET LINGER TO
clauses can be combined in a single statement, but the last clausewins
.SET DEFAULT SQL SECURITY
Specifies the default
SQL SECURITY
option to apply at runtime for objects without the SQL Security property set. See also SQL Security in chapter Security.ENABLE PUBLICATION
Enables publication of this database for replication. Replication begins (or continues) with the next transaction started after this transaction commits.
DISABLE PUBLICATION
Enables publication of this database for replication. Replication is disabled immediately after commit.
EXCLUDE … FROM PUBLICATION
Excludes tables from publication. If the
INCLUDE ALL TO PUBLICATION
clause is used, all tables created afterward will also be replicated, unless overridden explicitly in theCREATE TABLE
statement.INCLUDE … TO PUBLICATION
Includes tables to publication. If the
INCLUDE ALL TO PUBLICATION
clause is used, all tables created afterward will also be replicated, unless overridden explicitly in theCREATE TABLE
statement.
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 DATABASE
|ADD FILE 'D:\test4.fdb'
|STARTING AT PAGE 30001;
Specifying the path and name of the delta file:
|
ALTER DATABASE
|ADD DIFFERENCE FILE 'D:\test.diff';
Deleting the description of the delta file:
|
ALTER DATABASE
|DROP DIFFERENCE FILE;
Switching the database to the
copy-safe
mode:|
ALTER DATABASE
|BEGIN BACKUP;
Switching the database back from the
copy-safe
mode to the normal operation mode:|
ALTER DATABASE
|END BACKUP;
Changing the default character set for a database to
WIN1251
|
ALTER DATABASE
|SET DEFAULT CHARACTER SET WIN1252;
Setting a linger-delay of 30 seconds
|
ALTER DATABASE
|SET LINGER TO 30;
Encrypting the database with a plugin called
DbCrypt
|
ALTER DATABASE
|ENCRYPT WITH DbCrypt;
Decrypting the database
|
ALTER DATABASE
|DECRYPT;
See alsoSection 5.1.1, “CREATE DATABASE
”, Section 5.1.3, “DROP DATABASE
”
5.1.3. DROP DATABASE
Drops (deletes) the database of the current connection
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 DATABASE
privilege
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
”