- 工信部備案號 滇ICP備05000110號-1
- 滇公安備案 滇53010302000111
- 增值電信業務經營許可證 B1.B2-20181647、滇B1.B2-20190004
- 云南互聯網協會理事單位
- 安全聯盟認證網站身份V標記
- 域名注冊服務機構許可:滇D3-20230001
- 代理域名注冊服務機構:新網數碼
mysql安裝完之后,登陸后發現只有兩個數據庫:mysql>show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| test |
+--------------------+
,mysql> use mysql
ERROR 1044 (42000): Access denied for user''@'localhost' to database 'mysql'
訪問被拒絕,原因就是在刪除數據庫時(rpm -e mysql*)沒有刪除干凈,需要把/var/lib/mysql的目錄全部刪除干凈,然后再重新安裝即可。
順便記一下一些常用的命令:
一、連接MYSQL。
格式: mysql -h主機地址 -u用戶名-p用戶密碼
1、連接到本機上的MYSQL。
# mysql -u root -p
回車后提示你輸密碼,注意用戶名前可以有空格也可以沒有空格,但是密碼前必須沒有空格,否則讓你重新輸入密碼。
如果剛安裝好MYSQL,超級用戶root是沒有密碼的,故直接回車即可進入到MYSQL中了,MYSQL的提示符是: mysql>
2、連接到遠程主機上的MYSQL。假設遠程主機的IP為:192.168.2.2,用戶名為root,密碼為123456。則鍵入以下命令:
# mysql -h192.168.2.2 -uroot -p123456
3、退出MYSQL命令:
# exit (回車)
二、修改密碼。
格式:mysqladmin -u用戶名 -p舊密碼 password 新密碼
1、給root加個密碼123456。鍵入以下命令:
# mysqladmin -u root -password 123456
2、再將root的密碼改為56789。
# mysqladmin -u root -p123456 password56789
三、增加新用戶。
格式:grant select on 數據庫.* to 用戶名@登錄主機 identified by “密碼”
1、增加一個用戶test1密碼為abc,讓他可以在任何主機上登錄,并對所有數據庫有查詢、插入、修改、刪除的權限。首先用root用戶連入MYSQL,然后鍵入以下命令:
mysql>grant select,insert,update,deleteon *.* to test1@”%” Identified by “abc”;
mysql>flush privileges; 使之生效
2、增加一個用戶test2密碼為abc,讓他只可以在localhost上登錄,并可以對數據庫mydb進行查詢、插入、修改、刪除的操作(localhost指本地主機,即MYSQL數據庫所在的那臺主機),這樣用戶即使用知道test2的密碼,他也無法從internet上直接訪問數據庫,只能通過MYSQL主機上的web頁來訪問了。
mysql>grant select,insert,update,deleteon mydb.* to test2@localhost identified by “abc”;
mysql>flush privileges; 使之生效
如果你不想test2有密碼,可以再打一個命令將密碼消掉。
mysql>grant select,insert,update,deleteon mydb.* to test2@localhost identified by “”;
mysql>flush privileges; 使之生效
操作技巧
1、如果你打命令時,回車后發現忘記加分號,你無須重打一遍命令,只要打個分號回車就可以了。也就是說你可以把一個完整的命令分成幾行來打,完后用分號作結束標志就OK。
2、你可以使用光標上下鍵調出以前的命令。
查詢、創建、刪除、更新命令
1、顯示當前數據庫服務器中的數據庫列表:
mysql>show databases;
注意:mysql庫里面有MYSQL的系統信息,我們改密碼和新增用戶,實際上就是用這個庫進行操作。
2、顯示數據庫中的數據表:
mysql>use 庫名;
mysql>show tables;
3、顯示數據表的結構:
mysql>describe 表名;
4、建立數據庫:
mysql>create database 庫名;
5、建立數據表:
mysql>use 庫名;
mysql>create table 表名 (字段名varchar(20), 字段名 char(1));
6、刪除數據庫:
mysql>drop database 庫名;
7、刪除數據表:
mysql>drop table 表名;
8、將表中記錄清空:
mysql>delete from 表名;
9、顯示表中的記錄:
mysql>select * from 表名;
10、往表中插入記錄:
mysql>insert into 表名 values (”123”,”b”);
11、更新表中數據:
mysql>update 表名 set 字段名1='a',字段名2='b'where 字段名3='c';
12、用文本方式將數據裝入數據表中:
mysql>load data local infile “/root/mysql.txt” into table 表名;
13、導入.sql文件命令:
mysql>use 數據庫名;
mysql>source /root/mysql.sql;
14、命令行修改root密碼:
mysql>update mysql.user setpassword=PASSWORD('新密碼') where user='root';
mysql>flush privileges;
15、顯示use的數據庫名:
mysql>select database();
16、顯示當前的user:
mysql>select user();
備份數據庫
1.導出整個數據庫,導出文件默認是存在當前操作目錄下
# mysqldump -u 用戶名 -p 數據庫名 > 導出的文件名
# mysqldump -u user_name -p123456database_name > outfile_name.sql
2.導出一個表
# mysqldump -u 用戶名 -p 數據庫名 表名> 導出的文件名
# mysqldump -u user_name -p database_nametable_name > outfile_name.sql
3.導出一個數據庫結構
# mysqldump -u user_name -p -d–add-drop-table database_name > outfile_name.sql
-d 沒有數據 –add-drop-table 在每個create語句之前增加一個droptable
4.帶語言參數導出
# mysqldump -uroot -p –default-character-set=latin1–set-charset=gbk –skip-opt database_name > outfile_name.sql
查看不到mysql數據庫的解決辦法:
1.去/var/lib/mysql目錄下去查看,發現mysql以及mysql.sock目錄都在,還好還好,應該還有希望恢復;
2.停掉mysqld服務——“servicemysqld stop”
3.查看mysqld進程是否還在跑——“ps-aux | grep mysqld”,如果還有在跑得進程,可以直接殺之“killall -TERM mysqld”
4.安全模式啟動mysql;“mysqld_safe--user=mysql --skip-grant-tables --skip-networking &”
5.另起終端,輸入“mysql -u root-p”,進入mysql數據庫
6.show databases;看到mysql庫又出現了
7.更改root用戶密碼:usemysql;update user set password=PASSWORD(“new-passwd”)whereuser='root';
8.FLUSH PRIVILEGES;
售前咨詢
售后咨詢
備案咨詢
二維碼
TOP