The mysql.columns_priv table contains information about column-level privileges. The table can be queried and although it is possible to directly update it, it is best to use GRANT for setting privileges. 
Note that the MariaDB privileges occur at many levels. A user may be granted a privilege at the column level, but may still not have permission on a table level, for example. See privileges for a more complete view of the MariaDB privilege system.
The INFORMATION_SCHEMA.COLUMN_PRIVILEGES table derives its contents from mysql.columns_priv.
In MariaDB 10.4 and later, this table uses the Aria storage engine.
In MariaDB 10.3 and before, this table uses the MyISAM storage engine.
The mysql.columns_priv table contains the following fields:
| Field | Type | Null | Key | Default | Description | 
|---|---|---|---|---|---|
| Host | char(60) | NO | PRI | Host (together with User,Db,Table_nameandColumn_namemakes up the unique identifier for this record. | |
| Db | char(64) | NO | PRI | Database name (together with User,Host,Table_nameandColumn_namemakes up the unique identifier for this record. | |
| User | char(80) | NO | PRI | User (together with Host,Db,Table_nameandColumn_namemakes up the unique identifier for this record. | |
| Table_name | char(64) | NO | PRI | Table name (together with User,Db,HostandColumn_namemakes up the unique identifier for this record. | |
| Column_name | char(64) | NO | PRI | Column name (together with User,Db,Table_nameandHostmakes up the unique identifier for this record. | |
| Timestamp | timestamp | NO | CURRENT_TIMESTAMP | ||
| Column_priv | set('Select', 'Insert', 'Update', 'References') | NO | The privilege type. See Column Privileges for details. | 
The Acl_column_grants status variable, added in MariaDB 10.1.4, indicates how many rows the mysql.columns_priv table contains.
    © 2019 MariaDB
Licensed under the Creative Commons Attribution 3.0 Unported License and the GNU Free Documentation License.
    https://mariadb.com/kb/en/mysqlcolumns_priv-table/