mirror of
				https://github.com/MariaDB/server.git
				synced 2025-11-03 14:33:32 +03:00 
			
		
		
		
	tables requires privileges for them if some table or column level grants present" (with after-review fixes). We should set SELECT_ACL for implicitly opened tables in my_tz_check_n_skip_implicit_tables() to be able to bypass privilege checking in check_grant(). Also we should exclude those tables from privilege checking in multi-update.
		
			
				
	
	
		
			36 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			36 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
/* Copyright (C) 2000 MySQL AB & MySQL Finland AB & TCX DataKonsult AB
 | 
						|
   
 | 
						|
   This program is free software; you can redistribute it and/or modify
 | 
						|
   it under the terms of the GNU General Public License as published by
 | 
						|
   the Free Software Foundation; either version 2 of the License, or
 | 
						|
   (at your option) any later version.
 | 
						|
   
 | 
						|
   This program is distributed in the hope that it will be useful,
 | 
						|
   but WITHOUT ANY WARRANTY; without even the implied warranty of
 | 
						|
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | 
						|
   GNU General Public License for more details.
 | 
						|
   
 | 
						|
   You should have received a copy of the GNU General Public License
 | 
						|
   along with this program; if not, write to the Free Software
 | 
						|
   Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA */
 | 
						|
 | 
						|
 | 
						|
/* Execute DO statement */
 | 
						|
 | 
						|
#include "mysql_priv.h"
 | 
						|
 | 
						|
int mysql_do(THD *thd, List<Item> &values)
 | 
						|
{
 | 
						|
  List_iterator<Item> li(values);
 | 
						|
  Item *value;
 | 
						|
  DBUG_ENTER("mysql_do");
 | 
						|
  if (setup_fields(thd, 0, 0, values, 0, 0, 0))
 | 
						|
    DBUG_RETURN(-1);
 | 
						|
  while ((value = li++))
 | 
						|
    value->val_int();
 | 
						|
  free_underlaid_joins(thd, &thd->lex->select_lex);
 | 
						|
  thd->clear_error(); // DO always is OK
 | 
						|
  send_ok(thd);
 | 
						|
  DBUG_RETURN(0);
 | 
						|
}
 |