DbConnect: Difference between revisions
| No edit summary | No edit summary | ||
| Line 6: | Line 6: | ||
| This function opens a connection to a database and returns an element that can be used with [[dbQuery]]. To disconnect use [[destroyElement]]. | This function opens a connection to a database and returns an element that can be used with [[dbQuery]]. To disconnect use [[destroyElement]]. | ||
| Connecting and disconnecting many times can have a performance impact on the server. For optimal performance it is recommended that you use dbConnect once when the resource starts | ''Note: Connecting and disconnecting many times can have a performance impact on the server. For optimal performance it is recommended that you use dbConnect only once when the resource starts, and share the connection element with the whole script.'' | ||
| ==Syntax==   | ==Syntax==   | ||
| Line 28: | Line 28: | ||
| *'''options :''' List of key=value pairs separated by semicolons. Supported keys are: | *'''options :''' List of key=value pairs separated by semicolons. Supported keys are: | ||
| **'''share''' which can be set to 0 or 1. When set to 1, the connection is shared and will be used by other calls to dbConnect with the same host string. This is usually a good thing for SQLite connections, but not so good for MySQL unless care is taken. Default value for SQLite is "share=1". Default value for MySQL is "share=0" | **'''share''' which can be set to 0 or 1. When set to 1, the connection is shared and will be used by other calls to dbConnect with the same host string. This is usually a good thing for SQLite connections, but not so good for MySQL unless care is taken. Default value for SQLite is "share=1". Default value for MySQL is "share=0" | ||
| **'''batch''' which can be set to 0 or 1. When set to 1, queries called in the same frame are automatically batched together which can significantly speed up inserts/updates. The downside is you lose control of the feature that is used to achieve batching (For SQLite it is transactions, for MySQL it is autocommit mode). Therefore, if you use transactions, lock tables or control autocommit yourself, you may want to disable this feature. Default value "batch=1". | |||
| ===Returns=== | ===Returns=== | ||
Revision as of 16:47, 30 October 2011
Available only in MTA SA 1.1.1 r3328 and onwards This function opens a connection to a database and returns an element that can be used with dbQuery. To disconnect use destroyElement.
Note: Connecting and disconnecting many times can have a performance impact on the server. For optimal performance it is recommended that you use dbConnect only once when the resource starts, and share the connection element with the whole script.
Syntax
element dbConnect ( string databaseType, string host [, string username, string password, string options ] )
Required Arguments
- databaseType: The type of database. This can be either sqlite or mysql
- host: The target to connect to. The format of this depends on the database type.
- For SQLite it is a filepath to a SQLite database file. If the filepath starts with ":/" then the server's global databases directory is used.
- For MySQL it is a list of key=value pairs separated by semicolons. Supported keys are:
- dbname: Name of the database to use e.g. dbname=test
- host: Host address e.g. host=127.0.0.1
- port: Host port e.g. port=1234 (optional, defaults to standard MySQL port if not used)
- unix_socket: Unix socket or named pipe to use (optional, thankgoodness)
 
 
Optional Arguments
- username: Usually required for MySQL, ignored by SQLite
- password: Usually required for MySQL, ignored by SQLite
- options : List of key=value pairs separated by semicolons. Supported keys are:
- share which can be set to 0 or 1. When set to 1, the connection is shared and will be used by other calls to dbConnect with the same host string. This is usually a good thing for SQLite connections, but not so good for MySQL unless care is taken. Default value for SQLite is "share=1". Default value for MySQL is "share=0"
- batch which can be set to 0 or 1. When set to 1, queries called in the same frame are automatically batched together which can significantly speed up inserts/updates. The downside is you lose control of the feature that is used to achieve batching (For SQLite it is transactions, for MySQL it is autocommit mode). Therefore, if you use transactions, lock tables or control autocommit yourself, you may want to disable this feature. Default value "batch=1".
 
Returns
Returns a database connection element unless there are problems, in which case it return false.
Example
This example opens a connection to a SQLite database file in the current resource
test_db = dbConnect( "sqlite", "file.db" )
This example opens a connection to a SQLite database file in another resource
test_db = dbConnect( "sqlite", ":resname/file.db" )
This example opens a connection to a SQLite database file in the global databases directory
test_db = dbConnect( "sqlite", ":/file.db" )
This example opens a connection to a SQLite database file in a sub directory of the global databases directory
test_db = dbConnect( "sqlite", ":/example/sub/dir/file.db" )
This example opens a connection to a MySQL database called 'frank' at server ip 1.2.3.4 and allows the connection to be shared. Note that changing the database or other connection dependent settings affect all connections that are shared.
test_db = dbConnect( "mysql", "dbname=frank;host=1.2.3.4", "username", "password", "share=1" )
This example opens a connection to a SQLite database is disallows sharing of the connection
test_db = dbConnect( "sqlite", ":file.db", "", "", "share=0" )
Requirements
This template will be deleted.
See Also