mirror of
https://github.com/MariaDB/server.git
synced 2025-07-30 16:24:05 +03:00
Merge remote-tracking branch 'origin/10.1' into 10.2
Also, adding 10.2 related changes for MDEV-22579
This commit is contained in:
@ -407,6 +407,26 @@ aaa
|
|||||||
Warnings:
|
Warnings:
|
||||||
Warning 1918 Encountered illegal value '\xF0\xF1\xF2\xF3\xF4\xF5\xF6\xF7' when converting to DOUBLE
|
Warning 1918 Encountered illegal value '\xF0\xF1\xF2\xF3\xF4\xF5\xF6\xF7' when converting to DOUBLE
|
||||||
#
|
#
|
||||||
|
# MDEV-22579 No error when inserting DEFAULT(non_virtual_column) into a virtual column
|
||||||
|
#
|
||||||
|
SET sql_mode=STRICT_ALL_TABLES;
|
||||||
|
CREATE OR REPLACE TABLE t1 (
|
||||||
|
a INT NOT NULL DEFAULT 10,
|
||||||
|
b INT AS (a+1) VIRTUAL
|
||||||
|
) ENGINE=MyISAM;
|
||||||
|
INSERT INTO t1 (b) VALUES (10);
|
||||||
|
ERROR HY000: The value specified for generated column 'b' in table 't1' has been ignored
|
||||||
|
INSERT INTO t1 (b) VALUES (DEFAULT(a));
|
||||||
|
ERROR HY000: The value specified for generated column 'b' in table 't1' has been ignored
|
||||||
|
INSERT INTO t1 (b) VALUES (DEFAULT);
|
||||||
|
INSERT INTO t1 VALUES (10,10);
|
||||||
|
ERROR HY000: The value specified for generated column 'b' in table 't1' has been ignored
|
||||||
|
INSERT INTO t1 VALUES (10,DEFAULT(a));
|
||||||
|
ERROR HY000: The value specified for generated column 'b' in table 't1' has been ignored
|
||||||
|
INSERT INTO t1 VALUES (10, DEFAULT);
|
||||||
|
DROP TABLE t1;
|
||||||
|
SET sql_mode=DEFAULT;
|
||||||
|
#
|
||||||
# End of 10.1 tests
|
# End of 10.1 tests
|
||||||
#
|
#
|
||||||
#
|
#
|
||||||
@ -461,5 +481,37 @@ Warning 1264 Out of range value for column 'vi' at row 1
|
|||||||
DROP TABLE t1;
|
DROP TABLE t1;
|
||||||
SET @sql_mode=@old_sql_mode;
|
SET @sql_mode=@old_sql_mode;
|
||||||
#
|
#
|
||||||
|
# MDEV-22579 No error when inserting DEFAULT(non_virtual_column) into a virtual column
|
||||||
|
# 10.2+ specific part
|
||||||
|
#
|
||||||
|
SET sql_mode=STRICT_ALL_TABLES;
|
||||||
|
CREATE OR REPLACE TABLE t1 (
|
||||||
|
a INT NOT NULL DEFAULT 10,
|
||||||
|
b INT AS (a+1) VIRTUAL
|
||||||
|
) ENGINE=MyISAM;
|
||||||
|
EXECUTE IMMEDIATE 'INSERT INTO t1 (b) VALUES(?)' USING DEFAULT;
|
||||||
|
EXECUTE IMMEDIATE 'INSERT INTO t1 (b) VALUES(?)' USING IGNORE;
|
||||||
|
INSERT INTO t1 (b) VALUES (DEFAULT);
|
||||||
|
INSERT INTO t1 (b) VALUES (IGNORE);
|
||||||
|
SELECT * FROM t1;
|
||||||
|
a b
|
||||||
|
10 11
|
||||||
|
10 11
|
||||||
|
10 11
|
||||||
|
10 11
|
||||||
|
DELETE FROM t1;
|
||||||
|
EXECUTE IMMEDIATE 'INSERT INTO t1 VALUES(10,?)' USING DEFAULT;
|
||||||
|
EXECUTE IMMEDIATE 'INSERT INTO t1 VALUES(11,?)' USING IGNORE;
|
||||||
|
INSERT INTO t1 VALUES (12,DEFAULT);
|
||||||
|
INSERT INTO t1 VALUES (13,IGNORE);
|
||||||
|
SELECT * FROM t1;
|
||||||
|
a b
|
||||||
|
10 11
|
||||||
|
11 12
|
||||||
|
12 13
|
||||||
|
13 14
|
||||||
|
DROP TABLE t1;
|
||||||
|
SET sql_mode=DEFAULT;
|
||||||
|
#
|
||||||
# End of 10.2 tests
|
# End of 10.2 tests
|
||||||
#
|
#
|
||||||
|
@ -368,6 +368,36 @@ SELECT COLUMN_GET(@aaa, 'price' AS DECIMAL) aaa;
|
|||||||
SELECT COLUMN_GET(@aaa, 'price' AS INT) aaa;
|
SELECT COLUMN_GET(@aaa, 'price' AS INT) aaa;
|
||||||
SELECT COLUMN_GET(@aaa, 'price' AS DOUBLE) aaa;
|
SELECT COLUMN_GET(@aaa, 'price' AS DOUBLE) aaa;
|
||||||
|
|
||||||
|
|
||||||
|
--echo #
|
||||||
|
--echo # MDEV-22579 No error when inserting DEFAULT(non_virtual_column) into a virtual column
|
||||||
|
--echo #
|
||||||
|
|
||||||
|
SET sql_mode=STRICT_ALL_TABLES;
|
||||||
|
CREATE OR REPLACE TABLE t1 (
|
||||||
|
a INT NOT NULL DEFAULT 10,
|
||||||
|
b INT AS (a+1) VIRTUAL
|
||||||
|
) ENGINE=MyISAM;
|
||||||
|
|
||||||
|
# Testing with a column list
|
||||||
|
|
||||||
|
--error ER_WARNING_NON_DEFAULT_VALUE_FOR_GENERATED_COLUMN
|
||||||
|
INSERT INTO t1 (b) VALUES (10);
|
||||||
|
--error ER_WARNING_NON_DEFAULT_VALUE_FOR_GENERATED_COLUMN
|
||||||
|
INSERT INTO t1 (b) VALUES (DEFAULT(a));
|
||||||
|
INSERT INTO t1 (b) VALUES (DEFAULT);
|
||||||
|
|
||||||
|
# Testing without a column list
|
||||||
|
--error ER_WARNING_NON_DEFAULT_VALUE_FOR_GENERATED_COLUMN
|
||||||
|
INSERT INTO t1 VALUES (10,10);
|
||||||
|
--error ER_WARNING_NON_DEFAULT_VALUE_FOR_GENERATED_COLUMN
|
||||||
|
INSERT INTO t1 VALUES (10,DEFAULT(a));
|
||||||
|
INSERT INTO t1 VALUES (10, DEFAULT);
|
||||||
|
|
||||||
|
DROP TABLE t1;
|
||||||
|
SET sql_mode=DEFAULT;
|
||||||
|
|
||||||
|
|
||||||
--echo #
|
--echo #
|
||||||
--echo # End of 10.1 tests
|
--echo # End of 10.1 tests
|
||||||
--echo #
|
--echo #
|
||||||
@ -425,6 +455,37 @@ REPLACE INTO t1 (pk,i) VALUES (1,2);
|
|||||||
DROP TABLE t1;
|
DROP TABLE t1;
|
||||||
SET @sql_mode=@old_sql_mode;
|
SET @sql_mode=@old_sql_mode;
|
||||||
|
|
||||||
|
--echo #
|
||||||
|
--echo # MDEV-22579 No error when inserting DEFAULT(non_virtual_column) into a virtual column
|
||||||
|
--echo # 10.2+ specific part
|
||||||
|
--echo #
|
||||||
|
|
||||||
|
SET sql_mode=STRICT_ALL_TABLES;
|
||||||
|
CREATE OR REPLACE TABLE t1 (
|
||||||
|
a INT NOT NULL DEFAULT 10,
|
||||||
|
b INT AS (a+1) VIRTUAL
|
||||||
|
) ENGINE=MyISAM;
|
||||||
|
|
||||||
|
# Testing with column list
|
||||||
|
|
||||||
|
EXECUTE IMMEDIATE 'INSERT INTO t1 (b) VALUES(?)' USING DEFAULT;
|
||||||
|
EXECUTE IMMEDIATE 'INSERT INTO t1 (b) VALUES(?)' USING IGNORE;
|
||||||
|
INSERT INTO t1 (b) VALUES (DEFAULT);
|
||||||
|
INSERT INTO t1 (b) VALUES (IGNORE);
|
||||||
|
SELECT * FROM t1;
|
||||||
|
DELETE FROM t1;
|
||||||
|
|
||||||
|
# Testing without column list
|
||||||
|
|
||||||
|
EXECUTE IMMEDIATE 'INSERT INTO t1 VALUES(10,?)' USING DEFAULT;
|
||||||
|
EXECUTE IMMEDIATE 'INSERT INTO t1 VALUES(11,?)' USING IGNORE;
|
||||||
|
INSERT INTO t1 VALUES (12,DEFAULT);
|
||||||
|
INSERT INTO t1 VALUES (13,IGNORE);
|
||||||
|
SELECT * FROM t1;
|
||||||
|
|
||||||
|
DROP TABLE t1;
|
||||||
|
SET sql_mode=DEFAULT;
|
||||||
|
|
||||||
--echo #
|
--echo #
|
||||||
--echo # End of 10.2 tests
|
--echo # End of 10.2 tests
|
||||||
--echo #
|
--echo #
|
||||||
|
28
sql/item.h
28
sql/item.h
@ -1301,6 +1301,13 @@ public:
|
|||||||
a constant expression. Used in the optimizer to propagate basic constants.
|
a constant expression. Used in the optimizer to propagate basic constants.
|
||||||
*/
|
*/
|
||||||
virtual bool basic_const_item() const { return 0; }
|
virtual bool basic_const_item() const { return 0; }
|
||||||
|
/*
|
||||||
|
Determines if the expression is allowed as
|
||||||
|
a virtual column assignment source:
|
||||||
|
INSERT INTO t1 (vcol) VALUES (10) -> error
|
||||||
|
INSERT INTO t1 (vcol) VALUES (NULL) -> ok
|
||||||
|
*/
|
||||||
|
virtual bool vcol_assignment_allowed_value() const { return false; }
|
||||||
/* cloning of constant items (0 if it is not const) */
|
/* cloning of constant items (0 if it is not const) */
|
||||||
virtual Item *clone_item(THD *thd) { return 0; }
|
virtual Item *clone_item(THD *thd) { return 0; }
|
||||||
virtual Item* build_clone(THD *thd, MEM_ROOT *mem_root) { return get_copy(thd, mem_root); }
|
virtual Item* build_clone(THD *thd, MEM_ROOT *mem_root) { return get_copy(thd, mem_root); }
|
||||||
@ -2900,6 +2907,7 @@ public:
|
|||||||
collation.set(cs, DERIVATION_IGNORABLE, MY_REPERTOIRE_ASCII);
|
collation.set(cs, DERIVATION_IGNORABLE, MY_REPERTOIRE_ASCII);
|
||||||
}
|
}
|
||||||
enum Type type() const { return NULL_ITEM; }
|
enum Type type() const { return NULL_ITEM; }
|
||||||
|
bool vcol_assignment_allowed_value() const { return true; }
|
||||||
bool eq(const Item *item, bool binary_cmp) const { return null_eq(item); }
|
bool eq(const Item *item, bool binary_cmp) const { return null_eq(item); }
|
||||||
double val_real();
|
double val_real();
|
||||||
longlong val_int();
|
longlong val_int();
|
||||||
@ -3082,6 +3090,25 @@ public:
|
|||||||
*/
|
*/
|
||||||
enum enum_indicator_type indicator;
|
enum enum_indicator_type indicator;
|
||||||
|
|
||||||
|
bool vcol_assignment_allowed_value() const
|
||||||
|
{
|
||||||
|
switch (state) {
|
||||||
|
case NULL_VALUE:
|
||||||
|
case DEFAULT_VALUE:
|
||||||
|
case IGNORE_VALUE:
|
||||||
|
return true;
|
||||||
|
case NO_VALUE:
|
||||||
|
case INT_VALUE:
|
||||||
|
case REAL_VALUE:
|
||||||
|
case STRING_VALUE:
|
||||||
|
case TIME_VALUE:
|
||||||
|
case LONG_DATA_VALUE:
|
||||||
|
case DECIMAL_VALUE:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
A buffer for string and long data values. Historically all allocated
|
A buffer for string and long data values. Historically all allocated
|
||||||
values returned from val_str() were treated as eligible to
|
values returned from val_str() were treated as eligible to
|
||||||
@ -5372,6 +5399,7 @@ public:
|
|||||||
(const char *)NULL),
|
(const char *)NULL),
|
||||||
arg(NULL),cached_field(NULL) {}
|
arg(NULL),cached_field(NULL) {}
|
||||||
enum Type type() const { return DEFAULT_VALUE_ITEM; }
|
enum Type type() const { return DEFAULT_VALUE_ITEM; }
|
||||||
|
bool vcol_assignment_allowed_value() const { return arg == NULL; }
|
||||||
bool eq(const Item *item, bool binary_cmp) const;
|
bool eq(const Item *item, bool binary_cmp) const;
|
||||||
bool fix_fields(THD *, Item **);
|
bool fix_fields(THD *, Item **);
|
||||||
void cleanup();
|
void cleanup();
|
||||||
|
@ -8042,10 +8042,8 @@ fill_record(THD *thd, TABLE *table_arg, List<Item> &fields, List<Item> &values,
|
|||||||
if (table->next_number_field &&
|
if (table->next_number_field &&
|
||||||
rfield->field_index == table->next_number_field->field_index)
|
rfield->field_index == table->next_number_field->field_index)
|
||||||
table->auto_increment_field_not_null= TRUE;
|
table->auto_increment_field_not_null= TRUE;
|
||||||
Item::Type type= value->type();
|
|
||||||
if (rfield->vcol_info &&
|
if (rfield->vcol_info &&
|
||||||
type != Item::DEFAULT_VALUE_ITEM &&
|
!value->vcol_assignment_allowed_value() &&
|
||||||
type != Item::NULL_ITEM &&
|
|
||||||
table->s->table_category != TABLE_CATEGORY_TEMPORARY)
|
table->s->table_category != TABLE_CATEGORY_TEMPORARY)
|
||||||
{
|
{
|
||||||
push_warning_printf(thd, Sql_condition::WARN_LEVEL_WARN,
|
push_warning_printf(thd, Sql_condition::WARN_LEVEL_WARN,
|
||||||
@ -8289,11 +8287,8 @@ fill_record(THD *thd, TABLE *table, Field **ptr, List<Item> &values,
|
|||||||
value=v++;
|
value=v++;
|
||||||
if (field->field_index == autoinc_index)
|
if (field->field_index == autoinc_index)
|
||||||
table->auto_increment_field_not_null= TRUE;
|
table->auto_increment_field_not_null= TRUE;
|
||||||
if (field->vcol_info)
|
if (field->vcol_info &&
|
||||||
{
|
!value->vcol_assignment_allowed_value() &&
|
||||||
Item::Type type= value->type();
|
|
||||||
if (type != Item::DEFAULT_VALUE_ITEM &&
|
|
||||||
type != Item::NULL_ITEM &&
|
|
||||||
table->s->table_category != TABLE_CATEGORY_TEMPORARY)
|
table->s->table_category != TABLE_CATEGORY_TEMPORARY)
|
||||||
{
|
{
|
||||||
push_warning_printf(thd, Sql_condition::WARN_LEVEL_WARN,
|
push_warning_printf(thd, Sql_condition::WARN_LEVEL_WARN,
|
||||||
@ -8301,7 +8296,6 @@ fill_record(THD *thd, TABLE *table, Field **ptr, List<Item> &values,
|
|||||||
ER_THD(thd, ER_WARNING_NON_DEFAULT_VALUE_FOR_VIRTUAL_COLUMN),
|
ER_THD(thd, ER_WARNING_NON_DEFAULT_VALUE_FOR_VIRTUAL_COLUMN),
|
||||||
field->field_name, table->s->table_name.str);
|
field->field_name, table->s->table_name.str);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
if (use_value)
|
if (use_value)
|
||||||
value->save_val(field);
|
value->save_val(field);
|
||||||
|
Reference in New Issue
Block a user