创建MySql用户并给用户授权,设置mariadb默认编码,修改mariadb数据存储目录datadir...
GRANT ALL PRIVILEGES ON 數據庫名.* TO '用戶名'@'登錄地址' IDENTIFIED BY '密碼' WITH GRANT OPTION;
FLUSH PRIVILEGES;
如果是僅限本機登錄,登錄地址為localhost,如果任意地址都可以登錄,則為%
數據庫名為*表示所有的數據庫都有權限,也可以指定具體的某個表。
?#重要:
在centos7上安裝 mariadb后,使用以上語句創建用戶后登錄失敗。原因是mariadb不允許空密碼的用戶。需要刪除掉數據庫中密碼為空字符串的用戶,然后再flush下即可:
select host,user,password from mysql.user;
delete from mysql.user where password ='';
flush privileges;
?
退出當前session,重新登錄下試試看,就可以工作了
?
#設置mariadb服務器的默認編碼
SET character_set_server = 'utf8';SET collation_server = 'utf8_general_ci';
?#設置數據存儲目錄datadir
啟動mariadb后如果再想修改datadir目錄的話會比較麻煩:
1.先停止服務
systemctl stop mariadb.service
?
2.拷貝目錄:
rsync -av /var/lib/mysql /home/ksi/mariadb/data
3.拷貝配置文件并修改:
?cp /usr/share/mysql/my-huge.cnf?/etc/my.cnf.d/
mv?/etc/my.cnf.d/server.cnf?/etc/my.cnf.d/server.cnf.bak
mv /etc/my.cnf.d/my-huge.cnf?/etc/my.cnf.d/server.cnf
vim /etc/my.cnf.d/server.cnf
修改或增加datadir:
# The following options will be passed to all MySQL clients
[client]
#password = your_password
port = 3306
socket = /home/ksi/mariadb/mysql.sock
# Here follows entries for some specific programs
# The MySQL server
[mysqld]
#skip-grant-tables
datadir = /home/ksi/mariadb/data
character_set_server=utf8
port = 3306
socket = /home/ksi/mariadb/mysql.sock
保存退出。
3.修改目錄權限:
chown -R mysql:mysql /home/ksi/mariadb
4.使用下列命令安裝
mysql_install_db --user=mysql --datadir=/home/ksi/mariadb/data
5.修改啟動腳本:
vim /usr/lib/systemd/system/mariadb.service
找到這個項:
ProtectHome
修改為false。保存退出。這一步如果不修改的話,會導致使用systemctl 啟動mariadb服務失敗。
6.啟動mariadb:
systemctl start mariadb.service
7.檢查datadir:
select @@datadir;
@@datadir
/home/ksi/mariadb/data/
?
?
?
?
?
總結
以上是生活随笔為你收集整理的创建MySql用户并给用户授权,设置mariadb默认编码,修改mariadb数据存储目录datadir...的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: EF Code First 学习笔记:关
- 下一篇: Android 条码扫描程序源码