存儲過程definer
方法如下:
修改mysql 存儲過程的definer
修改mysql.proc表 的definer欄位
update mysql.proc set definer='root@%' where db='servant_591up'; UPDATE `mysql`.`proc` SET `definer`='root00@%' WHERE `db`='test' AND `name`='jjjj' AND `type`='PROCEDURE'; UPDATE `mysql`.`proc` SET `definer`='wtc_678869@%' WHERE `db`='servant_591up' AND `type`='PROCEDURE';
2.修改sql security
ALTER PROCEDURE www SQL SECURITY INVOKER ; ALTER PROCEDURE www SQL SECURITY DEFINER ;
(1)MySQL存儲過程是通過指定SQL SECURITY子句指定執行存儲過程的實際用戶;
(2)如果SQL SECURITY子句指定為DEFINER,存儲過程將使用存儲過程的DEFINER執行存儲過程,驗證調用存儲過程的用戶是否具有存儲過程的execute許可權和DEFINER用戶是否具有存儲過程引用的相關對象的許可權;
(3)如果SQL SECURITY子句指定為INVOKER,那麼MySQL將使用當前調用存儲過程的用戶執行此過程,並驗證用戶是否具有存儲過程的execute許可權和存儲過程引用的相關對象的許可權;
(4)如果不顯示的指定SQL SECURITY子句,MySQL默認將以DEFINER執行存儲過程。
3.執行存儲過程授權
GRANT EXECUTE ON test.* TO 'wtc'@'%'; GRANT CREATE ROUTINE,ALTER ROUTINE, SELECT,CREATE, INSERT, UPDATE, DELETE, EXECUTE ON test.* TO 'wtc'@'%' IDENTIFIED BY '111111'
CREATE ROUTINE : 創建存儲過程的許可權
ALTER ROUTINE : 修改存儲過程的許可權
4.刪除用戶
REVOKE all ON test.* FROM wtc@'%'
DELETE FROM user WHERE User='user_name' and Host='host_name';
FLUSH PRIVILEGES;
好文要頂關注我
Ⅱ MySQL儲存過程報1064錯誤
DELIMITER$$
CREATEDEFINER=CURRENT_USERPROCEDURE`NewProc3`()
BEGIN
DECLAREtableNameVARCHAR(20);
DECLAREsqlStatementVARCHAR(400);
END$$
DELIMITER;
DELIMITER修改mysql結束符。
默認以;為結束符,也就是檢測到;就會執行,但存儲過程顯然是一個整段,必須一起執行,單獨執行肯定報錯。
所以只有在執行存儲過程時先修改掉默認的結束符,等執行完後再改回去。
Ⅲ MySQL存儲過程無法使用可能的原因和解決方案mysql不能用存儲過程
MySQL存儲過程無法使用:可能的原因和解決方案
MySQL存儲過程是一種存儲在資料庫中、可重復使用的SQL代碼塊。它們可以大大簡化應用程序的代碼,提高資料庫操作的效率,但是在使用存儲過程的過程中,有時會遇到一些問題。本文將介紹MySQL存儲過程無法使用的可能原因及相關解決方案。
一、可能的原因
1.許可權問題
MySQL存儲過程需要特定的許可權才能正常運行。如果用戶許可權不足,則無法執行存儲過程。如果您正在使用MySQL 8.0之前的版本,需要確保在創建存儲過程時使用了「DEFINER」選項並指定了超級用戶。例如:
CREATE PROCEDURE my_procere()
BEGIN
— 存儲過程的代碼
END
DEFINER = ‘root’@’localhost’
請注意,該語句中的「root」應替換為具有足夠許可權的用戶,並且「localhost」應替換為資料庫所在的主機名。
2.語法錯誤
存儲過程中的語法錯誤也會導致無法執行。在創建存儲過程之前,請仔細檢查語法是否正確。您還可以使用MySQL的「DELIMITER」命令指定語句分隔符,如下所示:
DELIMITER $$
CREATE PROCEDURE my_procere()
BEGIN
— 存儲過程的代碼
END $$
DELIMITER ;
在上面的示例中,語句分隔符由默認的「;」更改為「$$」,以確保正確處理存儲過程中的所有語句。
3.存儲過程已存在
如果嘗試重新創建已存在的存儲過程,將會導致錯誤。在創建存儲過程之前,請檢查在相同名稱下是否已經存在一個相同的存儲過程。
4.不正確的參數
存儲過程需要參數才能執行。如果提供的參數不正確,存儲過程將無法正常執行。請確保提供與存儲過程定義匹配的參數。
二、解決方案
1.檢查許可權
如果存儲過程無法運行,請檢查您是否有足夠的許可權。如果不是,請聯系資料庫管理員以獲取必要的許可權。確保在創建存儲過程時指定了超級用戶。
2.檢查語法
在創建存儲過程之前,請仔細檢查定義的語法是否正確,並使用「DELIMITER」命令指定正確的語句分隔符。
3.檢查存儲過程是否存在
在創建存儲過程之前,請檢查是否存在具有相同名稱的存儲過程。
4.檢查參數
檢查提供給存儲過程的參數是否正確。
5.使用MySQL的錯誤日誌文件
MySQL的錯誤日誌文件記錄了MySQL伺服器的所有錯誤消息。如果存儲過程無法運行,可以檢查錯誤日誌文件以查找有關錯誤的詳細信息。在MySQL配置文件中指定錯誤日誌文件的位置:
[mysqld]
log_error=/var/log/mysql/error.log
在上面的示例中,錯誤日誌文件位於「/var/log/mysql/error.log」位置。
總結
MySQL存儲過程無法運行的原因可能是多種多樣的,但是在檢查和解決問題時,注意一些常見的問題,包括許可權問題,語法錯誤,存儲過程已存在和不正確的參數。在需要幫助時,請查閱MySQL文檔或尋求專業資料庫管理員的幫助。
Ⅳ mysql 存儲過程 definer可以刪除嗎
【存儲過程的許可權】
ALTER ROUTINE 編輯或刪除存儲過程
CREATE ROUTINE 創建存儲過程
EXECUTE運行存儲過程
【存儲過程的創建語法】
delimiter // -- 聲明分隔符(命令結束符)
create
definer = user@hostname | current_user
procere 存儲過程名 (參數)
comment '注釋'
sql security definer | invoker -- sql 的安全設置
begin
存儲過程的body