473 lines
		
	
	
		
			20 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
		
		
			
		
	
	
			473 lines
		
	
	
		
			20 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
|  | SET NAMES binary; | ||
|  | drop database if exists mysqltest; | ||
|  | drop database if exists mysqltest_1; | ||
|  | delete from mysql.user where user like 'mysqltest\_%'; | ||
|  | delete from mysql.db where user like 'mysqltest\_%'; | ||
|  | delete from mysql.tables_priv where user like 'mysqltest\_%'; | ||
|  | delete from mysql.columns_priv where user like 'mysqltest\_%'; | ||
|  | flush privileges; | ||
|  | grant all privileges on `my\_1`.* to mysqltest_1@localhost with grant option; | ||
|  | grant create user on *.* to mysqltest_1@localhost; | ||
|  | create user mysqltest_2@localhost; | ||
|  | grant select on `my\_1`.* to mysqltest_2@localhost; | ||
|  | grant select on `my\_1`.* to mysqltest_2@localhost identified by 'pass'; | ||
|  | ERROR 42000: You must have privileges to update tables in the mysql database to be able to change passwords for others | ||
|  | grant update on mysql.* to mysqltest_1@localhost; | ||
|  | grant select on `my\_1`.* to mysqltest_2@localhost identified by 'pass'; | ||
|  | grant select on `my\_1`.* to mysqltest_3@localhost; | ||
|  | grant insert on mysql.* to mysqltest_1@localhost; | ||
|  | grant select on `my\_1`.* to mysqltest_3@localhost; | ||
|  | grant select on `my\_1`.* to mysqltest_4@localhost identified by 'pass'; | ||
|  | delete from mysql.user where user like 'mysqltest\_%'; | ||
|  | delete from mysql.db where user like 'mysqltest\_%'; | ||
|  | delete from mysql.tables_priv where user like 'mysqltest\_%'; | ||
|  | delete from mysql.columns_priv where user like 'mysqltest\_%'; | ||
|  | flush privileges; | ||
|  | grant all privileges on `my\_%`.* to mysqltest_1@localhost with grant option; | ||
|  | grant create user on *.* to mysqltest_1@localhost; | ||
|  | select current_user(); | ||
|  | current_user() | ||
|  | mysqltest_1@localhost | ||
|  | grant all privileges on `my\_1`.* to mysqltest_2@localhost with grant option; | ||
|  | grant all privileges on `my_%`.* to mysqltest_3@localhost with grant option; | ||
|  | ERROR 42000: Access denied for user 'mysqltest_1'@'localhost' to database 'my_%' | ||
|  | set @@sql_mode='NO_AUTO_CREATE_USER'; | ||
|  | select @@sql_mode; | ||
|  | @@sql_mode | ||
|  | NO_AUTO_CREATE_USER | ||
|  | grant select on `my\_1`.* to mysqltest_4@localhost with grant option; | ||
|  | ERROR 42000: Can't find any matching row in the user table | ||
|  | grant select on `my\_1`.* to mysqltest_4@localhost identified by 'mypass' | ||
|  | with grant option; | ||
|  | show grants for mysqltest_1@localhost; | ||
|  | Grants for mysqltest_1@localhost | ||
|  | GRANT CREATE USER ON *.* TO 'mysqltest_1'@'localhost' | ||
|  | GRANT ALL PRIVILEGES ON `my\_%`.* TO 'mysqltest_1'@'localhost' WITH GRANT OPTION | ||
|  | show grants for mysqltest_2@localhost; | ||
|  | Grants for mysqltest_2@localhost | ||
|  | GRANT USAGE ON *.* TO 'mysqltest_2'@'localhost' | ||
|  | GRANT ALL PRIVILEGES ON `my\_1`.* TO 'mysqltest_2'@'localhost' WITH GRANT OPTION | ||
|  | show grants for mysqltest_3@localhost; | ||
|  | ERROR 42000: There is no such grant defined for user 'mysqltest_3' on host 'localhost' | ||
|  | delete from mysql.user where user like 'mysqltest\_%'; | ||
|  | delete from mysql.db where user like 'mysqltest\_%'; | ||
|  | flush privileges; | ||
|  | create database mysqltest_1; | ||
|  | grant all privileges on `mysqltest\_1`.* to mysqltest_1@localhost with grant option; | ||
|  | select current_user(); | ||
|  | current_user() | ||
|  | mysqltest_1@localhost | ||
|  | show databases; | ||
|  | Database | ||
|  | information_schema | ||
|  | mysqltest_1 | ||
|  | test | ||
|  | grant all privileges on `mysqltest_1`.* to mysqltest_1@localhost with grant option; | ||
|  | ERROR 42000: Access denied for user 'mysqltest_1'@'localhost' to database 'mysqltest_1' | ||
|  | show grants for mysqltest_1@localhost; | ||
|  | Grants for mysqltest_1@localhost | ||
|  | GRANT USAGE ON *.* TO 'mysqltest_1'@'localhost' | ||
|  | GRANT ALL PRIVILEGES ON `mysqltest\_1`.* TO 'mysqltest_1'@'localhost' WITH GRANT OPTION | ||
|  | delete from mysql.user where user like 'mysqltest\_%'; | ||
|  | delete from mysql.db where user like 'mysqltest\_%'; | ||
|  | drop database mysqltest_1; | ||
|  | flush privileges; | ||
|  | create database mysqltest; | ||
|  | grant INSERT, SELECT on mysqltest.* to mysqltest_1@localhost; | ||
|  | flush privileges; | ||
|  | use mysqltest; | ||
|  | create table t1 (id int primary key, data varchar(255)); | ||
|  | show grants for current_user(); | ||
|  | Grants for mysqltest_1@localhost | ||
|  | GRANT USAGE ON *.* TO 'mysqltest_1'@'localhost' | ||
|  | GRANT SELECT, INSERT ON `mysqltest`.* TO 'mysqltest_1'@'localhost' | ||
|  | insert into t1 values (1, 'I can''t change it!'); | ||
|  | update t1 set data='I can change it!' where id = 1; | ||
|  | ERROR 42000: UPDATE command denied to user 'mysqltest_1'@'localhost' for table 't1' | ||
|  | insert into t1 values (1, 'XXX') on duplicate key update data= 'I can change it!'; | ||
|  | ERROR 42000: UPDATE command denied to user 'mysqltest_1'@'localhost' for table 't1' | ||
|  | select * from t1; | ||
|  | id	data | ||
|  | 1	I can't change it! | ||
|  | drop table t1; | ||
|  | delete from mysql.user where user like 'mysqltest\_%'; | ||
|  | delete from mysql.db where user like 'mysqltest\_%'; | ||
|  | flush privileges; | ||
|  | create table t1 (a int, b int); | ||
|  | grant select (a) on t1 to mysqltest_1@localhost with grant option; | ||
|  | grant select (a,b) on t1 to mysqltest_2@localhost; | ||
|  | ERROR 42000: SELECT command denied to user 'mysqltest_1'@'localhost' for column 'b' in table 't1' | ||
|  | grant select on t1 to mysqltest_3@localhost; | ||
|  | ERROR 42000: SELECT command denied to user 'mysqltest_1'@'localhost' for table 't1' | ||
|  | drop table t1; | ||
|  | delete from mysql.user where user like 'mysqltest\_%'; | ||
|  | delete from mysql.db where user like 'mysqltest\_%'; | ||
|  | delete from mysql.tables_priv where user like 'mysqltest\_%'; | ||
|  | delete from mysql.columns_priv where user like 'mysqltest\_%'; | ||
|  | flush privileges; | ||
|  | drop database mysqltest; | ||
|  | use test; | ||
|  | create user mysqltest_1@host1; | ||
|  | create user mysqltest_2@host2; | ||
|  | create user mysqltest_3@host3; | ||
|  | create user mysqltest_4@host4; | ||
|  | create user mysqltest_5@host5; | ||
|  | create user mysqltest_6@host6; | ||
|  | create user mysqltest_7@host7; | ||
|  | flush privileges; | ||
|  | drop user mysqltest_3@host3; | ||
|  | drop user mysqltest_1@host1, mysqltest_2@host2, mysqltest_4@host4, | ||
|  | mysqltest_5@host5, mysqltest_6@host6, mysqltest_7@host7; | ||
|  | create database mysqltest_1; | ||
|  | grant select, insert, update on `mysqltest\_1`.* to mysqltest_1@localhost; | ||
|  | set sql_log_off = 1; | ||
|  | ERROR 42000: Access denied; you need the SUPER privilege for this operation | ||
|  | set sql_log_bin = 0; | ||
|  | ERROR 42000: Access denied; you need the SUPER privilege for this operation | ||
|  | delete from mysql.user where user like 'mysqltest\_1'; | ||
|  | delete from mysql.db where user like 'mysqltest\_1'; | ||
|  | drop database mysqltest_1; | ||
|  | flush privileges; | ||
|  | set sql_mode='maxdb'; | ||
|  | drop table if exists t1, t2; | ||
|  | create table t1(c1 int); | ||
|  | create table t2(c1 int, c2 int); | ||
|  | create user 'mysqltest_1'; | ||
|  | create user 'mysqltest_1'; | ||
|  | ERROR HY000: Operation CREATE USER failed for 'mysqltest_1'@'%' | ||
|  | create user 'mysqltest_2' identified by 'Mysqltest-2'; | ||
|  | create user 'mysqltest_3' identified by password 'fffffffffffffffffffffffffffffffffffffffff'; | ||
|  | grant select on *.* to 'mysqltest_2'; | ||
|  | grant insert on test.* to 'mysqltest_2'; | ||
|  | grant update on test.t1 to 'mysqltest_2'; | ||
|  | grant update (c2) on test.t2 to 'mysqltest_2'; | ||
|  | select host,user,password from mysql.user where user like 'mysqltest_%' order by host,user,password; | ||
|  | host	user	password | ||
|  | %	mysqltest_1	 | ||
|  | %	mysqltest_2	*BD447CBA355AF58578D3AE33BA2E2CD388BA08D1 | ||
|  | %	mysqltest_3	fffffffffffffffffffffffffffffffffffffffff | ||
|  | select host,db,user from mysql.db where user like 'mysqltest_%' order by host,db,user; | ||
|  | host	db	user | ||
|  | %	test	mysqltest_2 | ||
|  | select host,db,user,table_name from mysql.tables_priv where user like 'mysqltest_%' order by host,db,user,table_name; | ||
|  | host	db	user	table_name | ||
|  | %	test	mysqltest_2	t1 | ||
|  | %	test	mysqltest_2	t2 | ||
|  | select host,db,user,table_name,column_name from mysql.columns_priv where user like 'mysqltest_%' order by host,db,user,table_name,column_name; | ||
|  | host	db	user	table_name	column_name | ||
|  | %	test	mysqltest_2	t2	c2 | ||
|  | show grants for 'mysqltest_1'; | ||
|  | Grants for mysqltest_1@% | ||
|  | GRANT USAGE ON *.* TO 'mysqltest_1'@'%' | ||
|  | show grants for 'mysqltest_2'; | ||
|  | Grants for mysqltest_2@% | ||
|  | GRANT SELECT ON *.* TO 'mysqltest_2'@'%' IDENTIFIED BY PASSWORD '*BD447CBA355AF58578D3AE33BA2E2CD388BA08D1' | ||
|  | GRANT INSERT ON "test".* TO 'mysqltest_2'@'%' | ||
|  | GRANT UPDATE (c2) ON "test"."t2" TO 'mysqltest_2'@'%' | ||
|  | GRANT UPDATE ON "test"."t1" TO 'mysqltest_2'@'%' | ||
|  | drop user 'mysqltest_1'; | ||
|  | select host,user,password from mysql.user where user like 'mysqltest_%' order by host,user,password; | ||
|  | host	user	password | ||
|  | %	mysqltest_2	*BD447CBA355AF58578D3AE33BA2E2CD388BA08D1 | ||
|  | %	mysqltest_3	fffffffffffffffffffffffffffffffffffffffff | ||
|  | select host,db,user from mysql.db where user like 'mysqltest_%' order by host,db,user; | ||
|  | host	db	user | ||
|  | %	test	mysqltest_2 | ||
|  | select host,db,user,table_name from mysql.tables_priv where user like 'mysqltest_%' order by host,db,user,table_name; | ||
|  | host	db	user	table_name | ||
|  | %	test	mysqltest_2	t1 | ||
|  | %	test	mysqltest_2	t2 | ||
|  | select host,db,user,table_name,column_name from mysql.columns_priv where user like 'mysqltest_%' order by host,db,user,table_name,column_name; | ||
|  | host	db	user	table_name	column_name | ||
|  | %	test	mysqltest_2	t2	c2 | ||
|  | show grants for 'mysqltest_1'; | ||
|  | ERROR 42000: There is no such grant defined for user 'mysqltest_1' on host '%' | ||
|  | rename user 'mysqltest_2' to 'mysqltest_1'; | ||
|  | select host,user,password from mysql.user where user like 'mysqltest_%' order by host,user,password; | ||
|  | host	user	password | ||
|  | %	mysqltest_1	*BD447CBA355AF58578D3AE33BA2E2CD388BA08D1 | ||
|  | %	mysqltest_3	fffffffffffffffffffffffffffffffffffffffff | ||
|  | select host,db,user from mysql.db where user like 'mysqltest_%' order by host,db,user; | ||
|  | host	db	user | ||
|  | %	test	mysqltest_1 | ||
|  | select host,db,user,table_name from mysql.tables_priv where user like 'mysqltest_%' order by host,db,user,table_name; | ||
|  | host	db	user	table_name | ||
|  | %	test	mysqltest_1	t1 | ||
|  | %	test	mysqltest_1	t2 | ||
|  | select host,db,user,table_name,column_name from mysql.columns_priv where user like 'mysqltest_%' order by host,db,user,table_name,column_name; | ||
|  | host	db	user	table_name	column_name | ||
|  | %	test	mysqltest_1	t2	c2 | ||
|  | show grants for 'mysqltest_1'; | ||
|  | Grants for mysqltest_1@% | ||
|  | GRANT SELECT ON *.* TO 'mysqltest_1'@'%' IDENTIFIED BY PASSWORD '*BD447CBA355AF58578D3AE33BA2E2CD388BA08D1' | ||
|  | GRANT INSERT ON "test".* TO 'mysqltest_1'@'%' | ||
|  | GRANT UPDATE (c2) ON "test"."t2" TO 'mysqltest_1'@'%' | ||
|  | GRANT UPDATE ON "test"."t1" TO 'mysqltest_1'@'%' | ||
|  | drop user 'mysqltest_1', 'mysqltest_3'; | ||
|  | drop user 'mysqltest_1'; | ||
|  | ERROR HY000: Operation DROP USER failed for 'mysqltest_1'@'%' | ||
|  | drop table t1, t2; | ||
|  | insert into mysql.db set user='mysqltest_1', db='%', host='%'; | ||
|  | flush privileges; | ||
|  | show grants for 'mysqltest_1'; | ||
|  | ERROR 42000: There is no such grant defined for user 'mysqltest_1' on host '%' | ||
|  | revoke all privileges, grant option from 'mysqltest_1'; | ||
|  | ERROR HY000: Can't revoke all privileges for one or more of the requested users | ||
|  | drop user 'mysqltest_1'; | ||
|  | select host,db,user from mysql.db where user = 'mysqltest_1' order by host,db,user; | ||
|  | host	db	user | ||
|  | insert into mysql.tables_priv set host='%', db='test', user='mysqltest_1', table_name='t1'; | ||
|  | flush privileges; | ||
|  | show grants for 'mysqltest_1'; | ||
|  | ERROR 42000: There is no such grant defined for user 'mysqltest_1' on host '%' | ||
|  | drop user 'mysqltest_1'; | ||
|  | select host,db,user,table_name from mysql.tables_priv where user = 'mysqltest_1' order by host,db,user,table_name; | ||
|  | host	db	user	table_name | ||
|  | insert into mysql.columns_priv set host='%', db='test', user='mysqltest_1', table_name='t1', column_name='c1'; | ||
|  | flush privileges; | ||
|  | show grants for 'mysqltest_1'; | ||
|  | ERROR 42000: There is no such grant defined for user 'mysqltest_1' on host '%' | ||
|  | drop user 'mysqltest_1'; | ||
|  | select host,db,user,table_name,column_name from mysql.columns_priv where user = 'mysqltest_1' order by host,db,user,table_name,column_name; | ||
|  | host	db	user	table_name	column_name | ||
|  | create user 'mysqltest_1', 'mysqltest_2', 'mysqltest_3'; | ||
|  | drop user 'mysqltest_1', 'mysqltest_2', 'mysqltest_3'; | ||
|  | create user 'mysqltest_1', 'mysqltest_2' identified by 'Mysqltest-2', 'mysqltest_3' identified by password 'fffffffffffffffffffffffffffffffffffffffff'; | ||
|  | rename user 'mysqltest_1' to 'mysqltest_1a', 'mysqltest_2' TO 'mysqltest_2a', 'mysqltest_3' TO 'mysqltest_3a'; | ||
|  | drop user 'mysqltest_1', 'mysqltest_2', 'mysqltest_3'; | ||
|  | ERROR HY000: Operation DROP USER failed for 'mysqltest_1'@'%','mysqltest_2'@'%','mysqltest_3'@'%' | ||
|  | drop user 'mysqltest_1a', 'mysqltest_2a', 'mysqltest_3a'; | ||
|  | create user 'mysqltest_1', 'mysqltest_2', 'mysqltest_3'; | ||
|  | create user 'mysqltest_1a', 'mysqltest_2', 'mysqltest_3a'; | ||
|  | ERROR HY000: Operation CREATE USER failed for 'mysqltest_2'@'%' | ||
|  | rename user 'mysqltest_1a' to 'mysqltest_1b', 'mysqltest_2a' TO 'mysqltest_2b', 'mysqltest_3a' TO 'mysqltest_3b'; | ||
|  | ERROR HY000: Operation RENAME USER failed for 'mysqltest_2a'@'%' | ||
|  | drop user 'mysqltest_1', 'mysqltest_2', 'mysqltest_3'; | ||
|  | drop user 'mysqltest_1b', 'mysqltest_2b', 'mysqltest_3b'; | ||
|  | ERROR HY000: Operation DROP USER failed for 'mysqltest_2b'@'%' | ||
|  | create user 'mysqltest_2' identified by 'Mysqltest-2'; | ||
|  | drop user 'mysqltest_2' identified by 'Mysqltest-2'; | ||
|  | 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 'identified by 'Mysqltest-2'' at line 1 | ||
|  | drop user 'mysqltest_2'; | ||
|  | create user '%@b'@'b'; | ||
|  | show grants for '%@b'@'b'; | ||
|  | Grants for %@b@b | ||
|  | GRANT USAGE ON *.* TO '%@b'@'b' | ||
|  | grant select on mysql.* to '%@b'@'b'; | ||
|  | show grants for '%@b'@'b'; | ||
|  | Grants for %@b@b | ||
|  | GRANT USAGE ON *.* TO '%@b'@'b' | ||
|  | GRANT SELECT ON "mysql".* TO '%@b'@'b' | ||
|  | rename user '%@b'@'b' to '%@a'@'a'; | ||
|  | show grants for '%@b'@'b'; | ||
|  | ERROR 42000: There is no such grant defined for user '%@b' on host 'b' | ||
|  | show grants for '%@a'@'a'; | ||
|  | Grants for %@a@a | ||
|  | GRANT USAGE ON *.* TO '%@a'@'a' | ||
|  | GRANT SELECT ON "mysql".* TO '%@a'@'a' | ||
|  | drop user '%@a'@'a'; | ||
|  | create user mysqltest_2@localhost; | ||
|  | grant create user on *.* to mysqltest_2@localhost; | ||
|  | select host,user,password from mysql.user where user like 'mysqltest_%' order by host,user,password; | ||
|  | ERROR 42000: SELECT command denied to user 'mysqltest_2'@'localhost' for table 'user' | ||
|  | create user mysqltest_A@'%'; | ||
|  | rename user mysqltest_A@'%' to mysqltest_B@'%'; | ||
|  | drop user mysqltest_B@'%'; | ||
|  | drop user mysqltest_2@localhost; | ||
|  | create user mysqltest_3@localhost; | ||
|  | grant INSERT,DELETE,UPDATE on mysql.* to mysqltest_3@localhost; | ||
|  | show grants; | ||
|  | Grants for mysqltest_3@localhost | ||
|  | GRANT USAGE ON *.* TO 'mysqltest_3'@'localhost' | ||
|  | GRANT INSERT, UPDATE, DELETE ON `mysql`.* TO 'mysqltest_3'@'localhost' | ||
|  | select host,user,password from mysql.user where user like 'mysqltest_%' order by host,user,password; | ||
|  | ERROR 42000: SELECT command denied to user 'mysqltest_3'@'localhost' for table 'user' | ||
|  | insert into mysql.user set host='%', user='mysqltest_B'; | ||
|  | Warnings: | ||
|  | Warning	1364	Field 'ssl_cipher' doesn't have a default value | ||
|  | Warning	1364	Field 'x509_issuer' doesn't have a default value | ||
|  | Warning	1364	Field 'x509_subject' doesn't have a default value | ||
|  | create user mysqltest_A@'%'; | ||
|  | rename user mysqltest_B@'%' to mysqltest_C@'%'; | ||
|  | drop user mysqltest_C@'%'; | ||
|  | drop user mysqltest_A@'%'; | ||
|  | drop user mysqltest_3@localhost; | ||
|  | set @@sql_mode=''; | ||
|  | create database mysqltest_1; | ||
|  | create table mysqltest_1.t1 (i int); | ||
|  | insert into mysqltest_1.t1 values (1),(2),(3); | ||
|  | GRANT ALL ON mysqltest_1.t1 TO mysqltest_1@'127.0.0.0/255.0.0.0'; | ||
|  | show grants for current_user(); | ||
|  | Grants for mysqltest_1@127.0.0.0/255.0.0.0 | ||
|  | GRANT USAGE ON *.* TO 'mysqltest_1'@'127.0.0.0/255.0.0.0' | ||
|  | GRANT ALL PRIVILEGES ON `mysqltest_1`.`t1` TO 'mysqltest_1'@'127.0.0.0/255.0.0.0' | ||
|  | select * from t1; | ||
|  | i | ||
|  | 1 | ||
|  | 2 | ||
|  | 3 | ||
|  | REVOKE ALL ON mysqltest_1.t1 FROM mysqltest_1@'127.0.0.0/255.0.0.0'; | ||
|  | delete from mysql.user where user like 'mysqltest\_1'; | ||
|  | flush privileges; | ||
|  | drop table mysqltest_1.t1; | ||
|  | grant all on mysqltest_1.* to mysqltest_1@'127.0.0.1'; | ||
|  | select current_user(); | ||
|  | current_user() | ||
|  | mysqltest_1@127.0.0.1 | ||
|  | set password = password('changed'); | ||
|  | select host, length(password) from mysql.user where user like 'mysqltest\_1'; | ||
|  | host	length(password) | ||
|  | 127.0.0.1	41 | ||
|  | revoke all on mysqltest_1.* from mysqltest_1@'127.0.0.1'; | ||
|  | delete from mysql.user where user like 'mysqltest\_1'; | ||
|  | flush privileges; | ||
|  | grant all on mysqltest_1.* to mysqltest_1@'127.0.0.0/255.0.0.0'; | ||
|  | select current_user(); | ||
|  | current_user() | ||
|  | mysqltest_1@127.0.0.0/255.0.0.0 | ||
|  | set password = password('changed'); | ||
|  | select host, length(password) from mysql.user where user like 'mysqltest\_1'; | ||
|  | host	length(password) | ||
|  | 127.0.0.0/255.0.0.0	41 | ||
|  | revoke all on mysqltest_1.* from mysqltest_1@'127.0.0.0/255.0.0.0'; | ||
|  | delete from mysql.user where user like 'mysqltest\_1'; | ||
|  | flush privileges; | ||
|  | drop database mysqltest_1; | ||
|  | set password = password("changed"); | ||
|  | ERROR 42000: Access denied for user ''@'localhost' to database 'mysql' | ||
|  | lock table mysql.user write; | ||
|  | flush privileges; | ||
|  | grant all on *.* to 'mysqltest_1'@'localhost'; | ||
|  | unlock tables; | ||
|  | lock table mysql.user write; | ||
|  | set password for 'mysqltest_1'@'localhost' = password(''); | ||
|  | revoke all on *.* from 'mysqltest_1'@'localhost'; | ||
|  | unlock tables; | ||
|  | drop user 'mysqltest_1'@'localhost'; | ||
|  | create database TESTDB; | ||
|  | create table t2(a int); | ||
|  | create temporary table t1 as select * from mysql.user; | ||
|  | delete from mysql.user where host='localhost'; | ||
|  | INSERT INTO mysql.user (host, user, password) VALUES | ||
|  | ('%','mysqltest_1',password('password')); | ||
|  | Warnings: | ||
|  | Warning	1364	Field 'ssl_cipher' doesn't have a default value | ||
|  | Warning	1364	Field 'x509_issuer' doesn't have a default value | ||
|  | Warning	1364	Field 'x509_subject' doesn't have a default value | ||
|  | INSERT INTO mysql.db (host, db, user, select_priv) VALUES | ||
|  | ('%','TESTDB','mysqltest_1','Y'); | ||
|  | FLUSH PRIVILEGES; | ||
|  | create database TEStdb; | ||
|  | Got one of the listed errors | ||
|  | delete from mysql.user; | ||
|  | delete from mysql.db where host='%' and user='mysqltest_1' and db='TESTDB'; | ||
|  | insert into mysql.user select * from t1; | ||
|  | drop table t1, t2; | ||
|  | drop database TESTDB; | ||
|  | flush privileges; | ||
|  | SET @old_log_bin_trust_function_creators= @@global.log_bin_trust_function_creators; | ||
|  | SET GLOBAL log_bin_trust_function_creators = 1; | ||
|  | GRANT ALL PRIVILEGES ON test.* TO `a@`@localhost; | ||
|  | GRANT EXECUTE ON * TO `a@`@localhost; | ||
|  | CREATE TABLE t2 (s1 INT); | ||
|  | INSERT INTO t2 VALUES (1); | ||
|  | DROP FUNCTION IF EXISTS f2; | ||
|  | CREATE FUNCTION f2 () RETURNS INT | ||
|  | BEGIN DECLARE v INT; SELECT s1 FROM t2 INTO v; RETURN v; END// | ||
|  | SELECT f2(); | ||
|  | f2() | ||
|  | 1 | ||
|  | DROP FUNCTION f2; | ||
|  | DROP TABLE t2; | ||
|  | REVOKE ALL PRIVILEGES, GRANT OPTION FROM `a@`@localhost; | ||
|  | DROP USER `a@`@localhost; | ||
|  | SET @@global.log_bin_trust_function_creators= @old_log_bin_trust_function_creators; | ||
|  | drop database if exists mysqltest_1; | ||
|  | drop database if exists mysqltest_2; | ||
|  | drop user mysqltest_u1@localhost; | ||
|  | create database mysqltest_1; | ||
|  | create database mysqltest_2; | ||
|  | grant all on mysqltest_1.* to mysqltest_u1@localhost; | ||
|  | use mysqltest_2; | ||
|  | create table t1 (i int); | ||
|  | show create table mysqltest_2.t1; | ||
|  | ERROR 42000: SELECT command denied to user 'mysqltest_u1'@'localhost' for table 't1' | ||
|  | create table t1 like mysqltest_2.t1; | ||
|  | ERROR 42000: SELECT command denied to user 'mysqltest_u1'@'localhost' for table 't1' | ||
|  | grant select on mysqltest_2.t1 to mysqltest_u1@localhost; | ||
|  | show create table mysqltest_2.t1; | ||
|  | Table	Create Table | ||
|  | t1	CREATE TABLE `t1` ( | ||
|  |   `i` int(11) DEFAULT NULL | ||
|  | ) ENGINE=MyISAM DEFAULT CHARSET=latin1 | ||
|  | create table t1 like mysqltest_2.t1; | ||
|  | use test; | ||
|  | drop database mysqltest_1; | ||
|  | drop database mysqltest_2; | ||
|  | drop user mysqltest_u1@localhost; | ||
|  | grant all on `mysqltest\_%`.* to mysqltest_1@localhost with grant option; | ||
|  | grant usage on *.* to mysqltest_2@localhost; | ||
|  | create database mysqltest_1; | ||
|  | use mysqltest_1; | ||
|  | create table t1 (f1 int); | ||
|  | grant create on `mysqltest\_1`.* to mysqltest_2@localhost; | ||
|  | grant select on mysqltest_1.t1 to mysqltest_2@localhost; | ||
|  | create database mysqltest_3; | ||
|  | ERROR 42000: Access denied for user 'mysqltest_2'@'localhost' to database 'mysqltest_3' | ||
|  | use mysqltest_1; | ||
|  | create table t2(f1 int); | ||
|  | select * from t1; | ||
|  | f1 | ||
|  | drop database mysqltest_1; | ||
|  | revoke all privileges, grant option from mysqltest_1@localhost; | ||
|  | revoke all privileges, grant option from mysqltest_2@localhost; | ||
|  | drop user mysqltest_1@localhost; | ||
|  | drop user mysqltest_2@localhost; | ||
|  | CREATE DATABASE db1; | ||
|  | USE db1; | ||
|  | CREATE TABLE t1 (a INT, b INT); | ||
|  | INSERT INTO t1 VALUES (1,1),(2,2); | ||
|  | CREATE TABLE t2 (b INT, c INT); | ||
|  | INSERT INTO t2 VALUES (1,100),(2,200); | ||
|  | GRANT SELECT ON t1 TO mysqltest1@localhost; | ||
|  | GRANT SELECT (b) ON t2 TO mysqltest1@localhost; | ||
|  | USE db1; | ||
|  | SELECT c FROM t2; | ||
|  | ERROR 42000: SELECT command denied to user 'mysqltest1'@'localhost' for column 'c' in table 't2' | ||
|  | SELECT * FROM t2; | ||
|  | ERROR 42000: SELECT command denied to user 'mysqltest1'@'localhost' for table 't2' | ||
|  | SELECT * FROM t1 JOIN t2 USING (b); | ||
|  | ERROR 42000: SELECT command denied to user 'mysqltest1'@'localhost' for column 'c' in table 't2' | ||
|  | USE test; | ||
|  | DROP TABLE db1.t1, db1.t2; | ||
|  | DROP USER mysqltest1@localhost; | ||
|  | DROP DATABASE db1; | ||
|  | End of 5.0 tests | ||
|  | USE mysql; | ||
|  | SELECT LEFT(CURRENT_USER(),INSTR(CURRENT_USER(),'@')-1) INTO @u; | ||
|  | SELECT MID(CURRENT_USER(),INSTR(CURRENT_USER(),'@')+1)  INTO @h; | ||
|  | SELECT password FROM user WHERE user=@u AND host=@h INTO @pwd; | ||
|  | SELECT user,host,password,insert_priv FROM user WHERE user=@u AND host=@h; | ||
|  | user	host	password	insert_priv | ||
|  | root	localhost		Y | ||
|  | UPDATE user SET insert_priv='N' WHERE user=@u AND host=@h; | ||
|  | SELECT user,host,password,insert_priv FROM user WHERE user=@u AND host=@h; | ||
|  | user	host	password	insert_priv | ||
|  | root	localhost		N | ||
|  | GRANT INSERT ON *.* TO CURRENT_USER(); | ||
|  | SELECT user,host,password,insert_priv FROM user WHERE user=@u AND host=@h; | ||
|  | user	host	password	insert_priv | ||
|  | root	localhost		Y | ||
|  | UPDATE user SET insert_priv='N' WHERE user=@u AND host=@h; | ||
|  | GRANT INSERT ON *.* TO CURRENT_USER() IDENTIFIED BY 'keksdose'; | ||
|  | SELECT user,host,password,insert_priv FROM user WHERE user=@u AND host=@h; | ||
|  | user	host	password	insert_priv | ||
|  | root	localhost	*0BB7188CF0DE9B403BA66E9DD810D82652D002EB	Y | ||
|  | UPDATE user SET password=@pwd WHERE user=@u AND host=@h; | ||
|  | SELECT user,host,password,insert_priv FROM user WHERE user=@u AND host=@h; | ||
|  | user	host	password	insert_priv | ||
|  | root	localhost		Y | ||
|  | FLUSH PRIVILEGES; | ||
|  | USE test; | ||
|  | End of 5.1 tests |