Execute Immediate within a stored procedure keeps giving insufficient priviliges error

Oracle’s security model is such that when executing dynamic SQL using Execute Immediate (inside the context of a PL/SQL block or procedure), the user does not have privileges to objects or commands that are granted via role membership. Your user likely has “DBA” role or something similar. You must explicitly grant “drop table” permissions to this user. The same would apply if you were trying to select from tables in another schema (such as sys or system) – you would need to grant explicit SELECT privileges on that table to this user.

Leave a Comment