mysql grant
本文实例,运行于 MySQL 5.0 及以上版本。 MySQL 赋予用户权限命令的简单式可概括为: grant 权限 on 数据库对象 to 用户 一、grant 普通数据用户,查询、插入、更新、删除 数据库中所有表数据的权利。 grant select on testdb. * to common_user@ ' % ' gra
本文实例,运行于 MySQL 5.0 及以上版本。
MySQL 赋予用户权限命令的简单格式可概括为:
<p><span>grant</span><span> 权限 </span><span>on</span><span> 数据库对象 </span><span>to</span><span> 用户</span></p>
一、grant 普通数据用户,查询、插入、更新、删除 数据库中所有表数据的权利。
<p><span>grant</span><span>select</span><span>on</span><span> testdb.</span><span>*</span><span>to</span><span> common_user@</span><span>'</span><span>%</span><span>'</span><span><br></span><span>grant</span><span>insert</span><span>on</span><span> testdb.</span><span>*</span><span>to</span><span> common_user@</span><span>'</span><span>%</span><span>'</span><span><br></span><span>grant</span><span>update</span><span>on</span><span> testdb.</span><span>*</span><span>to</span><span> common_user@</span><span>'</span><span>%</span><span>'</span><span><br></span><span>grant</span><span>delete</span><span>on</span><span> testdb.</span><span>*</span><span>to</span><span> common_user@</span><span>'</span><span>%</span><span>'</span></p>
或者,用一条 MySQL 命令来替代:
<p><span>grant</span><span>select</span><span>, </span><span>insert</span><span>, </span><span>update</span><span>, </span><span>delete</span><span>on</span><span> testdb.</span><span>*</span><span>to</span><span> common_user@</span><span>'</span><span>%</span><span>'</span></p>
二、grant 数据库开发人员,创建表、索引、视图、存储过程、函数。。。等权限。
grant 创建、修改、删除 MySQL 数据表结构权限。
<p><span>grant</span><span>create</span><span>on</span><span> testdb.</span><span>*</span><span>to</span><span> developer@</span><span>'</span><span>192.168.0.%</span><span>'</span><span>;<br></span><span>grant</span><span>alter</span><span>on</span><span> testdb.</span><span>*</span><span>to</span><span> developer@</span><span>'</span><span>192.168.0.%</span><span>'</span><span>;<br></span><span>grant</span><span>drop</span><span> on</span><span> testdb.</span><span>*</span><span>to</span><span> developer@</span><span>'</span><span>192.168.0.%</span><span>'</span><span>;</span></p>
grant 操作 MySQL 外键权限。
<p><span>grant</span><span>references</span><span>on</span><span> testdb.</span><span>*</span><span>to</span><span> developer@</span><span>'</span><span>192.168.0.%</span><span>'</span><span>;</span></p>
grant 操作 MySQL 临时表权限。
<p><span>grant</span><span>create</span><span>temporary</span><span> tables </span><span>on</span><span> testdb.</span><span>*</span><span>to</span><span> developer@</span><span>'</span><span>192.168.0.%</span><span>'</span><span>;</span></p>
grant 操作 MySQL 索引权限。
<p><span>grant</span><span>index</span><span>on</span><span> testdb.</span><span>*</span><span>to</span><span> developer@</span><span>'</span><span>192.168.0.%</span><span>'</span><span>;</span></p>
grant 操作 MySQL 视图、查看视图源代码 权限。
<p><span>grant</span><span>create</span><span>view</span><span>on</span><span> testdb.</span><span>*</span><span>to</span><span> developer@</span><span>'</span><span>192.168.0.%</span><span>'</span><span>;<br></span><span>grant</span><span> show </span><span> view</span><span>on</span><span> testdb.</span><span>*</span><span>to</span><span> developer@</span><span>'</span><span>192.168.0.%</span><span>'</span><span>;</span></p>
grant 操作 MySQL 存储过程、函数 权限。
<p><span>grant</span><span>create</span><span> routine </span><span>on</span><span> testdb.</span><span>*</span><span>to</span><span> developer@</span><span>'</span><span>192.168.0.%</span><span>'</span><span>; </span><span>--</span><span> now, can show procedure status</span><span><br></span><span>grant</span><span>alter</span><span> routine </span><span>on</span><span> testdb.</span><span>*</span><span>to</span><span> developer@</span><span>'</span><span>192.168.0.%</span><span>'</span><span>; </span><span>--</span><span> now, you can drop a procedure</span><span><br></span><span>grant</span><span>execute</span><span>on</span><span> testdb.</span><span>*</span><span>to</span><span> developer@</span><span>'</span><span>192.168.0.%</span><span>'</span><span>;</span></p>
三、grant 普通 DBA 管理某个 MySQL 数据库的权限。
<p><span>grant</span><span>all</span><span>privileges</span><span>on</span><span> testdb </span><span>to</span><span> dba@</span><span>'</span><span>localhost</span><span>'</span></p>
其中,关键字 “privileges” 可以省略。
四、grant 高级 DBA 管理 MySQL 中所有数据库的权限。
<p><span>grant</span><span>all</span><span>on</span><span>*</span><span>.</span><span>*</span><span>to</span><span> dba@</span><span>'</span><span>localhost</span><span>'</span></p>
五、MySQL grant 权限,分别可以作用在多个层次上。
1. grant 作用在整个 MySQL 服务器上:
<p><span>grant</span><span>select</span><span>on</span><span>*</span><span>.</span><span>*</span><span>to</span><span> dba</span><span>@localhost</span><span>; </span><span>--</span><span> dba 可以查询 MySQL 中所有数据库中的表。</span><span><br></span><span>grant</span><span>all</span><span>on</span><span>*</span><span>.</span><span>*</span><span>to</span><span> dba</span><span>@localhost</span><span>; </span><span>--</span><span> dba 可以管理 MySQL 中的所有数据库</span></p>
2. grant 作用在单个数据库上:
<p><span>grant</span><span>select</span><span>on</span><span> testdb.</span><span>*</span><span>to</span><span> dba</span><span>@localhost</span><span>; </span><span>--</span><span> dba 可以查询 testdb 中的表。</span></p>
3. grant 作用在单个数据表上:
<p><span>grant</span><span>select</span><span>, </span><span>insert</span><span>, </span><span>update</span><span>, </span><span>delete</span><span>on</span><span> testdb.orders </span><span>to</span><span> dba</span><span>@localhost</span><span>;</span></p>
这里在给一个用户授权多张表时,可以多次执行以上语句。例如:
<p><span>grant</span><span>select</span><span>(</span><span>user_id</span><span>,username) </span><span>on</span><span> smp.users </span><span>to</span><span> mo_user@</span><span>'</span><span>%</span><span>'</span><span> identified </span><span>by</span><span>'</span><span>123345</span><span>'</span><span>;<br></span><span>grant</span><span>select</span><span>on</span><span> smp.mo_sms </span><span>to</span><span> mo_user@</span><span>'</span><span>%</span><span>'</span><span> identified </span><span>by</span><span>'</span><span>123345</span><span>'</span><span>;</span></p>
4. grant 作用在表中的列上:
<p><span>grant</span><span>select</span><span>(id, se, rank) </span><span>on</span><span> testdb.apache_log </span><span>to</span><span> dba</span><span>@localhost</span><span>;</span></p>
5. grant 作用在存储过程、函数上:
<p><span>grant</span><span>execute</span><span>on</span><span>procedure</span><span> testdb.pr_add </span><span>to</span><span>'</span><span>dba</span><span>'</span><span>@</span><span>'</span><span>localhost</span><span>'</span><span><br></span><span>grant</span><span>execute</span><span>on</span><span>function</span><span> testdb.fn_add </span><span>to</span><span>'</span><span>dba</span><span>'</span><span>@</span><span>'</span><span>localhost</span><span>'</span></p>
六、查看 MySQL 用户权限
查看当前用户(自己)权限:
<p><span>show grants;</span></p>
查看其他 MySQL 用户权限:
<p><span>show grants </span><span>for</span><span> dba</span><span>@localhost</span><span>;</span></p>
七、撤销已经赋予给 MySQL 用户权限的权限。
revoke 跟 grant 的语法差不多,只需要把关键字 “to” 换成 “from” 即可:
<p><span>grant</span><span>all</span><span>on</span><span>*</span><span>.</span><span>*</span><span>to</span><span> dba</span><span>@localhost</span><span>;<br></span><span>revoke</span><span>all</span><span>on</span><span>*</span><span>.</span><span>*</span><span>from</span><span> dba</span><span>@localhost</span><span>;</span></p>
八、MySQL grant、revoke 用户权限注意事项
1. grant, revoke 用户权限后,该用户只有重新连接 MySQL 数据库,权限才能生效。
2. 如果想让授权的用户,也可以将这些权限 grant 给其他用户,需要选项 “grant option“
<p><span>grant</span><span>select</span><span>on</span><span> testdb.</span><span>*</span><span>to</span><span> dba</span><span>@localhost</span><span>with</span><span>grant</span><span>option</span><span>;</span></p>
这个特性一般用不到。实际中,数据库权限最好由 DBA 来统一管理。
*************************************************************************************************
遇到 SELECT command denied to user '用户名'@'主机名' for table '表名' 这种错误,解决方法是需要把吧后面的表名授权,即是要你授权核心数据库也要。
我遇到的是SELECT command denied to user 'my'@'%' for table 'proc',是调用存储过程的时候出现,原以为只要把指定的数据库授权就行了,什么存储过程、函数等都不用再管了,谁知道也要把数据库mysql的proc表授权
*************************************************************************************************
参考:http://zhidao.baidu.com/question/19633785.html
mysql授权表共有5个表:user、db、host、tables_priv和columns_priv。
授权表的内容有如下用途:
user表
user表列出可以连接服务器的用户及其口令,并且它指定他们有哪种全局(超级用户)权限。在user表启用的任何权限均是全局权限,并适用于所有数据库。例如,如果你启用了DELETE权限,在这里列出的用户可以从任何表中删除记录,所以在你这样做之前要认真考虑。
db表
db表列出数据库,而用户有权限访问它们。在这里指定的权限适用于一个数据库中的所有表。
host表
host表与db表结合使用在一个较好层次上控制特定主机对数据库的访问权限,这可能比单独使用db好些。这个表不受GRANT和REVOKE语句的影响,所以,你可能发觉你根本不是用它。
tables_priv表
tables_priv表指定表级权限,在这里指定的一个权限适用于一个表的所有列。
columns_priv表
columns_priv表指定列级权限。这里指定的权限适用于一个表的特定列。

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas



