隨筆-16  評論-8  文章-30  trackbacks-0
          (流傳較廣的方法,mysql中文參考手冊上的)
          1. 向mysqld server 發送kill命令關掉mysqld server(不是 kill -9),存放進程ID的文件通常在MYSQL的數據庫所在的目錄中。
          killall -TERM mysqld
          你必須是UNIX的root用戶或者是你所運行的SERVER上的同等用戶,才能執行這個操作。
          2. 使用`--skip-grant-tables' 參數來啟動 mysqld。 (LINUX下/usr/bin/safe_mysqld --skip-grant-tables , windows下c:\mysql\bin\mysqld --skip-grant-tables)

          3. 然后無密碼登錄到mysqld server ,
          >use mysql
          >update user set password=password("new_pass") where user="root";
          >flush privileges;
          。你也可以這樣做:`mysqladmin -h hostname -u user password 'new password''。

          4. 載入權限表: `mysqladmin -h hostname flush-privileges' ,或者使用 SQL 命令`FLUSH PRIVILEGES'。
          5.killall -TERM mysqld
          6.用新密碼登陸

          修正一下:我在Windows下的實際操作如下
          1.關閉正在運行的MySQL。
          2.打開DOS窗口,轉到mysql\bin目錄。
          3.輸入mysqld-nt --skip-grant-tables回車。如果沒有出現提示信息,那就對了。
          4.再開一個DOS窗口(因為剛才那個DOS窗口已經不能動了),轉到mysql\bin目錄。
          5.輸入mysql回車,如果成功,將出現MySQL提示符 >
          6. 連接權限數據庫>use mysql; (>是本來就有的提示符,別忘了最后的分號)
          6.改密碼:> update user set password=password("123456") where user="root"; (別忘了最后的分號)
          7.刷新權限(必須的步驟)>
          flush privileges;
          8.退出 > \q
          9
          .注銷系統,再進入,開MySQL,使用用戶名root和剛才設置的新密碼123456登陸。

          據說可以用直接修改user表文件的方法:
          關閉MySQL,Windows下打開Mysql\data\mysql,有三個文件user.frm,user.MYD,user.MYI找個知道密碼的MySQL,替換相應的這三個文件,如果user表結構沒改過,一般也沒人去改,替換user.MYD就可以了。
          也可以直接編輯user.MYD,找個十六進制編輯器,UltraEdit就有這個功能。關閉MySQL,打開user.MYD。將用戶名root后面的八個字符改為565491d704013245,新密碼就是123456。或者將它們對應的十六進制數字,(左邊那里,一個字符對應兩個數字),改為 00 02 02 02 02 02 02 02,這就是空密碼,在編輯器右邊看到的都是星號*,看起來很象小數點。重開MySQL,輸入root和你的新密碼。
          posted on 2005-06-11 13:49 楚客 閱讀(1046) 評論(0)  編輯  收藏 所屬分類: PHP
          主站蜘蛛池模板: 沾化县| 旅游| 望江县| 宁陕县| 乌拉特前旗| 漳平市| 白城市| 吉首市| 策勒县| 右玉县| 莱西市| 卫辉市| 永城市| 德庆县| 冕宁县| 新郑市| 上杭县| 乌拉特中旗| 平阳县| 齐齐哈尔市| 大埔县| 蒙城县| 库尔勒市| 高清| 京山县| 盱眙县| 拉萨市| 西充县| 乌拉特前旗| 图片| 驻马店市| 高平市| 罗江县| 彩票| 都昌县| 南澳县| 玉门市| 油尖旺区| 进贤县| 章丘市| 福建省|