|
dolibarr
13.0.2
|
Class to manage Dolibarr database access for a SQLite database. More...
Inheritance diagram for DoliDBSqlite3:
Collaboration diagram for DoliDBSqlite3:Public Member Functions | |
| __construct ($type, $host, $user, $pass, $name= '', $port=0) | |
| Constructor. More... | |
| select_db ($database) | |
| Select a database. More... | |
| connect ($host, $login, $passwd, $name, $port=0) | |
| Connexion to server. More... | |
| getVersion () | |
| Return version of database server. More... | |
| getDriverInfo () | |
| Return version of database client driver. More... | |
| close () | |
| Close database connexion. More... | |
| query ($query, $usesavepoint=0, $type= 'auto') | |
| Execute a SQL request and return the resultset. More... | |
| fetch_object ($resultset) | |
| Renvoie la ligne courante (comme un objet) pour le curseur resultset. More... | |
| fetch_array ($resultset) | |
| Return datas as an array. More... | |
| fetch_row ($resultset) | |
| Return datas as an array. More... | |
| num_rows ($resultset) | |
| Return number of lines for result of a SELECT. More... | |
| affected_rows ($resultset) | |
| Return number of lines for result of a SELECT. More... | |
| free ($resultset=null) | |
| Free last resultset used. More... | |
| escape ($stringtoencode) | |
| Escape a string to insert data. More... | |
| errno () | |
| Renvoie le code erreur generique de l'operation precedente. More... | |
| error () | |
| Renvoie le texte de l'erreur mysql de l'operation precedente. More... | |
| last_insert_id ($tab, $fieldid= 'rowid') | |
| Get last ID after an insert INSERT. More... | |
| encrypt ($fieldorvalue, $withQuotes=0) | |
| Encrypt sensitive data in database Warning: This function includes the escape, so it must use direct value. More... | |
| decrypt ($value) | |
| Decrypt sensitive data in database. More... | |
| DDLGetConnectId () | |
| Return connexion ID. More... | |
| DDLCreateDb ($database, $charset= '', $collation= '', $owner= '') | |
| Create a new database Do not use function xxx_create_db (xxx=mysql, ...) as they are deprecated We force to create database with charset this->forcecharset and collate this->forcecollate. More... | |
| DDLListTables ($database, $table= '') | |
| List tables into a database. More... | |
| DDLInfoTable ($table) | |
| List information of columns into a table. More... | |
| DDLCreateTable ($table, $fields, $primary_key, $type, $unique_keys=null, $fulltext_keys=null, $keys=null) | |
| Create a table into database. More... | |
| DDLDropTable ($table) | |
| Drop a table into database. More... | |
| DDLDescTable ($table, $field="") | |
| Return a pointer of line with description of a table or field. More... | |
| DDLAddField ($table, $field_name, $field_desc, $field_position="") | |
| Create a new field into table. More... | |
| DDLUpdateField ($table, $field_name, $field_desc) | |
| Update format of a field into a table. More... | |
| DDLDropField ($table, $field_name) | |
| Drop a field from table. More... | |
| DDLCreateUser ($dolibarr_main_db_host, $dolibarr_main_db_user, $dolibarr_main_db_pass, $dolibarr_main_db_name) | |
| Create a user and privileges to connect to database (even if database does not exists yet) More... | |
| getDefaultCharacterSetDatabase () | |
| Return charset used to store data in database. More... | |
| getListOfCharacterSet () | |
| Return list of available charset that can be used to store data in database. More... | |
| getDefaultCollationDatabase () | |
| Return collation used in database. More... | |
| getListOfCollation () | |
| Return list of available collation that can be used for database. More... | |
| getPathOfDump () | |
| Return full path of dump program. More... | |
| getPathOfRestore () | |
| Return full path of restore program. More... | |
| getServerParametersValues ($filter= '') | |
| Return value of server parameters. More... | |
| getServerStatusValues ($filter= '') | |
| Return value of server status. More... | |
Public Member Functions inherited from DoliDB | |
| ifsql ($test, $resok, $resko) | |
| Format a SQL IF. More... | |
| idate ($param, $gm= 'tzserver') | |
| Convert (by PHP) a GM Timestamp date into a string date with PHP server TZ to insert into a date field. More... | |
| lasterrno () | |
| Return last error code. More... | |
| sanitize ($stringtosanitize, $allowsimplequote=0) | |
| Sanitize a string for SQL forging. More... | |
| begin () | |
| Start transaction. More... | |
| commit ($log= '') | |
| Validate a database transaction. More... | |
| rollback ($log= '') | |
| Cancel a transaction and go back to initial data values. More... | |
| plimit ($limit=0, $offset=0) | |
| Define limits and offset of request. More... | |
| getVersionArray () | |
| Return version of database server into an array. More... | |
| lastquery () | |
| Return last request executed with query() More... | |
| order ($sortfield=null, $sortorder=null) | |
| Define sort criteria of request. More... | |
| lasterror () | |
| Return last error label. More... | |
| jdate ($string, $gm= 'tzserver') | |
| Convert (by PHP) a PHP server TZ string date into a Timestamps date (GMT if gm=true) 19700101020000 -> 3600 with TZ+1 and gmt=0 19700101020000 -> 7200 whaterver is TZ if gmt=1. More... | |
| lastqueryerror () | |
| Return last query in error. More... | |
| getRow ($sql) | |
| Return first result from query as object Note : This method executes a given SQL query and retrieves the first row of results as an object. More... | |
| getRows ($sql) | |
| return all results from query as an array of objects Note : This method executes a given SQL query and retrieves all row of results as an array of objects. More... | |
Public Member Functions inherited from Database | |
| idate ($param) | |
| Convert (by PHP) a GM Timestamp date into a string date with PHP server TZ to insert into a date field. More... | |
| sanitize ($stringtosanitize) | |
| Sanitize a string for SQL forging. More... | |
Static Public Member Functions | |
| static | convertSQLFromMysql ($line, $type= 'ddl') |
| Convert a SQL request in Mysql syntax to native syntax. More... | |
Public Attributes | |
| $type = 'sqlite3' | |
| Database type. | |
| const | LABEL = 'Sqlite3' |
| Database label. | |
| const | VERSIONMIN = '3.0.0' |
| Version min database. | |
Private Member Functions | |
| addCustomFunction ($name, $arg_count=-1) | |
| Permet le chargement d'une fonction personnalisee dans le moteur de base de donnees. More... | |
Static Private Member Functions | |
| static | calc_daynr ($year, $month, $day) |
| calc_daynr More... | |
| static | calc_weekday ($daynr, $sunday_first_day_of_week) |
| calc_weekday More... | |
| static | calc_days_in_year ($year) |
| calc_days_in_year More... | |
| static | calc_week ($year, $month, $day, $week_behaviour, &$calc_year) |
| calc_week More... | |
Class to manage Dolibarr database access for a SQLite database.
Definition at line 33 of file sqlite3.class.php.
| DoliDBSqlite3::__construct | ( | $type, | |
| $host, | |||
| $user, | |||
| $pass, | |||
$name = '', |
|||
$port = 0 |
|||
| ) |
Constructor.
This create an opened connexion to a database server and eventually to a database
| string | $type | Type of database (mysql, pgsql...) |
| string | $host | Address of database server |
| string | $user | Nom de l'utilisateur autorise |
| string | $pass | Mot de passe |
| string | $name | Nom de la database |
| int | $port | Port of database server |
Definition at line 60 of file sqlite3.class.php.
References addCustomFunction(), connect(), db, dol_syslog(), and error().
|
private |
Permet le chargement d'une fonction personnalisee dans le moteur de base de donnees.
Note: le nom de la fonction personnalisee est prefixee par 'db'. La fonction doit ĂȘtre statique et publique. Le nombre de parametres est determine automatiquement.
| string | $name | Le nom de la fonction a definir dans Sqlite |
| int | $arg_count | Arg count |
Definition at line 1308 of file sqlite3.class.php.
Referenced by __construct().
| DoliDBSqlite3::affected_rows | ( | $resultset | ) |
Return number of lines for result of a SELECT.
| SQLite3Result | $resultset | Resulset of requests |
Implements Database.
Definition at line 587 of file sqlite3.class.php.
References db, and num_rows().
|
staticprivate |
calc_daynr
| int | $year | Year |
| int | $month | Month |
| int | $day | Day |
Definition at line 1335 of file sqlite3.class.php.
|
staticprivate |
calc_days_in_year
| string | $year | Year |
Definition at line 1371 of file sqlite3.class.php.
|
staticprivate |
calc_week
| string | $year | Year |
| string | $month | Month |
| string | $day | Day |
| string | $week_behaviour | Week behaviour |
| string | $calc_year | ??? |
Definition at line 1388 of file sqlite3.class.php.
|
staticprivate |
calc_weekday
| int | $daynr | ??? |
| bool | $sunday_first_day_of_week | ??? |
Definition at line 1357 of file sqlite3.class.php.
| DoliDBSqlite3::close | ( | ) |
Close database connexion.
Implements Database.
Definition at line 379 of file sqlite3.class.php.
References db, and dol_syslog().
| DoliDBSqlite3::connect | ( | $host, | |
| $login, | |||
| $passwd, | |||
| $name, | |||
$port = 0 |
|||
| ) |
Connexion to server.
| string | $host | database server host |
| string | $login | login |
| string | $passwd | password |
| string | $name | name of database (not used for mysql, used for pgsql) |
| integer | $port | Port of database server |
Implements Database.
Definition at line 324 of file sqlite3.class.php.
References db, dol_syslog(), and error().
Referenced by __construct().
|
static |
Convert a SQL request in Mysql syntax to native syntax.
| string | $line | SQL request line to convert |
| string | $type | Type of SQL order ('ddl' for insert, update, select, delete or 'dml' for create, alter...) |
Implements Database.
Definition at line 135 of file sqlite3.class.php.
References $type, and dol_syslog().
Referenced by query().
| DoliDBSqlite3::DDLAddField | ( | $table, | |
| $field_name, | |||
| $field_desc, | |||
$field_position = "" |
|||
| ) |
Create a new field into table.
| string | $table | Name of table |
| string | $field_name | Name of field to add |
| string | $field_desc | Tableau associatif de description du champ a inserer[nom du parametre][valeur du parametre] |
| string | $field_position | Optionnel ex.: "after champtruc" |
Implements Database.
Definition at line 1013 of file sqlite3.class.php.
| DoliDBSqlite3::DDLCreateDb | ( | $database, | |
$charset = '', |
|||
$collation = '', |
|||
$owner = '' |
|||
| ) |
Create a new database Do not use function xxx_create_db (xxx=mysql, ...) as they are deprecated We force to create database with charset this->forcecharset and collate this->forcecollate.
| string | $database | Database name to create |
| string | $charset | Charset used to store data |
| string | $collation | Charset used to sort data |
| string | $owner | Username of database owner |
Implements Database.
Definition at line 813 of file sqlite3.class.php.
| DoliDBSqlite3::DDLCreateTable | ( | $table, | |
| $fields, | |||
| $primary_key, | |||
| $type, | |||
$unique_keys = null, |
|||
$fulltext_keys = null, |
|||
$keys = null |
|||
| ) |
Create a table into database.
| string | $table | Nom de la table |
| array | $fields | Tableau associatif [nom champ][tableau des descriptions] |
| string | $primary_key | Nom du champ qui sera la clef primaire |
| string | $type | Type de la table |
| array | $unique_keys | Tableau associatifs Nom de champs qui seront clef unique => valeur |
| array | $fulltext_keys | Tableau des Nom de champs qui seront indexes en fulltext |
| array | $keys | Tableau des champs cles noms => valeur |
Implements Database.
Definition at line 903 of file sqlite3.class.php.
| DoliDBSqlite3::DDLCreateUser | ( | $dolibarr_main_db_host, | |
| $dolibarr_main_db_user, | |||
| $dolibarr_main_db_pass, | |||
| $dolibarr_main_db_name | |||
| ) |
Create a user and privileges to connect to database (even if database does not exists yet)
| string | $dolibarr_main_db_host | Ip serveur |
| string | $dolibarr_main_db_user | Nom user a creer |
| string | $dolibarr_main_db_pass | Mot de passe user a creer |
| string | $dolibarr_main_db_name | Database name where user must be granted |
Implements Database.
Definition at line 1103 of file sqlite3.class.php.
| DoliDBSqlite3::DDLDescTable | ( | $table, | |
$field = "" |
|||
| ) |
Return a pointer of line with description of a table or field.
| string | $table | Name of table |
| string | $field | Optionnel : Name of field if we want description of field |
Implements Database.
Definition at line 993 of file sqlite3.class.php.
| DoliDBSqlite3::DDLDropField | ( | $table, | |
| $field_name | |||
| ) |
Drop a field from table.
| string | $table | Name of table |
| string | $field_name | Name of field to drop |
Implements Database.
Definition at line 1079 of file sqlite3.class.php.
| DoliDBSqlite3::DDLDropTable | ( | $table | ) |
Drop a table into database.
| string | $table | Name of table |
Implements Database.
Definition at line 975 of file sqlite3.class.php.
| DoliDBSqlite3::DDLGetConnectId | ( | ) |
Return connexion ID.
Implements Database.
Definition at line 794 of file sqlite3.class.php.
| DoliDBSqlite3::DDLInfoTable | ( | $table | ) |
List information of columns into a table.
| string | $table | Name of table |
Implements Database.
Definition at line 871 of file sqlite3.class.php.
| DoliDBSqlite3::DDLListTables | ( | $database, | |
$table = '' |
|||
| ) |
List tables into a database.
| string | $database | Name of database |
| string | $table | Name of table filter ('xxx') |
Implements Database.
Definition at line 843 of file sqlite3.class.php.
| DoliDBSqlite3::DDLUpdateField | ( | $table, | |
| $field_name, | |||
| $field_desc | |||
| ) |
Update format of a field into a table.
| string | $table | Name of table |
| string | $field_name | Name of field to modify |
| string | $field_desc | Array with description of field format |
Implements Database.
Definition at line 1056 of file sqlite3.class.php.
| DoliDBSqlite3::decrypt | ( | $value | ) |
Decrypt sensitive data in database.
| string | $value | Value to decrypt |
Implements Database.
Definition at line 761 of file sqlite3.class.php.
| DoliDBSqlite3::encrypt | ( | $fieldorvalue, | |
$withQuotes = 0 |
|||
| ) |
Encrypt sensitive data in database Warning: This function includes the escape, so it must use direct value.
| string | $fieldorvalue | Field name or value to encrypt |
| int | $withQuotes | Return string with quotes |
Implements Database.
Definition at line 729 of file sqlite3.class.php.
References escape().
| DoliDBSqlite3::errno | ( | ) |
| DoliDBSqlite3::error | ( | ) |
Renvoie le texte de l'erreur mysql de l'operation precedente.
Implements Database.
Definition at line 697 of file sqlite3.class.php.
Referenced by __construct(), addCustomFunction(), connect(), errno(), and query().
| DoliDBSqlite3::escape | ( | $stringtoencode | ) |
Escape a string to insert data.
| string | $stringtoencode | String to escape |
Implements Database.
Definition at line 623 of file sqlite3.class.php.
| DoliDBSqlite3::fetch_array | ( | $resultset | ) |
Return datas as an array.
| SQLite3Result | $resultset | Resultset of request |
Implements Database.
Definition at line 527 of file sqlite3.class.php.
Referenced by getPathOfDump(), and getPathOfRestore().
| DoliDBSqlite3::fetch_object | ( | $resultset | ) |
Renvoie la ligne courante (comme un objet) pour le curseur resultset.
| SQLite3Result | $resultset | Curseur de la requete voulue |
Implements Database.
Definition at line 506 of file sqlite3.class.php.
| DoliDBSqlite3::fetch_row | ( | $resultset | ) |
Return datas as an array.
| SQLite3Result | $resultset | Resultset of request |
Implements Database.
Definition at line 544 of file sqlite3.class.php.
Referenced by getServerParametersValues().
| DoliDBSqlite3::free | ( | $resultset = null | ) |
Free last resultset used.
| SQLite3Result | $resultset | Curseur de la requete voulue |
Implements Database.
Definition at line 609 of file sqlite3.class.php.
| DoliDBSqlite3::getDefaultCharacterSetDatabase | ( | ) |
Return charset used to store data in database.
Implements Database.
Definition at line 1146 of file sqlite3.class.php.
| DoliDBSqlite3::getDefaultCollationDatabase | ( | ) |
Return collation used in database.
Implements Database.
Definition at line 1170 of file sqlite3.class.php.
| DoliDBSqlite3::getDriverInfo | ( | ) |
Return version of database client driver.
Implements Database.
Definition at line 367 of file sqlite3.class.php.
| DoliDBSqlite3::getListOfCharacterSet | ( | ) |
Return list of available charset that can be used to store data in database.
Implements Database.
Definition at line 1156 of file sqlite3.class.php.
| DoliDBSqlite3::getListOfCollation | ( | ) |
Return list of available collation that can be used for database.
Implements Database.
Definition at line 1180 of file sqlite3.class.php.
| DoliDBSqlite3::getPathOfDump | ( | ) |
Return full path of dump program.
Implements Database.
Definition at line 1194 of file sqlite3.class.php.
References $resql, and fetch_array().
| DoliDBSqlite3::getPathOfRestore | ( | ) |
Return full path of restore program.
Implements Database.
Definition at line 1214 of file sqlite3.class.php.
References $resql, fetch_array(), and query().
| DoliDBSqlite3::getServerParametersValues | ( | $filter = '' | ) |
Return value of server parameters.
| string | $filter | Filter list on a particular value |
Implements Database.
Definition at line 1235 of file sqlite3.class.php.
References $resql, fetch_row(), and query().
| DoliDBSqlite3::getServerStatusValues | ( | $filter = '' | ) |
Return value of server status.
| string | $filter | Filter list on a particular value |
Implements Database.
Definition at line 1283 of file sqlite3.class.php.
| DoliDBSqlite3::getVersion | ( | ) |
Return version of database server.
Implements Database.
Definition at line 356 of file sqlite3.class.php.
References db.
| DoliDBSqlite3::last_insert_id | ( | $tab, | |
$fieldid = 'rowid' |
|||
| ) |
Get last ID after an insert INSERT.
| string | $tab | Table name concerned by insert. Ne sert pas sous MySql mais requis pour compatibilite avec Postgresql |
| string | $fieldid | Field name |
Implements Database.
Definition at line 715 of file sqlite3.class.php.
References db.
| DoliDBSqlite3::num_rows | ( | $resultset | ) |
Return number of lines for result of a SELECT.
| SQLite3Result | $resultset | Resulset of requests |
Implements Database.
Definition at line 566 of file sqlite3.class.php.
References db.
Referenced by affected_rows().
| DoliDBSqlite3::query | ( | $query, | |
$usesavepoint = 0, |
|||
$type = 'auto' |
|||
| ) |
Execute a SQL request and return the resultset.
| string | $query | SQL query string |
| int | $usesavepoint | 0=Default mode, 1=Run a savepoint before and a rollbock to savepoint if error (this allow to have some request with errors inside global transactions). Note that with Mysql, this parameter is not used as Myssql can already commit a transaction even if one request is in error, without using savepoints. |
| string | $type | Type of SQL order ('ddl' for insert, update, select, delete or 'dml' for create, alter...) |
Implements Database.
Definition at line 401 of file sqlite3.class.php.
References $type, convertSQLFromMysql(), db, dol_syslog(), errno(), error(), escape(), DoliDB\lasterrno(), DoliDB\lasterror(), DoliDB\lastquery(), and DoliDB\lastqueryerror().
Referenced by getPathOfRestore(), and getServerParametersValues().
| DoliDBSqlite3::select_db | ( | $database | ) |
Select a database.
| string | $database | Name of database |
Implements Database.
Definition at line 303 of file sqlite3.class.php.
References dol_syslog().