Dalam pangkalan data MySQL, hubungan antara pengguna dan pangkalan data ditakrifkan oleh kebenaran dan jadual. Pengguna mempunyai nama pengguna dan kata laluan untuk mengakses pangkalan data. Kebenaran diberikan melalui perintah geran, sementara jadual dibuat oleh perintah membuat jadual. Untuk mewujudkan hubungan antara pengguna dan pangkalan data, anda perlu membuat pangkalan data, membuat pengguna, dan kemudian memberikan kebenaran.

MySQL mempunyai versi komuniti percuma dan versi perusahaan berbayar. Versi komuniti boleh digunakan dan diubahsuai secara percuma, tetapi sokongannya terhad dan sesuai untuk aplikasi dengan keperluan kestabilan yang rendah dan keupayaan teknikal yang kuat. Edisi Enterprise menyediakan sokongan komersil yang komprehensif untuk aplikasi yang memerlukan pangkalan data yang stabil, boleh dipercayai, berprestasi tinggi dan bersedia membayar sokongan. Faktor yang dipertimbangkan apabila memilih versi termasuk kritikal aplikasi, belanjawan, dan kemahiran teknikal. Tidak ada pilihan yang sempurna, hanya pilihan yang paling sesuai, dan anda perlu memilih dengan teliti mengikut keadaan tertentu.

