Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
M
MariaDB
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
nexedi
MariaDB
Commits
a85ecdb6
Commit
a85ecdb6
authored
May 07, 2005
by
gbichot@quadita2.mysql.com
Browse files
Options
Browse Files
Download
Plain Diff
Merge gbichot@bk-internal.mysql.com:/home/bk/mysql-5.0
into quadita2.mysql.com:/nfstmp1/guilhem/mysql-5.0-4ita
parents
b4dcd8f4
ea1bc59e
Changes
4
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
96 additions
and
9 deletions
+96
-9
mysql-test/r/rpl_sp.result
mysql-test/r/rpl_sp.result
+29
-6
mysql-test/t/rpl_sp.test
mysql-test/t/rpl_sp.test
+34
-2
sql/sql_trigger.cc
sql/sql_trigger.cc
+25
-1
sql/sql_trigger.h
sql/sql_trigger.h
+8
-0
No files found.
mysql-test/r/rpl_sp.result
View file @
a85ecdb6
...
@@ -158,9 +158,6 @@ a
...
@@ -158,9 +158,6 @@ a
select * from t2;
select * from t2;
a
a
3
3
select if(compte<>3,"this is broken but documented","this unexpectedly works?") from (select count(*) as compte from t2) as aggreg;
if(compte<>3,"this is broken but documented","this unexpectedly works?")
this is broken but documented
select * from mysql.proc where name="foo4" and db='mysqltest1';
select * from mysql.proc where name="foo4" and db='mysqltest1';
db name type specific_name language sql_data_access is_deterministic security_type param_list returns body definer created modified sql_mode comment
db name type specific_name language sql_data_access is_deterministic security_type param_list returns body definer created modified sql_mode comment
mysqltest1 foo4 PROCEDURE foo4 SQL CONTAINS_SQL YES INVOKER begin
mysqltest1 foo4 PROCEDURE foo4 SQL CONTAINS_SQL YES INVOKER begin
...
@@ -197,9 +194,6 @@ a
...
@@ -197,9 +194,6 @@ a
select * from t1;
select * from t1;
a
a
21
21
select if(compte<>1,"this is broken but documented","this unexpectedly works?") from (select count(*) as compte from t1 where a=20) as aggreg;
if(compte<>1,"this is broken but documented","this unexpectedly works?")
this is broken but documented
select * from t2;
select * from t2;
a
a
23
23
...
@@ -230,6 +224,35 @@ db name type specific_name language sql_data_access is_deterministic security_ty
...
@@ -230,6 +224,35 @@ db name type specific_name language sql_data_access is_deterministic security_ty
mysqltest1 fn1 FUNCTION fn1 SQL CONTAINS_SQL YES DEFINER int(11) begin
mysqltest1 fn1 FUNCTION fn1 SQL CONTAINS_SQL YES DEFINER int(11) begin
return unix_timestamp();
return unix_timestamp();
end @ # #
end @ # #
create trigger trg before insert on t1 for each row set new.a= 10;
ERROR 42000: Access denied; you need the SUPER privilege for this operation
flush logs;
delete from t1;
create trigger trg before insert on t1 for each row set new.a= 10;
insert into t1 values (1);
select * from t1;
a
10
select * from t1;
a
10
delete from t1;
drop trigger t1.trg;
insert into t1 values (1);
select * from t1;
a
1
show binlog events in 'master-bin.000002' from 98;
Log_name Pos Event_type Server_id End_log_pos Info
master-bin.000002 # Query 1 # use `mysqltest1`; delete from t1
master-bin.000002 # Query 1 # use `mysqltest1`; create trigger trg before insert on t1 for each row set new.a= 10
master-bin.000002 # Query 1 # use `mysqltest1`; insert into t1 values (1)
master-bin.000002 # Query 1 # use `mysqltest1`; delete from t1
master-bin.000002 # Query 1 # use `mysqltest1`; drop trigger t1.trg
master-bin.000002 # Query 1 # use `mysqltest1`; insert into t1 values (1)
select * from t1;
a
1
drop function fn1;
drop function fn1;
drop database mysqltest1;
drop database mysqltest1;
drop user "zedjzlcsjhd"@127.0.0.1;
drop user "zedjzlcsjhd"@127.0.0.1;
mysql-test/t/rpl_sp.test
View file @
a85ecdb6
...
@@ -157,7 +157,6 @@ select * from t2;
...
@@ -157,7 +157,6 @@ select * from t2;
sync_slave_with_master
;
sync_slave_with_master
;
select
*
from
t1
;
select
*
from
t1
;
select
*
from
t2
;
select
*
from
t2
;
select
if
(
compte
<>
3
,
"this is broken but documented"
,
"this unexpectedly works?"
)
from
(
select
count
(
*
)
as
compte
from
t2
)
as
aggreg
;
# Test of DROP PROCEDURE
# Test of DROP PROCEDURE
...
@@ -194,7 +193,6 @@ select * from t1;
...
@@ -194,7 +193,6 @@ select * from t1;
select
*
from
t2
;
select
*
from
t2
;
sync_slave_with_master
;
sync_slave_with_master
;
select
*
from
t1
;
select
*
from
t1
;
select
if
(
compte
<>
1
,
"this is broken but documented"
,
"this unexpectedly works?"
)
from
(
select
count
(
*
)
as
compte
from
t1
where
a
=
20
)
as
aggreg
;
select
*
from
t2
;
select
*
from
t2
;
connection
master
;
connection
master
;
...
@@ -225,6 +223,40 @@ select * from t1;
...
@@ -225,6 +223,40 @@ select * from t1;
--
replace_column
13
# 14 #
--
replace_column
13
# 14 #
select
*
from
mysql
.
proc
where
db
=
'mysqltest1'
;
select
*
from
mysql
.
proc
where
db
=
'mysqltest1'
;
# And now triggers
connection
con1
;
--
error
1227
;
create
trigger
trg
before
insert
on
t1
for
each
row
set
new
.
a
=
10
;
connection
master
;
# fn1() above uses timestamps, so in !ps-protocol, the timezone will be
# binlogged, but in --ps-protocol it will not be (BUG#9359) so
# the binlog offsets get shifted which spoils SHOW BINLOG EVENTS.
# To be immune, we take a new binlog.
flush
logs
;
delete
from
t1
;
# TODO: when triggers can contain an update, test that this update
# does not go into binlog.
# I'm not setting user vars in the trigger, because replication of user vars
# would take care of propagating the user var's value to slave, so even if
# the trigger was not executed on slave it would not be discovered.
create
trigger
trg
before
insert
on
t1
for
each
row
set
new
.
a
=
10
;
insert
into
t1
values
(
1
);
select
*
from
t1
;
sync_slave_with_master
;
select
*
from
t1
;
connection
master
;
delete
from
t1
;
drop
trigger
t1
.
trg
;
insert
into
t1
values
(
1
);
select
*
from
t1
;
--
replace_column
2
# 5 #
show
binlog
events
in
'master-bin.000002'
from
98
;
sync_slave_with_master
;
select
*
from
t1
;
# Clean up
# Clean up
connection
master
;
connection
master
;
...
...
sql/sql_trigger.cc
View file @
a85ecdb6
...
@@ -98,6 +98,21 @@ bool mysql_create_or_drop_trigger(THD *thd, TABLE_LIST *tables, bool create)
...
@@ -98,6 +98,21 @@ bool mysql_create_or_drop_trigger(THD *thd, TABLE_LIST *tables, bool create)
if
(
wait_if_global_read_lock
(
thd
,
0
,
0
))
if
(
wait_if_global_read_lock
(
thd
,
0
,
0
))
DBUG_RETURN
(
TRUE
);
DBUG_RETURN
(
TRUE
);
/*
There is no DETERMINISTIC clause for triggers, so can't check it.
But a trigger can in theory be used to do nasty things (if it supported
DROP for example) so we do the check for privileges. For now there is
already a stronger test above (see start of the function); but when this
stronger test will be removed, the test below will hold.
*/
if
(
!
trust_routine_creators
&&
mysql_bin_log
.
is_open
()
&&
!
(
thd
->
master_access
&
SUPER_ACL
))
{
my_message
(
ER_BINLOG_CREATE_ROUTINE_NEED_SUPER
,
ER
(
ER_BINLOG_CREATE_ROUTINE_NEED_SUPER
),
MYF
(
0
));
DBUG_RETURN
(
TRUE
);
}
VOID
(
pthread_mutex_lock
(
&
LOCK_open
));
VOID
(
pthread_mutex_lock
(
&
LOCK_open
));
result
=
(
create
?
result
=
(
create
?
table
->
triggers
->
create_trigger
(
thd
,
tables
)
:
table
->
triggers
->
create_trigger
(
thd
,
tables
)
:
...
@@ -109,7 +124,16 @@ bool mysql_create_or_drop_trigger(THD *thd, TABLE_LIST *tables, bool create)
...
@@ -109,7 +124,16 @@ bool mysql_create_or_drop_trigger(THD *thd, TABLE_LIST *tables, bool create)
start_waiting_global_read_lock
(
thd
);
start_waiting_global_read_lock
(
thd
);
if
(
!
result
)
if
(
!
result
)
{
if
(
mysql_bin_log
.
is_open
())
{
thd
->
clear_error
();
/* Such a statement can always go directly to binlog, no trans cache */
Query_log_event
qinfo
(
thd
,
thd
->
query
,
thd
->
query_length
,
0
,
FALSE
);
mysql_bin_log
.
write
(
&
qinfo
);
}
send_ok
(
thd
);
send_ok
(
thd
);
}
DBUG_RETURN
(
result
);
DBUG_RETURN
(
result
);
}
}
...
...
sql/sql_trigger.h
View file @
a85ecdb6
...
@@ -52,7 +52,15 @@ class Table_triggers_list: public Sql_alloc
...
@@ -52,7 +52,15 @@ class Table_triggers_list: public Sql_alloc
FIXME: We should juggle with security context here (because trigger
FIXME: We should juggle with security context here (because trigger
should be invoked with creator rights).
should be invoked with creator rights).
*/
*/
/*
Guilhem puts code to disable binlogging, as in SP/functions, even
though currently triggers can't do updates. When triggers can do
updates, someone should add such a trigger to rpl_sp.test to verify
that the update does NOT go into binlog.
*/
tmp_disable_binlog
(
thd
);
res
=
bodies
[
event
][
time_type
]
->
execute_function
(
thd
,
0
,
0
,
0
);
res
=
bodies
[
event
][
time_type
]
->
execute_function
(
thd
,
0
,
0
,
0
);
reenable_binlog
(
thd
);
#ifndef EMBEDDED_LIBRARY
#ifndef EMBEDDED_LIBRARY
thd
->
net
.
no_send_ok
=
nsok
;
thd
->
net
.
no_send_ok
=
nsok
;
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment