memory_storedproc_06.result
来自「视频监控网络部分的协议ddns,的模块的实现代码,请大家大胆指正.」· RESULT 代码 · 共 400 行
RESULT
400 行
--source suite/funcs_1/storedproc/load_sp_tb.inc--------------------------------------------------------------------------------SET @@global.max_heap_table_size=4294967295;SET @@session.max_heap_table_size=4294967295;--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 = memory;load data infile 'MYSQL_TEST_DIR/suite/funcs_1/data/t4.txt' into table t1;create table t2(f1 char(20),f2 char(25),f3 date,f4 int,f5 char(25),f6 int) engine = memory;load data infile 'MYSQL_TEST_DIR/suite/funcs_1/data/t4.txt' into table t2;create table t3(f1 char(20),f2 char(20),f3 integer) engine = memory;load data infile 'MYSQL_TEST_DIR/suite/funcs_1/data/t3.txt' into table t3;create table t4(f1 char(20),f2 char(25),f3 date,f4 int,f5 char(25),f6 int) engine = memory;load data infile 'MYSQL_TEST_DIR/suite/funcs_1/data/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 = memory;load data infile 'MYSQL_TEST_DIR/suite/funcs_1/data/t4.txt' into table t6;USE db_storedproc;create table t7 (f1 char(20), f2 char(25), f3 date, f4 int) engine = memory;load data infile 'MYSQL_TEST_DIR/suite/funcs_1/data/t7.txt' into table t7;Warnings:Warning 1265 Data truncated for column 'f3' at row 1Warning 1265 Data truncated for column 'f3' at row 2Warning 1265 Data truncated for column 'f3' at row 3Warning 1265 Data truncated for column 'f3' at row 4Warning 1265 Data truncated for column 'f3' at row 5Warning 1265 Data truncated for column 'f3' at row 6Warning 1265 Data truncated for column 'f3' at row 7Warning 1265 Data truncated for column 'f3' at row 8Warning 1265 Data truncated for column 'f3' at row 9Warning 1265 Data truncated for column 'f3' at row 10create table t8 (f1 char(20), f2 char(25), f3 date, f4 int) engine = memory;load data infile 'MYSQL_TEST_DIR/suite/funcs_1/data/t7.txt' into table t8;Warnings:Warning 1265 Data truncated for column 'f3' at row 1Warning 1265 Data truncated for column 'f3' at row 2Warning 1265 Data truncated for column 'f3' at row 3Warning 1265 Data truncated for column 'f3' at row 4Warning 1265 Data truncated for column 'f3' at row 5Warning 1265 Data truncated for column 'f3' at row 6Warning 1265 Data truncated for column 'f3' at row 7Warning 1265 Data truncated for column 'f3' at row 8Warning 1265 Data truncated for column 'f3' at row 9Warning 1265 Data truncated for column 'f3' at row 10create table t9(f1 int, f2 char(25), f3 int) engine = memory;load data infile 'MYSQL_TEST_DIR/suite/funcs_1/data/t9.txt' into table t9;create table t10(f1 char(20),f2 char(25),f3 date,f4 int,f5 char(25),f6 int) engine = memory;load data infile 'MYSQL_TEST_DIR/suite/funcs_1/data/t4.txt' into table t10;create table t11(f1 char(20),f2 char(25),f3 date,f4 int,f5 char(25),f6 int) engine = memory;load data infile 'MYSQL_TEST_DIR/suite/funcs_1/data/t4.txt' into table t11;Section 3.1.6 - Privilege Checks:--------------------------------------------------------------------------------USE db_storedproc_1; root@localhost db_storedproc_1Testcase 3.1.6.1:-----------------Ensure that no user may create a stored procedure without the GRANT CREATEROUTINE privilege.--------------------------------------------------------------------------------create user 'user_1'@'localhost';grant all on db_storedproc_1.* to 'user_1'@'localhost';revoke create routine on db_storedproc_1.* from 'user_1'@'localhost';flush privileges;DROP PROCEDURE IF EXISTS sp1;connect(localhost,user_1,,db_storedproc_1,MYSQL_PORT,MYSQL_SOCK); user_1@localhost db_storedproc_1USE db_storedproc_1;CREATE PROCEDURE sp1(v1 char(20))BEGINSELECT * from db_storedproc_1.t6 where t6.f2= 'xyz';END//ERROR 42000: Access denied for user 'user_1'@'localhost' to database 'db_storedproc_1' root@localhost db_storedproc_1GRANT CREATE ROUTINE ON db_storedproc_1.* TO 'user_1'@'localhost';connect(localhost,user_1,,db_storedproc_1,MYSQL_PORT,MYSQL_SOCK); user_1@localhost db_storedproc_1USE db_storedproc_1;CREATE PROCEDURE sp1(v1 char(20))BEGINSELECT * from db_storedproc_1.t6 where t6.f2= 'xyz';END// root@localhost db_storedproc_1DROP USER 'user_1'@'localhost';DROP PROCEDURE sp1;Testcase 3.1.6.2:-----------------Ensure that root always has the GRANT CREATE ROUTINE privilege.(checked by other testscases)--------------------------------------------------------------------------------grant create routine on db_storedproc_1.* to 'user_1'@'localhost';flush privileges;connect(localhost,user_1,,db_storedproc_1,MYSQL_PORT,MYSQL_SOCK); user_1@localhost db_storedproc_1DROP PROCEDURE IF EXISTS sp3;DROP FUNCTION IF EXISTS fn1;CREATE PROCEDURE sp3(v1 char(20))BEGINSELECT * from db_storedproc_1.t6 where t6.f2= 'xyz';END//CREATE FUNCTION fn1(v1 int) returns intBEGINreturn v1;END// root@localhost db_storedproc_1drop user 'user_1'@'localhost';DROP PROCEDURE sp3;DROP FUNCTION fn1;Warnings:Error 1133 Can't find any matching row in the user tableError 1269 Can't revoke all privileges for one or more of the requested usersWarning 1405 Failed to revoke all privileges to dropped routineTestcase 3.1.6.4:-----------------Ensure that the default security provision of a stored procedure is SQL SECURITYDEFINER.--------------------------------------------------------------------------------CREATE USER 'user_1'@'localhost';grant update on db_storedproc_1.t6 to 'user_1'@'localhost';grant execute on db_storedproc_1.* to 'user_1'@'localhost';flush privileges;USE db_storedproc_1;DROP PROCEDURE IF EXISTS sp4;CREATE PROCEDURE sp4(v1 char(20))BEGINSELECT * from db_storedproc_1.t6 where t6.f2= 'xyz';END//connect(localhost,user_1,,db_storedproc_1,MYSQL_PORT,MYSQL_SOCK); user_1@localhost db_storedproc_1USE db_storedproc_1;CALL sp4('a');f1 f2 f3 f4 f5 f6SELECT SPECIFIC_NAME, ROUTINE_SCHEMA, ROUTINE_NAME, ROUTINE_TYPE,ROUTINE_BODY, ROUTINE_DEFINITION, IS_DETERMINISTIC,SQL_DATA_ACCESS, SECURITY_TYPE, SQL_MODE, ROUTINE_COMMENTFROM information_schema.routinesWHERE routine_schema LIKE 'db_sto%';SPECIFIC_NAME sp4ROUTINE_SCHEMA db_storedproc_1ROUTINE_NAME sp4ROUTINE_TYPE PROCEDUREROUTINE_BODY SQLROUTINE_DEFINITION NULLIS_DETERMINISTIC NOSQL_DATA_ACCESS CONTAINS SQLSECURITY_TYPE DEFINERSQL_MODE ROUTINE_COMMENT root@localhost db_storedproc_1DROP PROCEDURE sp4;DROP USER 'user_1'@'localhost';Testcase 3.1.6.5:-----------------Ensure that a stored procedure defined with SQL SECURITY DEFINER can becalled/executed by any user, using only the privileges (including databaseaccess privileges) associated with the user who created the stored procedure.--------------------------------------------------------------------------------USE db_storedproc_1;CREATE TABLE t3165 ( c1 char(20), c2 char(20), c3 date);INSERT INTO t3165 VALUES ('inserted', 'outside of SP', NULL);create user 'user_1'@'localhost';create user 'user_2'@'localhost';grant create routine on db_storedproc_1.* to 'user_1'@'localhost';grant SELECT on db_storedproc_1.* to 'user_2'@'localhost';grant execute on db_storedproc_1.* to 'user_2'@'localhost';flush privileges;connect(localhost,user_1,,db_storedproc_1,MYSQL_PORT,MYSQL_SOCK); user_1@localhost db_storedproc_1CREATE PROCEDURE sp5_s_i () sql security definerBEGINSELECT * from db_storedproc_1.t3165;insert into db_storedproc_1.t3165 values ('inserted', 'from sp5_s_i', 1000);END//CREATE PROCEDURE sp5_sel () sql security definerBEGINSELECT * from db_storedproc_1.t3165;END//CREATE PROCEDURE sp5_ins () sql security definerBEGINinsert into db_storedproc_1.t3165 values ('inserted', 'from sp5_ins', 1000);END//connect(localhost,user_2,,db_storedproc_1,MYSQL_PORT,MYSQL_SOCK); user_2@localhost db_storedproc_1CALL sp5_s_i();ERROR 42000: SELECT command denied to user 'user_1'@'localhost' for table 't3165'CALL sp5_ins();ERROR 42000: INSERT command denied to user 'user_1'@'localhost' for table 't3165'CALL sp5_sel();ERROR 42000: SELECT command denied to user 'user_1'@'localhost' for table 't3165' root@localhost db_storedproc_1CALL sp5_sel();ERROR 42000: SELECT command denied to user 'user_1'@'localhost' for table 't3165'grant insert on db_storedproc_1.* to 'user_1'@'localhost';flush privileges; user_2@localhost db_storedproc_1CALL sp5_s_i();ERROR 42000: SELECT command denied to user 'user_1'@'localhost' for table 't3165'CALL sp5_ins();CALL sp5_sel();ERROR 42000: SELECT command denied to user 'user_1'@'localhost' for table 't3165' root@localhost db_storedproc_1CALL sp5_sel();ERROR 42000: SELECT command denied to user 'user_1'@'localhost' for table 't3165'grant SELECT on db_storedproc_1.* to 'user_1'@'localhost';flush privileges; user_2@localhost db_storedproc_1CALL sp5_s_i();c1 c2 c3inserted outside of SP NULLinserted from sp5_ins 2000-10-00CALL sp5_ins();CALL sp5_sel();c1 c2 c3inserted outside of SP NULLinserted from sp5_ins 2000-10-00inserted from sp5_s_i 2000-10-00inserted from sp5_ins 2000-10-00 root@localhost db_storedproc_1REVOKE INSERT on db_storedproc_1.* from 'user_1'@'localhost';flush privileges; user_2@localhost db_storedproc_1CALL sp5_s_i();c1 c2 c3inserted outside of SP NULLinserted from sp5_ins 2000-10-00inserted from sp5_s_i 2000-10-00inserted from sp5_ins 2000-10-00ERROR 42000: INSERT command denied to user 'user_1'@'localhost' for table 't3165'CALL sp5_ins();ERROR 42000: INSERT command denied to user 'user_1'@'localhost' for table 't3165'CALL sp5_sel();c1 c2 c3inserted outside of SP NULLinserted from sp5_ins 2000-10-00inserted from sp5_s_i 2000-10-00inserted from sp5_ins 2000-10-00 root@localhost db_storedproc_1REVOKE SELECT on db_storedproc_1.* from 'user_1'@'localhost';flush privileges; user_2@localhost db_storedproc_1CALL sp5_s_i();ERROR 42000: SELECT command denied to user 'user_1'@'localhost' for table 't3165'CALL sp5_ins();ERROR 42000: INSERT command denied to user 'user_1'@'localhost' for table 't3165'CALL sp5_sel();ERROR 42000: SELECT command denied to user 'user_1'@'localhost' for table 't3165' root@localhost db_storedproc_1DROP PROCEDURE sp5_s_i;DROP PROCEDURE sp5_sel;DROP PROCEDURE sp5_ins;DROP TABLE t3165;DROP USER 'user_1'@'localhost';DROP USER 'user_2'@'localhost';Testcase 3.1.6.6:-----------------Ensure that a stored procedure defined with SQL SECURITY INVOKER can becalled/executed by any user, using only the privileges (including databaseaccess privileges) associated with the user executing the stored procedure.--------------------------------------------------------------------------------USE db_storedproc_1;CREATE TABLE t3166 ( c1 char(30) );INSERT INTO db_storedproc_1.t3166 VALUES ('inserted outside SP');create user 'user_1'@'localhost';create user 'user_2'@'localhost';GRANT CREATE ROUTINE ON db_storedproc_1.* TO 'user_1'@'localhost';GRANT SELECT ON db_storedproc_1.* TO 'user_2'@'localhost';GRANT EXECUTE ON db_storedproc_1.* TO 'user_2'@'localhost';FLUSH PRIVILEGES;connect(localhost,user_1,,db_storedproc_1,MYSQL_PORT,MYSQL_SOCK); user_1@localhost db_storedproc_1CREATE PROCEDURE sp3166_s_i () SQL SECURITY INVOKERBEGINSELECT * from db_storedproc_1.t3166;insert into db_storedproc_1.t3166 values ('inserted from sp3166_s_i');END//CREATE PROCEDURE sp3166_sel () SQL SECURITY INVOKERBEGINSELECT * from db_storedproc_1.t3166;END//CREATE PROCEDURE sp3166_ins () SQL SECURITY INVOKERBEGINinsert into db_storedproc_1.t3166 values ('inserted from sp3166_ins');END//connect(localhost,user_2,,db_storedproc_1,MYSQL_PORT,MYSQL_SOCK); user_2@localhost db_storedproc_1CALL sp3166_s_i();c1inserted outside SPERROR 42000: INSERT command denied to user 'user_2'@'localhost' for table 't3166'CALL sp3166_ins();ERROR 42000: INSERT command denied to user 'user_2'@'localhost' for table 't3166'CALL sp3166_sel();c1inserted outside SP root@localhost db_storedproc_1CALL sp3166_sel();c1inserted outside SPGRANT INSERT ON db_storedproc_1.* TO 'user_2'@'localhost';FLUSH PRIVILEGES;connect(localhost,user_2,,db_storedproc_1,MYSQL_PORT,MYSQL_SOCK); user_2@localhost db_storedproc_1CALL sp3166_s_i();c1inserted outside SPCALL sp3166_ins();CALL sp3166_sel();c1inserted outside SPinserted from sp3166_s_iinserted from sp3166_ins root@localhost db_storedproc_1CALL sp3166_sel();c1inserted outside SPinserted from sp3166_s_iinserted from sp3166_insREVOKE SELECT ON db_storedproc_1.* FROM 'user_2'@'localhost';FLUSH PRIVILEGES;connect(localhost,user_2,,db_storedproc_1,MYSQL_PORT,MYSQL_SOCK); user_2@localhost db_storedproc_1CALL sp3166_s_i();ERROR 42000: SELECT command denied to user 'user_2'@'localhost' for table 't3166'CALL sp3166_ins();CALL sp3166_sel();ERROR 42000: SELECT command denied to user 'user_2'@'localhost' for table 't3166'CALL sp3166_s_i();c1inserted outside SPinserted from sp3166_s_iinserted from sp3166_insinserted from sp3166_ins root@localhost db_storedproc_1REVOKE EXECUTE on db_storedproc_1.* FROM 'user_2'@'localhost';FLUSH PRIVILEGES;connect(localhost,user_2,,db_storedproc_1,MYSQL_PORT,MYSQL_SOCK); user_2@localhost db_storedproc_1CALL sp3166_s_i();ERROR 42000: execute command denied to user 'user_2'@'localhost' for routine 'db_storedproc_1.sp3166_s_i'CALL sp3166_ins();ERROR 42000: execute command denied to user 'user_2'@'localhost' for routine 'db_storedproc_1.sp3166_ins'CALL sp3166_sel();ERROR 42000: execute command denied to user 'user_2'@'localhost' for routine 'db_storedproc_1.sp3166_sel' root@localhost db_storedproc_1DROP PROCEDURE sp3166_s_i;DROP PROCEDURE sp3166_sel;DROP PROCEDURE sp3166_ins;DROP TABLE t3166;DROP USER 'user_1'@'localhost';DROP USER 'user_2'@'localhost';--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 +++--------------------------------------------------------------------------------
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?