Can a MySQL user have limiter delete, update permissions? - mysql

For a user in MySQL 5.6, can I limit the privileges to the point where the user can have delete, update privileges but
The user cannot update the whole table (no update without a where clause)
The user cannot delete the whole table (no delete without a where clause)

Related

Show roles and privileges for all users in MySQL 8.0

I am trying to create a query that will show the users, their roles, and their privileges in MySQL 8.0.
Users are stored in mysql.user table.
Roles are also stored in mysql.user table but in order to identify them we filter the query like this: SELECT * FROM mysql.user WHERE host = '%'AND LENGTH(AUTHENTICATION_STRING) = 0 \G. By default roles are applied globally ('%') and they have no password
so the length would be 0 (We use strong password policy so there are
no users with no password).
The privileges, can be seen by the commands: SHOW GRANTS FOR 'username'#'hostname'; and by SELECT * FROM mysql.columns_priv, SELECT * FROM mysql.procs_priv, SELECT * FROM mysql.tables_priv tables.
I don't thing that I am missing other tables with information about the privileges, I just need to join all the data together. Has anyone tried something similar like this ? Is there a simpler way?
I am currently studying MySQL, I haven't professional experience so any help would be appreciated!

About MySQL Table permission remove failure

My MySQL database version is 5.6.35 and I use InnoDB.
I want to remove the Delete and Drop Table permissions of the user U1 from the table T1 in the db1 database.
The operating instructions are as follows:
Revoke delete,drop on db1.T1 from U1;
No error message appeared after execution.
But after execution, the user U1 can still use the DELETE command to delete the data row in the data table T1.
You can also use the DROP TABLE command to delete the data table T1.
Thanks for replying.

MySQL: DELETE permission requires SELECT permission?

The user has INSERT and DELETE permissions but not SELECT permission. The user can write records but not read. When trying to "DELETE from my_table WHERE id=5" you get "#1143 select not allowed...". Is there a way to solve this?
Privileges
You need the DELETE privilege on a table to delete rows
from it. You need only the SELECT privilege for any columns that are
only read, such as those named in the WHERE clause.
source
Conclusion : If you use a where in the Delete you need the Select privilege too.

Get nearest index value in MySQL

so in order to restrict my app's user sql login I turned off create, drop, index, alter, tmp and lock. So, one of my tables will have rows deleted by the users, hence the index will most likely have a bunch of gaps, some being very large. I would just make the user re-index the table after a delete, but that would require me to enable drop and/or alter, which for security reasons I do not want to enable.
So now the user wants to access the index number 50 from this table but there's a gap from 48-54 for instance. How would I go about this?
Select * from my_table where id > 48 order by id limit 1

MySQL privileges applied for the triggers on a non-privileged user's action

I am creating a fresh schema for a new project, My basic requirements are 2 users with different privileges. One is a regular user and have minimum privileges and other is the administrator who have some elevated privileges than the regular user.
I am taking this scenario for the instance:
basicUser have INSERT Privilege over Table1 butNOPrivilege over Table2 and Table3
adminUser have INSERT Privilege over All the tables
Now, Table1 have a Trigger defined for INSERT option which INSERT the records into Table2 and Table3 taking the values from Table1 as soon as the record is inserted into table1.
I am wondering whether the trigger will work when basicUser insert the data into Table1 ?
Remember He can insert the data in Table1 but He have no privilege over other tables being populated by the trigger, and this trigger is raised by basicUser's action.
My first guess is Yes! This should work. but I am not sure. Please correct me if I am wrong.
If yes, then is there any way I can prevent the trigger's action if the record is inserted by basicUser ?
I'll need a fail-safe workaround because I still need Table1 to hold the record inserted by basicUser but I dont want it to insert the data into other tables.
and if No, Then is there any way I can log some of basicUser's action, bearing in mind that He have No privilege over the table which is being used for storing logs ?