1. 程式人生 > 其它 >淺析int(1) 和int(10) 有什麼區別、mysql的ZEROFILL屬性及其用途

淺析int(1) 和int(10) 有什麼區別、mysql的ZEROFILL屬性及其用途

這個問題是因為在資料庫伺服器中的mysql資料庫中的user的表中沒有許可權(也可以說沒有使用者),下面將記錄我遇到問題的過程及解決的方法。

  在搭建完LNMP環境後用Navicate連接出錯

  遇到這個問題首先到mysql所在的伺服器上用連線進行處理

  1、連線伺服器: mysql -u root -p

  2、看當前所有資料庫:show databases;

  3、進入mysql資料庫:use mysql;

  4、檢視mysql資料庫中所有的表:show tables;

  5、檢視user表中的資料:select Host, User,Password from user;

  6、修改user表中的Host:update user set Host='%' where User='root';

  7、最後重新整理一下:flush privileges;

#一定要記得在寫sql的時候要在語句完成後加上" ; "下面是圖示說明

      這個問題的話就是防火牆的埠沒有開啟,或者沒有放行

 

   這樣就可以解決了!

  

  遇到這個問題首先到mysql所在的伺服器上用連線進行處理

  連線伺服器: mysql -u root -p

  

  檢視當前所有資料庫:show databases;

  

  進入mysql資料庫:use mysql;

  

  檢視mysql資料庫中所有的表:show tables;

  

  檢視user表中的資料:select Host, User,Password from user;

  

  修改user表中的Host:update user set Host='%' where User='root';

  

  最後重新整理一下:flush privileges;

  

  重新在Navicate中測試一下:

  

 

第一種問題的解決辦法是:

在iptables中開放3306埠

 #/sbin/iptables -I INPUT -p tcp --dport 3306 -j ACCEPT

 #/etc/rc.d/init.d/iptables save  儲存:

 # service iptables restart  重啟生效

############################################################################################

iptables -I INPUT -p TCP -s 0.0.0.0/0 --dport 3306 -j ACCEPT    //我常用的在iptables中開放3306埠命令

第二種解決方法是:

設定遠端使用者訪問許可權:

 // 任何遠端主機都可以訪問資料庫

mysql> GRANT ALL PRIVILEGES ON *.* TO 'root'@'%'WITH GRANT OPTION;     

//需要輸入次命令使修改生效

mysql> FLUSH PRIVILEGES; 

//退出

mysql> EXIT     

第三種不解釋了.

(還有一種方法說是關閉伺服器防火牆:# service iptables stop  不建議使用這種方法,會引發未知的安全問題)

很明顯最後還是沒有解決,在網上的資料很多都是重複的,最後實在沒辦法,找了師兄幫忙才發現是阿里雲控制檯這邊的問題,說明自己思考的方向還是不對.具體的解決方法是:

開啟雲伺服器ECS

開啟左邊選單的例項

開啟例項最右邊的管理

開啟左邊選單的本例項安全組

開啟右邊的配置規則

右上角新增安全組規則

協議型別預設自定義,埠範圍:3306/3306,授權物件:0.0.0.0/0,其他預設就行

確定後重啟伺服器

連線OK!

轉載出處: https://blog.csdn.net/dabao87/article/details/80571877