mirror of
https://github.com/moodle/moodle.git
synced 2025-08-05 00:46:50 +02:00
MDL-35691 fix max length calculation in pg, mysql and our bigint checker
This commit is contained in:
parent
ccd90e765e
commit
3c17c85ae6
3 changed files with 45 additions and 30 deletions
|
@ -463,7 +463,18 @@ class pgsql_native_moodle_database extends moodle_database {
|
|||
$info->auto_increment= false;
|
||||
$info->has_default = ($rawcolumn->atthasdef === 't');
|
||||
}
|
||||
$info->max_length = $matches[1];
|
||||
// Return number of decimals, not bytes here.
|
||||
if ($matches[1] >= 8) {
|
||||
$info->max_length = 18;
|
||||
} else if ($matches[1] >= 4) {
|
||||
$info->max_length = 9;
|
||||
} else if ($matches[1] >= 2) {
|
||||
$info->max_length = 4;
|
||||
} else if ($matches[1] >= 1) {
|
||||
$info->max_length = 2;
|
||||
} else {
|
||||
$info->max_length = 0;
|
||||
}
|
||||
$info->scale = null;
|
||||
$info->not_null = ($rawcolumn->attnotnull === 't');
|
||||
if ($info->has_default) {
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue