簡介
使用MySQL 時,使用者可能會在使用MySQL到一條錯誤訊息,指示資料庫物件的定義者使用者不存在。此錯誤(代碼 1449)通常在從原始定義者使用者不再存在的另一個資料庫或伺服器匯入物件時發生。
原因
定義者使用者是使用者在其下方建立資料庫檢視、觸發器或流程。當資料庫物件匯入到另一個系統時,定義者使用者也必須存在於目標系統上。如果定義者使用者不存在,MySQL將拋出錯誤1449。
解
1。更改定義者
要解決此問題,您可以將定義者使用者變更為目標系統上存在的使用者。這可以在導入過程中透過從轉儲中刪除 DEFINER 語句來完成。
如果物件已匯入,您可以稍後使用下列步驟變更定義器:
對於檢視:
SELECT CONCAT("ALTER DEFINER=youruser@host VIEW ", table_name, " AS ", view_definition, ";") FROM information_schema.views WHERE table_schema='your-database-name';
對於預存程序:
UPDATE `mysql`.`proc` p SET definer = 'user@%' WHERE definer='root@%';
2。建立遺失的用戶
如果目標系統上不存在定義者用戶,您可以使用 GRANT 語句建立它。將「someuser」替換為缺少的使用者的名稱:
GRANT ALL ON *.* TO 'someuser'@'%' IDENTIFIED BY 'complex-password'; FLUSH PRIVILEGES;
其他注意事項
依照下列步驟,您可以解決錯誤 1449 並成功匯入或管理資料庫具有定義者使用者的物件。
以上是MySQL 錯誤 1449:如何修正「Definer 使用者不存在」問題?的詳細內容。更多資訊請關注PHP中文網其他相關文章!