mirror of
https://github.com/MariaDB/server.git
synced 2025-01-17 20:42:30 +01:00
73a220aac3
* revert part of the db7edfe
that moved calculations from
fix_fields to val_str for Item_func_sysconst and descendants
* mark session state dependent functions in check_vcol_func_processor()
* re-run fix_fields for all such functions for every statement
* fix CURRENT_USER/CURRENT_ROLE not to use Name_resolution_context
(that is allocated on the stack in unpack_vcol_info_from_frm())
Note that NOW(), CURDATE(), etc use lazy initialization and do *not*
force fix_fields to be re-run. The rule is:
* lazy initialization is *not* allowed, if it changes metadata (so,
e.g. DAYNAME() cannot use it)
* lazy initialization is *preferrable* if it has side effects (e.g.
NOW() sets thd->time_zone_used=1, so it's better to do it when
the value of NOW is actually needed, not when NOW is simply prepared)
82 lines
2.5 KiB
Text
82 lines
2.5 KiB
Text
#
|
|
# DEFAULT clause with functions that depend on the current session state
|
|
#
|
|
|
|
source include/not_embedded.inc;
|
|
|
|
create database mysqltest1;
|
|
|
|
create user ''@localhost;
|
|
create user foo@localhost;
|
|
create role bar;
|
|
grant select on *.* to ''@localhost;
|
|
grant select,insert on *.* to foo@localhost;
|
|
grant select,insert on *.* to bar;
|
|
grant bar to ''@localhost;
|
|
|
|
create table t1 (n varchar(100),
|
|
u varchar(100) default user(),
|
|
cu varchar(100) default current_user(),
|
|
cr varchar(100) default current_role(),
|
|
d varchar(100) default database());
|
|
|
|
create definer=foo@localhost view mysqltest1.v1 as select * from t1;
|
|
create definer=bar view v2 as select * from t1;
|
|
create view v3 as select * from v2;
|
|
|
|
create definer=foo@localhost view mysqltest1.v4 as select default(n),default(u),default(cu),default(cr), default(d) from t1;
|
|
create definer=bar view v5 as select default(n),default(u),default(cu),default(cr), default(d) from t1;
|
|
create view v6 as select * from v5;
|
|
|
|
insert t1 (n) values ('t1');
|
|
insert mysqltest1.v1 (n) values ('v1');
|
|
insert v2 (n) values ('v2');
|
|
insert v3 (n) values ('v3');
|
|
|
|
select default(n),default(u),default(cu),default(cr), default(d) from t1 limit 1;
|
|
select * from mysqltest1.v4 limit 1;
|
|
select * from v5 limit 1;
|
|
select * from v6 limit 1;
|
|
|
|
connect (conn,localhost,conn,,mysqltest1);
|
|
set role bar;
|
|
insert test.t1 (n) values ('t1');
|
|
insert v1 (n) values ('v1');
|
|
insert test.v2 (n) values ('v2');
|
|
insert test.v3 (n) values ('v3');
|
|
|
|
select default(n),default(u),default(cu),default(cr), default(d) from test.t1 limit 1;
|
|
select * from v4 limit 1;
|
|
select * from test.v5 limit 1;
|
|
select * from test.v6 limit 1;
|
|
connection default;
|
|
disconnect conn;
|
|
|
|
select * from t1;
|
|
drop database mysqltest1;
|
|
drop view v2, v3, v5, v6;
|
|
drop table t1;
|
|
drop user ''@localhost;
|
|
drop user foo@localhost;
|
|
drop role bar;
|
|
|
|
create table t1 (a date,
|
|
mn varchar(100) default monthname(a),
|
|
dn varchar(100) default dayname(a),
|
|
df varchar(100) default date_format(a, "%a, %b"));
|
|
|
|
insert t1 (a) values ('2010-12-2');
|
|
set lc_time_names=de_DE;
|
|
insert t1 (a) values ('2010-12-2');
|
|
set lc_time_names=default;
|
|
|
|
select * from t1;
|
|
drop table t1;
|
|
|
|
create table t1 (a varchar(100) default @@sql_mode);
|
|
insert t1 () values ();
|
|
set sql_mode=ansi;
|
|
insert t1 () values ();
|
|
set sql_mode=default;
|
|
select * from t1;
|
|
drop table t1;
|