Penyederhanaan Integrasi Data: AmazonRDSMYSQL dan Integrasi Data Integrasi Zero ETL Redshift adalah di tengah-tengah organisasi yang didorong oleh data. Proses tradisional ETL (ekstrak, menukar, beban) adalah kompleks dan memakan masa, terutamanya apabila mengintegrasikan pangkalan data (seperti Amazonrdsmysql) dengan gudang data (seperti redshift). Walau bagaimanapun, AWS menyediakan penyelesaian integrasi ETL sifar yang telah mengubah keadaan ini sepenuhnya, menyediakan penyelesaian yang mudah, hampir-sebenar untuk penghijrahan data dari RDSMYSQL ke redshift. Artikel ini akan menyelam ke integrasi RDSMYSQL Zero ETL dengan redshift, menjelaskan bagaimana ia berfungsi dan kelebihan yang dibawa kepada jurutera dan pemaju data.

Untuk mengisi nama pengguna dan kata laluan MySQL: 1. Tentukan nama pengguna dan kata laluan; 2. Sambungkan ke pangkalan data; 3. Gunakan nama pengguna dan kata laluan untuk melaksanakan pertanyaan dan arahan.

1. Gunakan indeks yang betul untuk mempercepatkan pengambilan data dengan mengurangkan jumlah data yang diimbas memilih*frommployeesWherElast_name = 'Smith'; Jika anda melihat lajur jadual beberapa kali, buat indeks untuk lajur tersebut. Jika anda atau aplikasi anda memerlukan data dari pelbagai lajur mengikut kriteria, buat indeks komposit 2. Elakkan pilih * Hanya lajur yang diperlukan, jika anda memilih semua lajur yang tidak diingini, ini hanya akan memakan lebih banyak pelayan dan menyebabkan pelayan melambatkan pada masa yang tinggi atau kekerapan misalnya, jadual anda

