mirror of
https://github.com/MariaDB/server.git
synced 2025-12-09 08:01:34 +03:00
Bug#35335 funcs_1: Some tests fail within load_file during
pushbuild runs
Solution: 1. Move files with input data used in load_file,
load data etc.
from suite/funcs_1/<whatever>
to std_data
2. Use for testsuite funcs_1 the server option
--secure-file-priv=<MYSQLTEST_VARDIR>
3. Outfiles have to be stored under MYSQLTEST_VARDIR
+ changes according to WL#4304 Cleanup in funcs_1 tests
- backport of fixes/improvements made in 5.1 to 5.0
The differences between scripts in 5.0 and 5.1 cause
much additional and annoying work during any upmerge.
- replace error numbers with names
- improved comments
- improved formatting
- Unify storage engine names so that result files for
storage engine variants do not differ (some tests)
- remove a script no more used (tests are done in other scripts)
BitKeeper/deleted/.del-triggers_master.test:
Delete: mysql-test/suite/funcs_1/triggers/triggers_master.test
mysql-test/std_data/funcs_1/innodb_tb1.txt:
Rename: mysql-test/suite/funcs_1/data/innodb_tb1.txt -> mysql-test/std_data/funcs_1/innodb_tb1.txt
mysql-test/std_data/funcs_1/innodb_tb2.txt:
Rename: mysql-test/suite/funcs_1/data/innodb_tb2.txt -> mysql-test/std_data/funcs_1/innodb_tb2.txt
mysql-test/std_data/funcs_1/innodb_tb3.txt:
Rename: mysql-test/suite/funcs_1/data/innodb_tb3.txt -> mysql-test/std_data/funcs_1/innodb_tb3.txt
mysql-test/std_data/funcs_1/innodb_tb4.txt:
Rename: mysql-test/suite/funcs_1/data/innodb_tb4.txt -> mysql-test/std_data/funcs_1/innodb_tb4.txt
mysql-test/std_data/funcs_1/memory_tb1.txt:
Rename: mysql-test/suite/funcs_1/data/memory_tb1.txt -> mysql-test/std_data/funcs_1/memory_tb1.txt
mysql-test/std_data/funcs_1/memory_tb2.txt:
Rename: mysql-test/suite/funcs_1/data/memory_tb2.txt -> mysql-test/std_data/funcs_1/memory_tb2.txt
mysql-test/std_data/funcs_1/memory_tb3.txt:
Rename: mysql-test/suite/funcs_1/data/memory_tb3.txt -> mysql-test/std_data/funcs_1/memory_tb3.txt
mysql-test/std_data/funcs_1/memory_tb4.txt:
Rename: mysql-test/suite/funcs_1/data/memory_tb4.txt -> mysql-test/std_data/funcs_1/memory_tb4.txt
mysql-test/std_data/funcs_1/myisam_tb1.txt:
Rename: mysql-test/suite/funcs_1/data/myisam_tb1.txt -> mysql-test/std_data/funcs_1/myisam_tb1.txt
mysql-test/std_data/funcs_1/myisam_tb2.txt:
Rename: mysql-test/suite/funcs_1/data/myisam_tb2.txt -> mysql-test/std_data/funcs_1/myisam_tb2.txt
mysql-test/std_data/funcs_1/myisam_tb3.txt:
Rename: mysql-test/suite/funcs_1/data/myisam_tb3.txt -> mysql-test/std_data/funcs_1/myisam_tb3.txt
mysql-test/std_data/funcs_1/myisam_tb4.txt:
Rename: mysql-test/suite/funcs_1/data/myisam_tb4.txt -> mysql-test/std_data/funcs_1/myisam_tb4.txt
mysql-test/std_data/funcs_1/t3.txt:
Rename: mysql-test/suite/funcs_1/data/t3.txt -> mysql-test/std_data/funcs_1/t3.txt
mysql-test/std_data/funcs_1/t4.txt:
Rename: mysql-test/suite/funcs_1/data/t4.txt -> mysql-test/std_data/funcs_1/t4.txt
mysql-test/std_data/funcs_1/t7.txt:
Rename: mysql-test/suite/funcs_1/data/t7.txt -> mysql-test/std_data/funcs_1/t7.txt
mysql-test/std_data/funcs_1/t9.txt:
Rename: mysql-test/suite/funcs_1/data/t9.txt -> mysql-test/std_data/funcs_1/t9.txt
mysql-test/Makefile.am:
Introduce installation of funcs_1 files in std_data.
mysql-test/mysql-test-run.pl:
The tests within funcs_1 need a server started with
--secure-file-priv=<MYSQLTEST_VARDIR>
like the main regression tests.
mysql-test/suite/funcs_1/README.txt:
Extended description
mysql-test/suite/funcs_1/datadict/datadict_bug_12777.inc:
Cleanup
mysql-test/suite/funcs_1/datadict/datadict_load.inc:
Cleanup
mysql-test/suite/funcs_1/include/innodb_tb1.inc:
Adjustment to new storage place of infile.
mysql-test/suite/funcs_1/include/innodb_tb2.inc:
Adjustment to new storage place of infile.
mysql-test/suite/funcs_1/include/innodb_tb3.inc:
Adjustment to new storage place of infile.
mysql-test/suite/funcs_1/include/innodb_tb4.inc:
Adjustment to new storage place of infile.
mysql-test/suite/funcs_1/include/memory_tb1.inc:
Adjustment to new storage place of infile.
mysql-test/suite/funcs_1/include/memory_tb2.inc:
Adjustment to new storage place of infile.
mysql-test/suite/funcs_1/include/memory_tb3.inc:
Adjustment to new storage place of infile.
mysql-test/suite/funcs_1/include/memory_tb4.inc:
Adjustment to new storage place of infile.
mysql-test/suite/funcs_1/include/myisam_tb1.inc:
Adjustment to new storage place of infile.
mysql-test/suite/funcs_1/include/myisam_tb2.inc:
Adjustment to new storage place of infile.
mysql-test/suite/funcs_1/include/myisam_tb3.inc:
Adjustment to new storage place of infile.
mysql-test/suite/funcs_1/include/myisam_tb4.inc:
Adjustment to new storage place of infile.
mysql-test/suite/funcs_1/include/sp_tb.inc:
Adjustment to new storage place of infile.
mysql-test/suite/funcs_1/r/innodb_func_view.result:
Updated results
mysql-test/suite/funcs_1/r/innodb_storedproc_02.result:
Updated results
mysql-test/suite/funcs_1/r/innodb_storedproc_03.result:
Updated results
mysql-test/suite/funcs_1/r/innodb_storedproc_06.result:
Updated results
mysql-test/suite/funcs_1/r/innodb_storedproc_07.result:
Updated results
mysql-test/suite/funcs_1/r/innodb_storedproc_08.result:
Updated results
mysql-test/suite/funcs_1/r/innodb_storedproc_10.result:
Updated results
mysql-test/suite/funcs_1/r/innodb_trig_0102.result:
Updated results
mysql-test/suite/funcs_1/r/innodb_trig_03.result:
Updated results
mysql-test/suite/funcs_1/r/innodb_trig_0407.result:
Updated results
mysql-test/suite/funcs_1/r/innodb_trig_08.result:
Updated results
mysql-test/suite/funcs_1/r/innodb_trig_09.result:
Updated results
mysql-test/suite/funcs_1/r/innodb_trig_1011ext.result:
Updated results
mysql-test/suite/funcs_1/r/innodb_trig_frkey.result:
Updated results
mysql-test/suite/funcs_1/r/innodb_views.result:
Updated results
mysql-test/suite/funcs_1/r/is_columns_innodb.result:
Updated results
mysql-test/suite/funcs_1/r/is_columns_memory.result:
Updated results
mysql-test/suite/funcs_1/r/is_columns_myisam.result:
Updated results
mysql-test/suite/funcs_1/r/is_columns_ndb.result:
Updated results
mysql-test/suite/funcs_1/r/is_tables_innodb.result:
Updated results
mysql-test/suite/funcs_1/r/is_tables_memory.result:
Updated results
mysql-test/suite/funcs_1/r/is_tables_myisam.result:
Updated results
mysql-test/suite/funcs_1/r/is_tables_ndb.result:
Updated results
mysql-test/suite/funcs_1/r/memory_func_view.result:
Updated results
mysql-test/suite/funcs_1/r/memory_storedproc_02.result:
Updated results
mysql-test/suite/funcs_1/r/memory_storedproc_03.result:
Updated results
mysql-test/suite/funcs_1/r/memory_storedproc_06.result:
Updated results
mysql-test/suite/funcs_1/r/memory_storedproc_07.result:
Updated results
mysql-test/suite/funcs_1/r/memory_storedproc_08.result:
Updated results
mysql-test/suite/funcs_1/r/memory_storedproc_10.result:
Updated results
mysql-test/suite/funcs_1/r/memory_trig_0102.result:
Updated results
mysql-test/suite/funcs_1/r/memory_trig_03.result:
Updated results
mysql-test/suite/funcs_1/r/memory_trig_0407.result:
Updated results
mysql-test/suite/funcs_1/r/memory_trig_08.result:
Updated results
mysql-test/suite/funcs_1/r/memory_trig_09.result:
Updated results
mysql-test/suite/funcs_1/r/memory_trig_1011ext.result:
Updated results
mysql-test/suite/funcs_1/r/memory_views.result:
Updated results
mysql-test/suite/funcs_1/r/myisam_func_view.result:
Updated results
mysql-test/suite/funcs_1/r/myisam_storedproc_02.result:
Updated results
mysql-test/suite/funcs_1/r/myisam_storedproc_03.result:
Updated results
mysql-test/suite/funcs_1/r/myisam_storedproc_06.result:
Updated results
mysql-test/suite/funcs_1/r/myisam_storedproc_07.result:
Updated results
mysql-test/suite/funcs_1/r/myisam_storedproc_08.result:
Updated results
mysql-test/suite/funcs_1/r/myisam_storedproc_10.result:
Updated results
mysql-test/suite/funcs_1/r/myisam_trig_0102.result:
Updated results
mysql-test/suite/funcs_1/r/myisam_trig_03.result:
Updated results
mysql-test/suite/funcs_1/r/myisam_trig_0407.result:
Updated results
mysql-test/suite/funcs_1/r/myisam_trig_08.result:
Updated results
mysql-test/suite/funcs_1/r/myisam_trig_09.result:
Updated results
mysql-test/suite/funcs_1/r/myisam_trig_1011ext.result:
Updated results
mysql-test/suite/funcs_1/r/myisam_views.result:
Updated results
mysql-test/suite/funcs_1/storedproc/cleanup_sp_tb.inc:
"--echo" instead of SQL command.
mysql-test/suite/funcs_1/storedproc/load_sp_tb.inc:
Adjustment to new storage place of infile
+ correct formatting.
mysql-test/suite/funcs_1/storedproc/storedproc_02.inc:
Backport from 5.1 + correct formatting.
mysql-test/suite/funcs_1/storedproc/storedproc_03.inc:
Minor improvements + correct formatting.
mysql-test/suite/funcs_1/storedproc/storedproc_06.inc:
Backport from 5.1 + correct formatting
mysql-test/suite/funcs_1/storedproc/storedproc_10.inc:
Backport from 5.1. + correct formatting
mysql-test/suite/funcs_1/t/innodb_trig_0407.test:
Cleanup
mysql-test/suite/funcs_1/t/is_basics_mixed.test:
Adjustment to new storage place of outfile.
mysql-test/suite/funcs_1/t/memory_storedproc_02.test:
Cleanup
mysql-test/suite/funcs_1/t/memory_storedproc_03.test:
Cleanup
mysql-test/suite/funcs_1/t/memory_storedproc_06.test:
Cleanup
mysql-test/suite/funcs_1/t/memory_storedproc_07.test:
Cleanup
mysql-test/suite/funcs_1/t/memory_storedproc_08.test:
Cleanup
mysql-test/suite/funcs_1/t/memory_storedproc_10.test:
Cleanup
mysql-test/suite/funcs_1/t/myisam_storedproc_02.test:
Cleanup
mysql-test/suite/funcs_1/t/myisam_storedproc_03.test:
Cleanup
mysql-test/suite/funcs_1/t/myisam_storedproc_06.test:
Cleanup
mysql-test/suite/funcs_1/t/myisam_storedproc_07.test:
Cleanup
mysql-test/suite/funcs_1/t/myisam_storedproc_08.test:
Cleanup
mysql-test/suite/funcs_1/t/myisam_storedproc_10.test:
Cleanup
mysql-test/suite/funcs_1/triggers/trig_frkey2.inc:
Cleanup
mysql-test/suite/funcs_1/triggers/triggers_0102.inc:
Cleanup
mysql-test/suite/funcs_1/triggers/triggers_03.inc:
Backport from 5.1
mysql-test/suite/funcs_1/triggers/triggers_0407.inc:
Backport from 5.1
mysql-test/suite/funcs_1/triggers/triggers_08.inc:
Backport from 5.1
mysql-test/suite/funcs_1/triggers/triggers_09.inc:
Backport from 5.1
mysql-test/suite/funcs_1/triggers/triggers_1011ext.inc:
Backport from 5.1
mysql-test/suite/funcs_1/views/func_view.inc:
Backport from 5.1
mysql-test/suite/funcs_1/views/views_master.inc:
Cleanup
mysql-test/std_data/funcs_1/load_file.txt:
New BitKeeper file ``mysql-test/std_data/funcs_1/load_file.txt''
644 lines
16 KiB
Plaintext
644 lines
16 KiB
Plaintext
|
|
--source suite/funcs_1/storedproc/load_sp_tb.inc
|
|
--------------------------------------------------------------------------------
|
|
|
|
--source suite/funcs_1/storedproc/cleanup_sp_tb.inc
|
|
--------------------------------------------------------------------------------
|
|
DROP DATABASE IF EXISTS db_storedproc;
|
|
DROP DATABASE IF EXISTS db_storedproc_1;
|
|
CREATE DATABASE db_storedproc;
|
|
CREATE DATABASE db_storedproc_1;
|
|
USE db_storedproc;
|
|
create table t1(f1 char(20),f2 char(25),f3 date,f4 int,f5 char(25),f6 int)
|
|
engine = <engine_to_be_tested>;
|
|
load data infile '<MYSQLTEST_VARDIR>/std_data_ln/funcs_1/t4.txt' into table t1;
|
|
create table t2(f1 char(20),f2 char(25),f3 date,f4 int,f5 char(25),f6 int)
|
|
engine = <engine_to_be_tested>;
|
|
load data infile '<MYSQLTEST_VARDIR>/std_data_ln/funcs_1/t4.txt' into table t2;
|
|
create table t3(f1 char(20),f2 char(20),f3 integer) engine = <engine_to_be_tested>;
|
|
load data infile '<MYSQLTEST_VARDIR>/std_data_ln/funcs_1/t3.txt' into table t3;
|
|
create table t4(f1 char(20),f2 char(25),f3 date,f4 int,f5 char(25),f6 int)
|
|
engine = <engine_to_be_tested>;
|
|
load data infile '<MYSQLTEST_VARDIR>/std_data_ln/funcs_1/t4.txt' into table t4;
|
|
USE db_storedproc_1;
|
|
create table t6(f1 char(20),f2 char(25),f3 date,f4 int,f5 char(25),f6 int)
|
|
engine = <engine_to_be_tested>;
|
|
load data infile '<MYSQLTEST_VARDIR>/std_data_ln/funcs_1/t4.txt' into table t6;
|
|
USE db_storedproc;
|
|
create table t7 (f1 char(20), f2 char(25), f3 date, f4 int)
|
|
engine = <engine_to_be_tested>;
|
|
load data infile '<MYSQLTEST_VARDIR>/std_data_ln/funcs_1/t7.txt' into table t7;
|
|
Warnings:
|
|
Warning 1265 Data truncated for column 'f3' at row 1
|
|
Warning 1265 Data truncated for column 'f3' at row 2
|
|
Warning 1265 Data truncated for column 'f3' at row 3
|
|
Warning 1265 Data truncated for column 'f3' at row 4
|
|
Warning 1265 Data truncated for column 'f3' at row 5
|
|
Warning 1265 Data truncated for column 'f3' at row 6
|
|
Warning 1265 Data truncated for column 'f3' at row 7
|
|
Warning 1265 Data truncated for column 'f3' at row 8
|
|
Warning 1265 Data truncated for column 'f3' at row 9
|
|
Warning 1265 Data truncated for column 'f3' at row 10
|
|
create table t8 (f1 char(20), f2 char(25), f3 date, f4 int)
|
|
engine = <engine_to_be_tested>;
|
|
load data infile '<MYSQLTEST_VARDIR>/std_data_ln/funcs_1/t7.txt' into table t8;
|
|
Warnings:
|
|
Warning 1265 Data truncated for column 'f3' at row 1
|
|
Warning 1265 Data truncated for column 'f3' at row 2
|
|
Warning 1265 Data truncated for column 'f3' at row 3
|
|
Warning 1265 Data truncated for column 'f3' at row 4
|
|
Warning 1265 Data truncated for column 'f3' at row 5
|
|
Warning 1265 Data truncated for column 'f3' at row 6
|
|
Warning 1265 Data truncated for column 'f3' at row 7
|
|
Warning 1265 Data truncated for column 'f3' at row 8
|
|
Warning 1265 Data truncated for column 'f3' at row 9
|
|
Warning 1265 Data truncated for column 'f3' at row 10
|
|
create table t9(f1 int, f2 char(25), f3 int) engine = <engine_to_be_tested>;
|
|
load data infile '<MYSQLTEST_VARDIR>/std_data_ln/funcs_1/t9.txt' into table t9;
|
|
create table t10(f1 char(20),f2 char(25),f3 date,f4 int,f5 char(25),f6 int)
|
|
engine = <engine_to_be_tested>;
|
|
load data infile '<MYSQLTEST_VARDIR>/std_data_ln/funcs_1/t4.txt' into table t10;
|
|
create table t11(f1 char(20),f2 char(25),f3 date,f4 int,f5 char(25),f6 int)
|
|
engine = <engine_to_be_tested>;
|
|
load data infile '<MYSQLTEST_VARDIR>/std_data_ln/funcs_1/t4.txt' into table t11;
|
|
|
|
Section 3.1.8 - SHOW statement checks:
|
|
--------------------------------------------------------------------------------
|
|
|
|
Testcase 3.1.8.9:
|
|
-----------------
|
|
|
|
Ensure that all stored procedure changes made with ALTER PROCEDURE or ALTER
|
|
FUNCTION are properly recorded and displayed when a SHOW CREATE PROCEDURE or
|
|
SHOW CREATE PROCEDURE STATUS statement, or a SHOW CREATE FUNCTION or SHOW CREATE
|
|
FUNCTION STATUS statement (respectively) is executed.
|
|
--------------------------------------------------------------------------------
|
|
DROP FUNCTION IF EXISTS fn_1;
|
|
DROP FUNCTION IF EXISTS fn_2;
|
|
DROP PROCEDURE IF EXISTS sp_1;
|
|
DROP PROCEDURE IF EXISTS sp_2;
|
|
CREATE PROCEDURE sp_1 (i1 int)
|
|
BEGIN
|
|
set @x=i1;
|
|
END//
|
|
CREATE PROCEDURE sp_2 (i1 int) SQL SECURITY INVOKER COMMENT 'created with INVOKER'
|
|
BEGIN
|
|
set @x=i1;
|
|
END//
|
|
CREATE FUNCTION fn_1 (i1 longtext, i2 mediumint , i3 longblob, i4 year, i5 real) returns year
|
|
BEGIN
|
|
set @x=i1;
|
|
set @y=@x;
|
|
return i4;
|
|
END//
|
|
CREATE FUNCTION fn_2 (i1 longtext, i2 mediumint , i3 longblob, i4 year, i5 real)
|
|
RETURNS YEAR
|
|
SQL SECURITY INVOKER
|
|
COMMENT 'created with INVOKER'
|
|
BEGIN
|
|
set @x=i1;
|
|
set @y=@x;
|
|
return i4;
|
|
END//
|
|
|
|
... now check what is stored:
|
|
-----------------------------
|
|
SELECT * FROM information_schema.routines;
|
|
SPECIFIC_NAME fn_1
|
|
ROUTINE_CATALOG NULL
|
|
ROUTINE_SCHEMA db_storedproc
|
|
ROUTINE_NAME fn_1
|
|
ROUTINE_TYPE FUNCTION
|
|
DTD_IDENTIFIER year(4)
|
|
ROUTINE_BODY SQL
|
|
ROUTINE_DEFINITION BEGIN
|
|
set @x=i1;
|
|
set @y=@x;
|
|
return i4;
|
|
END
|
|
EXTERNAL_NAME NULL
|
|
EXTERNAL_LANGUAGE NULL
|
|
PARAMETER_STYLE SQL
|
|
IS_DETERMINISTIC NO
|
|
SQL_DATA_ACCESS CONTAINS SQL
|
|
SQL_PATH NULL
|
|
SECURITY_TYPE DEFINER
|
|
CREATED <modified>
|
|
LAST_ALTERED <created>
|
|
SQL_MODE
|
|
ROUTINE_COMMENT
|
|
DEFINER root@localhost
|
|
SPECIFIC_NAME fn_2
|
|
ROUTINE_CATALOG NULL
|
|
ROUTINE_SCHEMA db_storedproc
|
|
ROUTINE_NAME fn_2
|
|
ROUTINE_TYPE FUNCTION
|
|
DTD_IDENTIFIER year(4)
|
|
ROUTINE_BODY SQL
|
|
ROUTINE_DEFINITION BEGIN
|
|
set @x=i1;
|
|
set @y=@x;
|
|
return i4;
|
|
END
|
|
EXTERNAL_NAME NULL
|
|
EXTERNAL_LANGUAGE NULL
|
|
PARAMETER_STYLE SQL
|
|
IS_DETERMINISTIC NO
|
|
SQL_DATA_ACCESS CONTAINS SQL
|
|
SQL_PATH NULL
|
|
SECURITY_TYPE INVOKER
|
|
CREATED <modified>
|
|
LAST_ALTERED <created>
|
|
SQL_MODE
|
|
ROUTINE_COMMENT created with INVOKER
|
|
DEFINER root@localhost
|
|
SPECIFIC_NAME sp_1
|
|
ROUTINE_CATALOG NULL
|
|
ROUTINE_SCHEMA db_storedproc
|
|
ROUTINE_NAME sp_1
|
|
ROUTINE_TYPE PROCEDURE
|
|
DTD_IDENTIFIER NULL
|
|
ROUTINE_BODY SQL
|
|
ROUTINE_DEFINITION BEGIN
|
|
set @x=i1;
|
|
END
|
|
EXTERNAL_NAME NULL
|
|
EXTERNAL_LANGUAGE NULL
|
|
PARAMETER_STYLE SQL
|
|
IS_DETERMINISTIC NO
|
|
SQL_DATA_ACCESS CONTAINS SQL
|
|
SQL_PATH NULL
|
|
SECURITY_TYPE DEFINER
|
|
CREATED <modified>
|
|
LAST_ALTERED <created>
|
|
SQL_MODE
|
|
ROUTINE_COMMENT
|
|
DEFINER root@localhost
|
|
SPECIFIC_NAME sp_2
|
|
ROUTINE_CATALOG NULL
|
|
ROUTINE_SCHEMA db_storedproc
|
|
ROUTINE_NAME sp_2
|
|
ROUTINE_TYPE PROCEDURE
|
|
DTD_IDENTIFIER NULL
|
|
ROUTINE_BODY SQL
|
|
ROUTINE_DEFINITION BEGIN
|
|
set @x=i1;
|
|
END
|
|
EXTERNAL_NAME NULL
|
|
EXTERNAL_LANGUAGE NULL
|
|
PARAMETER_STYLE SQL
|
|
IS_DETERMINISTIC NO
|
|
SQL_DATA_ACCESS CONTAINS SQL
|
|
SQL_PATH NULL
|
|
SECURITY_TYPE INVOKER
|
|
CREATED <modified>
|
|
LAST_ALTERED <created>
|
|
SQL_MODE
|
|
ROUTINE_COMMENT created with INVOKER
|
|
DEFINER root@localhost
|
|
SHOW CREATE FUNCTION fn_1;
|
|
Function fn_1
|
|
sql_mode
|
|
Create Function CREATE DEFINER=`root`@`localhost` FUNCTION `fn_1`(i1 longtext, i2 mediumint , i3 longblob, i4 year, i5 real) RETURNS year(4)
|
|
BEGIN
|
|
set @x=i1;
|
|
set @y=@x;
|
|
return i4;
|
|
END
|
|
SHOW CREATE FUNCTION fn_2;
|
|
Function fn_2
|
|
sql_mode
|
|
Create Function CREATE DEFINER=`root`@`localhost` FUNCTION `fn_2`(i1 longtext, i2 mediumint , i3 longblob, i4 year, i5 real) RETURNS year(4)
|
|
SQL SECURITY INVOKER
|
|
COMMENT 'created with INVOKER'
|
|
BEGIN
|
|
set @x=i1;
|
|
set @y=@x;
|
|
return i4;
|
|
END
|
|
SHOW CREATE PROCEDURE sp_1;
|
|
Procedure sp_1
|
|
sql_mode
|
|
Create Procedure CREATE DEFINER=`root`@`localhost` PROCEDURE `sp_1`(i1 int)
|
|
BEGIN
|
|
set @x=i1;
|
|
END
|
|
SHOW CREATE PROCEDURE sp_2;
|
|
Procedure sp_2
|
|
sql_mode
|
|
Create Procedure CREATE DEFINER=`root`@`localhost` PROCEDURE `sp_2`(i1 int)
|
|
SQL SECURITY INVOKER
|
|
COMMENT 'created with INVOKER'
|
|
BEGIN
|
|
set @x=i1;
|
|
END
|
|
SHOW FUNCTION STATUS LIKE 'fn_%';
|
|
Db db_storedproc
|
|
Name fn_1
|
|
Type FUNCTION
|
|
Definer root@localhost
|
|
Modified <modified>
|
|
Created <created>
|
|
Security_type DEFINER
|
|
Comment
|
|
Db db_storedproc
|
|
Name fn_2
|
|
Type FUNCTION
|
|
Definer root@localhost
|
|
Modified <modified>
|
|
Created <created>
|
|
Security_type INVOKER
|
|
Comment created with INVOKER
|
|
SHOW PROCEDURE STATUS LIKE 'sp_%';
|
|
Db db_storedproc
|
|
Name sp_1
|
|
Type PROCEDURE
|
|
Definer root@localhost
|
|
Modified <modified>
|
|
Created <created>
|
|
Security_type DEFINER
|
|
Comment
|
|
Db db_storedproc
|
|
Name sp_2
|
|
Type PROCEDURE
|
|
Definer root@localhost
|
|
Modified <modified>
|
|
Created <created>
|
|
Security_type INVOKER
|
|
Comment created with INVOKER
|
|
|
|
... now change some stuff:
|
|
--------------------------
|
|
ALTER PROCEDURE sp_1 SQL SECURITY INVOKER;
|
|
ALTER PROCEDURE sp_1 COMMENT 'new comment, SP changed to INVOKER';
|
|
ALTER PROCEDURE sp_2 SQL SECURITY DEFINER;
|
|
ALTER PROCEDURE sp_2 DROP COMMENT;
|
|
ERROR 42000: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'DROP COMMENT' at line 1
|
|
ALTER PROCEDURE sp_2 COMMENT 'SP changed to DEFINER';
|
|
ALTER PROCEDURE sp_2 READS SQL DATA;
|
|
ALTER FUNCTION fn_1 SQL SECURITY INVOKER;
|
|
ALTER FUNCTION fn_1 COMMENT 'new comment, FN changed to INVOKER';
|
|
ALTER FUNCTION fn_1 NO SQL;
|
|
ALTER FUNCTION fn_2 SQL SECURITY DEFINER;
|
|
ALTER FUNCTION fn_2 COMMENT 'FN changed to DEFINER';
|
|
ALTER FUNCTION fn_2 MODIFIES SQL DATA;
|
|
|
|
... now check what is stored:
|
|
-----------------------------
|
|
SELECT * FROM information_schema.routines;
|
|
SPECIFIC_NAME fn_1
|
|
ROUTINE_CATALOG NULL
|
|
ROUTINE_SCHEMA db_storedproc
|
|
ROUTINE_NAME fn_1
|
|
ROUTINE_TYPE FUNCTION
|
|
DTD_IDENTIFIER year(4)
|
|
ROUTINE_BODY SQL
|
|
ROUTINE_DEFINITION BEGIN
|
|
set @x=i1;
|
|
set @y=@x;
|
|
return i4;
|
|
END
|
|
EXTERNAL_NAME NULL
|
|
EXTERNAL_LANGUAGE NULL
|
|
PARAMETER_STYLE SQL
|
|
IS_DETERMINISTIC NO
|
|
SQL_DATA_ACCESS NO SQL
|
|
SQL_PATH NULL
|
|
SECURITY_TYPE INVOKER
|
|
CREATED <modified>
|
|
LAST_ALTERED <created>
|
|
SQL_MODE
|
|
ROUTINE_COMMENT new comment, FN changed to INVOKER
|
|
DEFINER root@localhost
|
|
SPECIFIC_NAME fn_2
|
|
ROUTINE_CATALOG NULL
|
|
ROUTINE_SCHEMA db_storedproc
|
|
ROUTINE_NAME fn_2
|
|
ROUTINE_TYPE FUNCTION
|
|
DTD_IDENTIFIER year(4)
|
|
ROUTINE_BODY SQL
|
|
ROUTINE_DEFINITION BEGIN
|
|
set @x=i1;
|
|
set @y=@x;
|
|
return i4;
|
|
END
|
|
EXTERNAL_NAME NULL
|
|
EXTERNAL_LANGUAGE NULL
|
|
PARAMETER_STYLE SQL
|
|
IS_DETERMINISTIC NO
|
|
SQL_DATA_ACCESS MODIFIES SQL DATA
|
|
SQL_PATH NULL
|
|
SECURITY_TYPE DEFINER
|
|
CREATED <modified>
|
|
LAST_ALTERED <created>
|
|
SQL_MODE
|
|
ROUTINE_COMMENT FN changed to DEFINER
|
|
DEFINER root@localhost
|
|
SPECIFIC_NAME sp_1
|
|
ROUTINE_CATALOG NULL
|
|
ROUTINE_SCHEMA db_storedproc
|
|
ROUTINE_NAME sp_1
|
|
ROUTINE_TYPE PROCEDURE
|
|
DTD_IDENTIFIER NULL
|
|
ROUTINE_BODY SQL
|
|
ROUTINE_DEFINITION BEGIN
|
|
set @x=i1;
|
|
END
|
|
EXTERNAL_NAME NULL
|
|
EXTERNAL_LANGUAGE NULL
|
|
PARAMETER_STYLE SQL
|
|
IS_DETERMINISTIC NO
|
|
SQL_DATA_ACCESS CONTAINS SQL
|
|
SQL_PATH NULL
|
|
SECURITY_TYPE INVOKER
|
|
CREATED <modified>
|
|
LAST_ALTERED <created>
|
|
SQL_MODE
|
|
ROUTINE_COMMENT new comment, SP changed to INVOKER
|
|
DEFINER root@localhost
|
|
SPECIFIC_NAME sp_2
|
|
ROUTINE_CATALOG NULL
|
|
ROUTINE_SCHEMA db_storedproc
|
|
ROUTINE_NAME sp_2
|
|
ROUTINE_TYPE PROCEDURE
|
|
DTD_IDENTIFIER NULL
|
|
ROUTINE_BODY SQL
|
|
ROUTINE_DEFINITION BEGIN
|
|
set @x=i1;
|
|
END
|
|
EXTERNAL_NAME NULL
|
|
EXTERNAL_LANGUAGE NULL
|
|
PARAMETER_STYLE SQL
|
|
IS_DETERMINISTIC NO
|
|
SQL_DATA_ACCESS READS SQL DATA
|
|
SQL_PATH NULL
|
|
SECURITY_TYPE DEFINER
|
|
CREATED <modified>
|
|
LAST_ALTERED <created>
|
|
SQL_MODE
|
|
ROUTINE_COMMENT SP changed to DEFINER
|
|
DEFINER root@localhost
|
|
SHOW CREATE FUNCTION fn_1;
|
|
Function fn_1
|
|
sql_mode
|
|
Create Function CREATE DEFINER=`root`@`localhost` FUNCTION `fn_1`(i1 longtext, i2 mediumint , i3 longblob, i4 year, i5 real) RETURNS year(4)
|
|
NO SQL
|
|
SQL SECURITY INVOKER
|
|
COMMENT 'new comment, FN changed to INVOKER'
|
|
BEGIN
|
|
set @x=i1;
|
|
set @y=@x;
|
|
return i4;
|
|
END
|
|
SHOW CREATE FUNCTION fn_2;
|
|
Function fn_2
|
|
sql_mode
|
|
Create Function CREATE DEFINER=`root`@`localhost` FUNCTION `fn_2`(i1 longtext, i2 mediumint , i3 longblob, i4 year, i5 real) RETURNS year(4)
|
|
MODIFIES SQL DATA
|
|
COMMENT 'FN changed to DEFINER'
|
|
BEGIN
|
|
set @x=i1;
|
|
set @y=@x;
|
|
return i4;
|
|
END
|
|
SHOW CREATE PROCEDURE sp_1;
|
|
Procedure sp_1
|
|
sql_mode
|
|
Create Procedure CREATE DEFINER=`root`@`localhost` PROCEDURE `sp_1`(i1 int)
|
|
SQL SECURITY INVOKER
|
|
COMMENT 'new comment, SP changed to INVOKER'
|
|
BEGIN
|
|
set @x=i1;
|
|
END
|
|
SHOW CREATE PROCEDURE sp_2;
|
|
Procedure sp_2
|
|
sql_mode
|
|
Create Procedure CREATE DEFINER=`root`@`localhost` PROCEDURE `sp_2`(i1 int)
|
|
READS SQL DATA
|
|
COMMENT 'SP changed to DEFINER'
|
|
BEGIN
|
|
set @x=i1;
|
|
END
|
|
SHOW FUNCTION STATUS LIKE 'fn_%';
|
|
Db db_storedproc
|
|
Name fn_1
|
|
Type FUNCTION
|
|
Definer root@localhost
|
|
Modified <modified>
|
|
Created <created>
|
|
Security_type INVOKER
|
|
Comment new comment, FN changed to INVOKER
|
|
Db db_storedproc
|
|
Name fn_2
|
|
Type FUNCTION
|
|
Definer root@localhost
|
|
Modified <modified>
|
|
Created <created>
|
|
Security_type DEFINER
|
|
Comment FN changed to DEFINER
|
|
SHOW PROCEDURE STATUS LIKE 'sp_%';
|
|
Db db_storedproc
|
|
Name sp_1
|
|
Type PROCEDURE
|
|
Definer root@localhost
|
|
Modified <modified>
|
|
Created <created>
|
|
Security_type INVOKER
|
|
Comment new comment, SP changed to INVOKER
|
|
Db db_storedproc
|
|
Name sp_2
|
|
Type PROCEDURE
|
|
Definer root@localhost
|
|
Modified <modified>
|
|
Created <created>
|
|
Security_type DEFINER
|
|
Comment SP changed to DEFINER
|
|
|
|
... change back to default and check result:
|
|
--------------------------------------------
|
|
ALTER FUNCTION fn_2 CONTAINS SQL;
|
|
|
|
... now check what is stored:
|
|
-----------------------------
|
|
SELECT * FROM information_schema.routines;
|
|
SPECIFIC_NAME fn_1
|
|
ROUTINE_CATALOG NULL
|
|
ROUTINE_SCHEMA db_storedproc
|
|
ROUTINE_NAME fn_1
|
|
ROUTINE_TYPE FUNCTION
|
|
DTD_IDENTIFIER year(4)
|
|
ROUTINE_BODY SQL
|
|
ROUTINE_DEFINITION BEGIN
|
|
set @x=i1;
|
|
set @y=@x;
|
|
return i4;
|
|
END
|
|
EXTERNAL_NAME NULL
|
|
EXTERNAL_LANGUAGE NULL
|
|
PARAMETER_STYLE SQL
|
|
IS_DETERMINISTIC NO
|
|
SQL_DATA_ACCESS NO SQL
|
|
SQL_PATH NULL
|
|
SECURITY_TYPE INVOKER
|
|
CREATED <modified>
|
|
LAST_ALTERED <created>
|
|
SQL_MODE
|
|
ROUTINE_COMMENT new comment, FN changed to INVOKER
|
|
DEFINER root@localhost
|
|
SPECIFIC_NAME fn_2
|
|
ROUTINE_CATALOG NULL
|
|
ROUTINE_SCHEMA db_storedproc
|
|
ROUTINE_NAME fn_2
|
|
ROUTINE_TYPE FUNCTION
|
|
DTD_IDENTIFIER year(4)
|
|
ROUTINE_BODY SQL
|
|
ROUTINE_DEFINITION BEGIN
|
|
set @x=i1;
|
|
set @y=@x;
|
|
return i4;
|
|
END
|
|
EXTERNAL_NAME NULL
|
|
EXTERNAL_LANGUAGE NULL
|
|
PARAMETER_STYLE SQL
|
|
IS_DETERMINISTIC NO
|
|
SQL_DATA_ACCESS CONTAINS SQL
|
|
SQL_PATH NULL
|
|
SECURITY_TYPE DEFINER
|
|
CREATED <modified>
|
|
LAST_ALTERED <created>
|
|
SQL_MODE
|
|
ROUTINE_COMMENT FN changed to DEFINER
|
|
DEFINER root@localhost
|
|
SPECIFIC_NAME sp_1
|
|
ROUTINE_CATALOG NULL
|
|
ROUTINE_SCHEMA db_storedproc
|
|
ROUTINE_NAME sp_1
|
|
ROUTINE_TYPE PROCEDURE
|
|
DTD_IDENTIFIER NULL
|
|
ROUTINE_BODY SQL
|
|
ROUTINE_DEFINITION BEGIN
|
|
set @x=i1;
|
|
END
|
|
EXTERNAL_NAME NULL
|
|
EXTERNAL_LANGUAGE NULL
|
|
PARAMETER_STYLE SQL
|
|
IS_DETERMINISTIC NO
|
|
SQL_DATA_ACCESS CONTAINS SQL
|
|
SQL_PATH NULL
|
|
SECURITY_TYPE INVOKER
|
|
CREATED <modified>
|
|
LAST_ALTERED <created>
|
|
SQL_MODE
|
|
ROUTINE_COMMENT new comment, SP changed to INVOKER
|
|
DEFINER root@localhost
|
|
SPECIFIC_NAME sp_2
|
|
ROUTINE_CATALOG NULL
|
|
ROUTINE_SCHEMA db_storedproc
|
|
ROUTINE_NAME sp_2
|
|
ROUTINE_TYPE PROCEDURE
|
|
DTD_IDENTIFIER NULL
|
|
ROUTINE_BODY SQL
|
|
ROUTINE_DEFINITION BEGIN
|
|
set @x=i1;
|
|
END
|
|
EXTERNAL_NAME NULL
|
|
EXTERNAL_LANGUAGE NULL
|
|
PARAMETER_STYLE SQL
|
|
IS_DETERMINISTIC NO
|
|
SQL_DATA_ACCESS READS SQL DATA
|
|
SQL_PATH NULL
|
|
SECURITY_TYPE DEFINER
|
|
CREATED <modified>
|
|
LAST_ALTERED <created>
|
|
SQL_MODE
|
|
ROUTINE_COMMENT SP changed to DEFINER
|
|
DEFINER root@localhost
|
|
SHOW CREATE FUNCTION fn_1;
|
|
Function fn_1
|
|
sql_mode
|
|
Create Function CREATE DEFINER=`root`@`localhost` FUNCTION `fn_1`(i1 longtext, i2 mediumint , i3 longblob, i4 year, i5 real) RETURNS year(4)
|
|
NO SQL
|
|
SQL SECURITY INVOKER
|
|
COMMENT 'new comment, FN changed to INVOKER'
|
|
BEGIN
|
|
set @x=i1;
|
|
set @y=@x;
|
|
return i4;
|
|
END
|
|
SHOW CREATE FUNCTION fn_2;
|
|
Function fn_2
|
|
sql_mode
|
|
Create Function CREATE DEFINER=`root`@`localhost` FUNCTION `fn_2`(i1 longtext, i2 mediumint , i3 longblob, i4 year, i5 real) RETURNS year(4)
|
|
COMMENT 'FN changed to DEFINER'
|
|
BEGIN
|
|
set @x=i1;
|
|
set @y=@x;
|
|
return i4;
|
|
END
|
|
SHOW CREATE PROCEDURE sp_1;
|
|
Procedure sp_1
|
|
sql_mode
|
|
Create Procedure CREATE DEFINER=`root`@`localhost` PROCEDURE `sp_1`(i1 int)
|
|
SQL SECURITY INVOKER
|
|
COMMENT 'new comment, SP changed to INVOKER'
|
|
BEGIN
|
|
set @x=i1;
|
|
END
|
|
SHOW CREATE PROCEDURE sp_2;
|
|
Procedure sp_2
|
|
sql_mode
|
|
Create Procedure CREATE DEFINER=`root`@`localhost` PROCEDURE `sp_2`(i1 int)
|
|
READS SQL DATA
|
|
COMMENT 'SP changed to DEFINER'
|
|
BEGIN
|
|
set @x=i1;
|
|
END
|
|
SHOW FUNCTION STATUS LIKE 'fn_%';
|
|
Db db_storedproc
|
|
Name fn_1
|
|
Type FUNCTION
|
|
Definer root@localhost
|
|
Modified <modified>
|
|
Created <created>
|
|
Security_type INVOKER
|
|
Comment new comment, FN changed to INVOKER
|
|
Db db_storedproc
|
|
Name fn_2
|
|
Type FUNCTION
|
|
Definer root@localhost
|
|
Modified <modified>
|
|
Created <created>
|
|
Security_type DEFINER
|
|
Comment FN changed to DEFINER
|
|
SHOW PROCEDURE STATUS LIKE 'sp_%';
|
|
Db db_storedproc
|
|
Name sp_1
|
|
Type PROCEDURE
|
|
Definer root@localhost
|
|
Modified <modified>
|
|
Created <created>
|
|
Security_type INVOKER
|
|
Comment new comment, SP changed to INVOKER
|
|
Db db_storedproc
|
|
Name sp_2
|
|
Type PROCEDURE
|
|
Definer root@localhost
|
|
Modified <modified>
|
|
Created <created>
|
|
Security_type DEFINER
|
|
Comment SP changed to DEFINER
|
|
|
|
... cleanup
|
|
-----------
|
|
DROP FUNCTION fn_1;
|
|
DROP FUNCTION fn_2;
|
|
DROP PROCEDURE sp_1;
|
|
|
|
--source suite/funcs_1/storedproc/cleanup_sp_tb.inc
|
|
--------------------------------------------------------------------------------
|
|
DROP DATABASE IF EXISTS db_storedproc;
|
|
DROP DATABASE IF EXISTS db_storedproc_1;
|
|
|
|
. +++ END OF SCRIPT +++
|
|
--------------------------------------------------------------------------------
|