mirror of
https://github.com/moodle/moodle.git
synced 2025-04-14 13:02:07 +02:00
MDL-51245 mssql: Diagnose missing READ_COMMITTED_SNAPSHOT mode
Without it, transactions are executed in standard READ_COMMITED mode, without snapshoting/row versioning, leading to update conflicts under high concurrency.
This commit is contained in:
parent
1dabedeedf
commit
a9daab4927
@ -388,6 +388,7 @@ $string['movecatcontentstoroot'] = 'Moving the category content to root is not a
|
||||
$string['movecategorynotpossible'] = 'You cannot move category \'{$a}\' into the selected category.';
|
||||
$string['movecategoryownparent'] = 'You cannot make category \'{$a}\' a parent of itself.';
|
||||
$string['movecategoryparentconflict'] = 'You cannot make category \'{$a}\' a subcategory of one of its own subcategories.';
|
||||
$string['mssqlrcsmodemissing'] = 'The database is not using the expected READ_COMMITTED_SNAPSHOT mode which can lead to wrong results, especially under high concurrency scenarios. Please enable it for correct behaviour. You can find more information in the <a href="https://docs.moodle.org/en/Installing_MSSQL_for_PHP#Configuration">Moodle Docs</a>.';
|
||||
$string['multiplerecordsfound'] = 'Multiple records found, only one record expected.';
|
||||
$string['multiplerestorenotallow'] = 'Multiple restore execution not allowed!';
|
||||
$string['mustbeloggedin'] = 'You must be logged in to do this';
|
||||
|
@ -98,6 +98,37 @@ class mssql_native_moodle_database extends moodle_database {
|
||||
return get_string('nativemssqlhelp', 'install');
|
||||
}
|
||||
|
||||
/**
|
||||
* Diagnose database and tables, this function is used
|
||||
* to verify database and driver settings, db engine types, etc.
|
||||
*
|
||||
* @return string null means everything ok, string means problem found.
|
||||
*/
|
||||
public function diagnose() {
|
||||
// Verify the database is running with READ_COMMITTED_SNAPSHOT enabled.
|
||||
// (that's required to get snapshots/row versioning on READ_COMMITED mode).
|
||||
$correctrcsmode = false;
|
||||
$sql = "SELECT is_read_committed_snapshot_on
|
||||
FROM sys.databases
|
||||
WHERE name = '{$this->dbname}'";
|
||||
$this->query_start($sql, null, SQL_QUERY_AUX);
|
||||
$result = mssql_query($sql, $this->mssql);
|
||||
$this->query_end($result);
|
||||
if ($result) {
|
||||
if ($row = mssql_fetch_assoc($result)) {
|
||||
$correctrcsmode = (bool)reset($row);
|
||||
}
|
||||
}
|
||||
$this->free_result($result);
|
||||
|
||||
if (!$correctrcsmode) {
|
||||
return get_string('mssqlrcsmodemissing', 'error');
|
||||
}
|
||||
|
||||
// Arrived here, all right.
|
||||
return null;
|
||||
}
|
||||
|
||||
/**
|
||||
* Connect to db
|
||||
* Must be called before other methods.
|
||||
|
Loading…
x
Reference in New Issue
Block a user