Panduan Pengoptimuman Prestasi Pangkalan Data MySQL Dalam aplikasi yang berintensifkan sumber, pangkalan data MySQL memainkan peranan penting dan bertanggungjawab untuk menguruskan urus niaga besar-besaran. Walau bagaimanapun, apabila skala aplikasi berkembang, kemunculan prestasi pangkalan data sering menjadi kekangan. Artikel ini akan meneroka satu siri strategi pengoptimuman prestasi MySQL yang berkesan untuk memastikan aplikasi anda tetap cekap dan responsif di bawah beban tinggi. Kami akan menggabungkan kes-kes sebenar untuk menerangkan teknologi utama yang mendalam seperti pengindeksan, pengoptimuman pertanyaan, reka bentuk pangkalan data dan caching. 1. Reka bentuk seni bina pangkalan data dan seni bina pangkalan data yang dioptimumkan adalah asas pengoptimuman prestasi MySQL. Berikut adalah beberapa prinsip teras: Memilih jenis data yang betul dan memilih jenis data terkecil yang memenuhi keperluan bukan sahaja dapat menjimatkan ruang penyimpanan, tetapi juga meningkatkan kelajuan pemprosesan data.

Salin dan tampal di MySQL termasuk langkah -langkah berikut: Pilih data, salin dengan Ctrl C (Windows) atau Cmd C (Mac); Klik kanan di lokasi sasaran, pilih Paste atau gunakan Ctrl V (Windows) atau CMD V (MAC); Data yang disalin dimasukkan ke dalam lokasi sasaran, atau menggantikan data sedia ada (bergantung kepada sama ada data sudah ada di lokasi sasaran).

Lihat pangkalan data MySQL dengan arahan berikut: Sambungkan ke pelayan: MySQL -U Pengguna Nama -P Kata Laluan Run Show pangkalan data; Perintah untuk mendapatkan semua pangkalan data yang sedia ada Pilih pangkalan data: Gunakan nama pangkalan data; Lihat Jadual: Tunjukkan Jadual; Lihat Struktur Jadual: Huraikan nama jadual; Lihat data: pilih * dari nama jadual;
