mirror of
https://github.com/moodle/moodle.git
synced 2025-04-21 16:32:18 +02:00
MDL-44377 dml: enforce non-empty prefix for sqlsrv
Only MySQL is allowed to run Moodle instances without (with an empty) database prefix. The rationale is that "user" is a reserved word in every RDBMS but MySQL. Before this patch, installation was breaking badly, when the "user" CREATE TABLE statement was issued. With this patch the error is shown earlier (on connection) preventing any advance/use of the database. This check is present in all the drivers, just sqlsrv was missing it.
This commit is contained in:
parent
76e4de31cc
commit
7b9ea861b6
@ -130,6 +130,11 @@ class sqlsrv_native_moodle_database extends moodle_database {
|
||||
* @throws dml_connection_exception if error
|
||||
*/
|
||||
public function connect($dbhost, $dbuser, $dbpass, $dbname, $prefix, array $dboptions=null) {
|
||||
if ($prefix == '' and !$this->external) {
|
||||
// Enforce prefixes for everybody but mysql.
|
||||
throw new dml_exception('prefixcannotbeempty', $this->get_dbfamily());
|
||||
}
|
||||
|
||||
$driverstatus = $this->driver_installed();
|
||||
|
||||
if ($driverstatus !== true) {
|
||||
|
Loading…
x
Reference in New Issue
Block a user