首頁 >php教程 >PHP开发 >mysql 指令總結

mysql 指令總結

高洛峰
高洛峰原創
2016-12-14 10:27:501175瀏覽

一、連接MySQL
 格式: mysql -h主機位址 -u使用者名稱 -p使用者密碼
1、例1:連接到本機上的MYSQL。
首先在打開DOS窗口,然後進入目錄mysqlbin,再鍵入指令mysql -uroot -p,回車後提示你輸密碼,如果剛安裝好MYSQL,超級用戶root是沒有密碼的,故直接回車即可進入到MYSQL中了,MYSQL的提示符號是: mysql>。
2、例2:連接到遠端主機上的MYSQL。假設遠端主機的IP為:110.110.110.110,使用者名稱為root,密碼為abcd123。則鍵入以下指令:
mysql -h110.110.110.110 -uroot -pabcd123
(註:u與root可以不用加空格,其它也一樣)
 3、退出MYSQL指令: exit (回車)。
二、修改密碼
格式:mysqladmin -u使用者名稱 -p舊密碼 password 新密碼

1、例1:給root加個密碼ab12。首先在DOS下進入目錄mysqlbin,然後鍵入以下指令:
mysqladmin -uroot -password ab12
註:因為一開始root沒有密碼,所以-p舊密碼一項就可以省略了。
2、例2:再將root的密碼改為djg345。
 mysqladmin -uroot -pab12 password djg345
 三、增加新使用者。 (注意:和上面不同,下面的因為是MySQL環境中的命令,所以後面都帶一個分號作為命令結束符)
格式:grant select on 資料庫.* to 用戶名@登入主機identified by "密碼"
例1.增加一個用戶test1密碼為abc,讓他可以在任何主機上登錄,並對所有資料庫有查詢、插入、修改、刪除的權限。先用以root用戶連入MySQL,然後鍵入以下指令:
grant select,insert,update,
delete on *.* to [email=test2@localhost]test2@localhost[/email] identified by "abc";
如果你不想test2有密碼,可以再打一個指令將密碼消掉。
 grant select,insert,update,delete on mydb
 .* to [email=test2@localhost]test2@localhost[/email] identified by "";
 在上面講了登入、增加使用者、密碼變更等問題。下面我們來看看MySQL中有關資料庫方面的操作。注意:你必須先登入MySQL中,以下操作都是在MySQL的提示符號下進行的,而且每個命令以分號結束。
1、MySQL常用指令
create database name; 建立資料庫
use databasename; 選擇資料庫
drop database name 直接刪除資料庫,不提醒
show tables; 顯示表
describe tablename 表格的詳細描述 刪除資料表的詳細描述。重複欄位
mysqladmin drop database name 刪除資料庫前,有提示。
顯示目前mysql版本和目前日期
select version(),current_date;
2、修改mysql中root的密碼:
shell>mysql -u root -p
mysql> update user set password=password(”xueok654133sql> update user set password=password(”xueok6541332) where user='root';
mysql> flush privileges //刷新資料庫
mysql>use dbname; 開啟資料庫:
mysql>show databases; 顯示所有資料庫
mysql>show tables; 顯示資料庫mysql中所有的表格:先mysqluse mysqluse mysqluse mysqluse ;然後
mysql>describe user; 顯示表mysql資料庫中user表的列資訊);
3、grant
創建一個可以從任何地方連接伺服器的一個完全的超級用戶,但是必須使用一個口令something做這個
mysql > grant all privileges on *.* to [email=user@localhost]user@localhost[/email] identified by 'something' with
增加新用戶
格式:grant select on 資料庫.* to 用戶名@登入主機identified by 「密碼」
GRANT ALL PRIVILEGES ON *.* TO [email=monty@localhost]monty@localhost[/email] IDENTIFIED BY 'something' WITH GRANT OPTION;
GR=ANT ALL PRIVILEGES ON *.* TO [email.* TO [email.* TO [email.* TO [email.* TO [email.* TO [email.* TO [email.* TO [email.* TO [email.* TO% E2%80%9D%]monty@”%[/email]” IDENTIFIED BY 'something' WITH GRANT OPTION;
刪除授權:
mysql> revoke all privileges on *.* from [email=root@%E2%80% 9D%]root@”%[/email]”;
mysql> delete from user where user=”root” and host=”%”;
mysql> flush privileges;
建立一個使用者custom在特定客戶端it363.com登錄,可存取特定資料庫fangchandb
mysql >grant select, insert, update, delete, create,drop on fangchandb.* to custom@ it363.com identified by ' passwd'
重命名表:
table t5 25 ;
4、mysqldump
備份資料庫
shell> mysqldump -h host -u root -p dbname >dbname_backup.sql
復原資料庫
shell> mysqladmin -h myhost -u root -p create name
shell> mysqladmin -h myhost -u root -p create name
> mynamed u root -p dbname 如果只想卸出建表指令,則指令如下:
shell> mysqladmin -u root -p -d databasename > a.sql
如果只想卸出插入資料的sql指令,而不需要建表命令,則命令如下:
shell> mysqladmin -u root -p -t databasename > a.sql
那麼如果我只想要數據,而不想要什麼sql命令時,應該如何操作呢?
   mysqldump -T./ phptest driver
其中,只有指定了-T參數才可以卸出純文本文件,表示卸出數據的目錄,./表示當前目錄,即與mysqldump同一目錄。如果不指定driver 表,則會解除整個資料庫的資料。每個表會產生兩個文件,一個為.sql文件,包含建表執行。另一個為.txt文件,只包含數據,且沒有sql指令。
5、可將查詢儲存在一個檔案中並告訴mysql從檔案中讀取查詢而不是等待鍵盤輸入。可利用外殼程式鍵入重定向實用程式來完成這項工作。例如,如果在檔案my_file.sql 中存放有查
詢,可如下執行這些查詢:
例如,如果您想要將建表語句提前寫在sql.txt中:
mysql > mysql -h myhost -u root -p database 1、安裝環境:
      Windows XP
      Mysql  可以使用mysql -h 172.5.1.183 -uroot 登陸,這個根據第二行的策略確定
    權限修改生效:
       1)net stop my binmysqladmin flush-privileges
       3)登陸mysql後,用flush privileges語句
6、建立資料庫staffer
    create database staffer;
7、下面的語句在mysql環境在執行
    顯示使用者擁有權限的資料庫    use staffer;
    顯示目前資料庫中有權限的表show tables;
    顯示表staffer的結構    desc staffer;
8、建立測試環境
    1)建立資料庫staffer
   ion, N0mysql> create 建立資料庫staffer
pos
      create table s_position
      (
          id int not null auto_increment,
         ion varchar(100),
          primary key PK_positon (id)   #設定主鍵
      );   
       );   
  table department
      (
          id int not null auto_increment,
          description varchar(100),
          primary key PK_department (id)   #設定主鍵
      ) ;
      create table depart_pos
      (
          department_id int not null,    primary key PK_depart_pos (department_id,position_id)   #設定複與主鍵
      );
     auto_increment primary key,   #設定主鍵
          name varchar(20) not null default '無名氏',   #設定預設值
    id int not null,
          unique (department_id,position_id)   #設定唯一值
      ) ;
    3)刪除
      mysql>
         drop table depart_pos;
    
         drop table staffer;
         drop database staffer;
9、修改結構
  table position add(test char(10));
    #表position修改列test
    alter table position modify test char(20) not null;
    #表position修改列testtesttest值 test  ';
    #表position去掉test預設值
    alter table position alter test drop default;
    #表position去掉列test
  alter table depart_pos drop primary key;
#表depart_pos增加主鍵
    alter table depart_pos add primary key PK_depart_pos (department_id,position_id);
10、操作資料
    # ;
    insert into department(name,description) values('公關部','公關部');
    insert into department(name,description) values('客服部','客服name,description) values('財務部','財務部');
    insert into department(name,description) values('測試部','測試部');
    #插入表s_position
)name. ,description) values('總監','總監');
    insert into s_position(name,description) values('經理','經理');
    insert into s_position(name,description) valuesert '一般員工');
    #插入表depart_pos
    insert into depart_pos(department_id,position_id)
    select a.id department_id,b.id postion_id🠎.
    insert into staffer(name ,department_id,position_id) values('陳達治',1,1);
    insert into staffer(name,department_id,position_id) values('李文賓',1,2);
 ('馬佳',1,3);
    insert into staffer(name,department_id,position_id) values('亢志強',5,1);
    insert into staffer(name,department_id,position_id. 4,1);
11、查詢及刪除作業
    #顯示系統部門的人員及職位
    select a.name,b.name department_name,c.name position_name
   from staffer a, . department_id=b.id and a.position_id=c.id and b.name='系統部';
    #顯示系統部的人數
    select count(*) from staffer a,department b
   select count(*) from staffer a,department b
  id and b.name='系統部'
    #顯示各部門的人數
    select count(*) cou,b.name
    from staffer a,department b ;
    #刪除客服部
    delete from department where name='客服部';
    #將財務部修改為財務一部
    update department set name='財務部門備份與復原
     備份資料庫staffer
      c:mysqlbinmysqldump -uroot -proot staffer>e:staffer.sql
    
     復原資料庫staffer,需要建立一個空庫staffer
      c:mysqlbinmysql -uroot -proot staffer   affer>e:staffer .sql
      mysql -uroot -proot >e:staffer.sql
      但這樣的話系統種不能存在staffer庫,且無法導入其他名字的資料庫,
     資料庫匯入資料
     1)使用工具c:mysqlbinmysqlimport
     這個工具的功能是將檔案匯入和去掉檔案副檔名名字相同的表裡,如
     staffer.txt,staffer都是導入staffer
     staffer.txt,staffer都是導入staffer
   功能如下
-d or --delete 新資料匯入資料表中先前刪除資料資料表中的所有資訊
-f or --force 不管是否遇到錯誤,mysqlimport將強制繼續插入資料
-i or --ignore mysqlimport跳過或忽略那些有相同唯一
關鍵字的行, 匯入檔案中的資料將被忽略。
-l or -lock-tables 資料插入之前鎖住表,這樣就防止了,
你在更新資料庫時,使用者的查詢和更新受到影響。
-r or -replace 這個選項與-i選項的作用相反;此選項將取代
表中有相同唯一關鍵字的記錄。
--fields-enclosed- by= char
指定文字檔案中資料的記錄時以什麼括起的, 很多情況下
資料以雙引號括起。 預設的情況下資料是沒有被字元括起的。
--fields-terminated- by=char
指定各個資料的值之間的分隔符,在句號分隔的檔案中,
分隔符是句號。您可以用此選項指定資料之間的分隔符號。
預設的分隔符號是跳格符(Tab)
--lines-terminated- by=str
此選項指定文字檔案中行與行之間資料的分隔字串
或字元。 預設的情況下mysqlimport以newline為行分隔符號。
您可以選擇用一個字串來取代一個單一的字元:
一個新行或一個回車。
mysqlimport指令常用的選項還有-v 顯示版本(version),
             -p 提示輸入密碼(password)等。
    這個工具有個問題,無法忽略某些列,這樣對我們的資料導入有很大的麻煩,雖然
    可以手動設定這個字段,但會出現莫名其妙的結果,我們做一個簡單的範例
    我們定義如下的depart_no.txt,保存在e盤,間隔為製表符t
10 10
11 11
12 24
執行如下命令
     c:mysqlbinmysqlimport -uroot -proot staffer etxtded.包圍符號,分割採用預設的t,因為採用別的符號會有問題,
     不知道是不是windows的原因
     2)Load Data INFILE file_name into table_name(column1_name,column2_name) 這個指令。都有問題,不知道是Windows的原因還是中文的問題,
     而且不指定的列它產生了空值,這顯然不是我們想要的,所以謹慎使用這些工具
進入MySQL:mysql -uuser -ppassword - -port=3307
1:使用SHOW語句找出在伺服器上目前存在什麼資料庫:
mysql> SHOW DATABASES;
2:2、建立一個資料庫MYSQLDATA
mysql> Create DATABASE MYSQLDATA;
3:選擇你所建立的資料庫
mysql> USE MYSQLDATA; (按回車鍵出現Database changed 時說明操作成功!)
4:查看現在的資料庫中存在什麼表
mysql> SHOW TABLES;
5:建立一個資料庫表
my> Create TABLELE MYTABLE (name VARCHAR(20), *** CHAR(1));
6:顯示表格的結構:
mysql> DESCRIBE MYTABLE;
7:往表中加入記錄
mysql> insert into MYTABLE values ("hyq"
mysql> insert into MYTABLE values ("hyq"
mysql> insert into MYTABLE values ("hyq" ,"M");
8:用文字方式將資料裝入資料庫表中(例如D:/mysql.txt)
mysql> LOAD DATA LOCAL INFILE "D:/mysql.txt" INTO TABLE MYTABLE;
9:導入.sql檔;
mysql>source d:/mysql.sql;
10:刪除表
mysql>drop TABLE MYTABLE;
11:清空表
mysql>drop TABLE MYTABLE;
11:清空表
mysql>drop TABLE MYTABLE;
11:清空表
mysql>drop TABLE MYTABLE;
11:清空表
mysql >delete from MYTABLE;
12:更新表中資料
UPDATE [LOW_PRIORITY] [IGNORE] tbl_name
  DATE [LOW_PRIORITY] [IGNORE] tbl_name
  expr2 ...]
    [WHERE where_definition]
    [ORDER BY ...]
    [LIMIT rows]
or
[ _name2= expr2 ...]
    [WHERE where_definition]
UPDATE 以新的值更新現存表中行的資料列。 SET 子句指出要修改哪個欄位和他們應該給定的值。 WHERE
      子句如果被給出,指定哪個記錄行應該更新。否則,所有的記錄行都被更新。如果 ORDER BY 子句被指定,記錄行將會以指定的順序更新。
      如果你指定關鍵字 LOW_PRIORITY,UPDATE 的執行將會延遲,直到沒有其它的客戶端正在讀取表。
      如果你指定關鍵字 IGNORE,更新語句將不會異常中止,即使更新過程中出現重複鍵錯誤。導致衝突的記錄行將不會被更新。
      如果在一個表達式中從 tbl_name 存取一個資料列,UPDATE 使用資料列的目前值。舉例來說,下面的語句設定 age 欄位值為它的目前值加 1 :
mysql> UPDATE persondata SET age=age+1;🎜UPDATE 賦值是從左到右計算的。舉例來說,下列語句將age 欄位設為它的兩倍,然後再加1 :
mysql> UPDATE persondata SET age=age*2, age=age+1;
如果你設定列為其目前的值, MySQL 注意到這一點,並沒有更新它。
      UPDATE 傳回實際被變更的記錄行數目。在 MySQL 3.22 或更新的版本中,C API 函數 mysql_info()
      傳回已配對且更新的記錄行數目,以及在 UPDATE 期間發生的警告的數目。
      在 MySQL 3.23 中,你可以使用 LIMIT # 來確保只有給定的記錄行數目被改變。
      如果一個 ORDER BY 子句被使用(從 MySQL 4.0.0 開始支援),記錄行將以指定的次序被更新。這其實只有連同 LIMIT
      才有用。
      從MySQL 4.0.4 開始,你也可以執行一個包含多個表的UPDATE 的操作:
UPDATE items,month SET items.price=month.price
WHERE items.id=month.id; UPDATE 不可以使用ORDER BY 或LIMIT。
關鍵字:   mysql   
啟動:net start mySql;
  進入:mysql -u root -p/mysql -h localhost -u root -p databaseName;🀜data  〜〜databaseName;列出表格:show tables;
  顯示表格列的屬性:show columns from tableName;
  建立資料庫:source fileName.txt;
  匹配字元:可以用通符_代表任何一個字元,%代表任何一個字串; :alter table tabelName add column fieldName dateType;
  增加多個欄位:alter table tabelName add column fieldName1 dateType,add columns fieldName2 dateType;
  資料行命令輸入多行命令欄位的字串展開到多行裡,否則硬回車將被儲存到資料中;
  增加一個管理員帳號:grant all on *.* to [email=user@localhost]user@localhost[/email] identified by "password";
  每條語句輸入完畢後要在末尾填加分號';',或者填加'g'也可以;
  查詢時間:select now();
  查詢當前用戶:select user(user() ;
  查詢資料庫版本:select version();
  查詢目前使用的資料庫:select database();
  1、刪除student_course資料庫中的students資料表:​​ 1、刪除student_course資料庫中的students資料表:  (將資料庫test備份)
  mysqldump -u root -p test>c:test.txt
  備份表格:(備份test資料庫下的mytable表格)
  mysqldump -u root -p test mytable>ctest.txt.備份資料匯入到資料庫:(導回test資料庫)
  mysql -u root -p test
  3、建立臨時表:(建立臨時表zengchao)
  create temporary table zengchao(name varchar(10));表是先判斷表是否存在
  create table if not exists students(……);
  5、從已經有的表中複製表的結構
 『create table table2 select * from table16,   create table table2 select * from table1;
  7、對表重新命名
  alter table table1 rename as table2;
  8、修改列的類型🀎 unsigned
  alter table table1 change id sid int unsigned;//修改列id的名字為sid,而且把屬性修改為int unsigned
  9、建立索引
  alter tabletable table1 液(id);
  create unique index ind_id on table1 (id);//建立唯一性索引
  10、刪除索引
  drop index idx_id on table1;
  drop indexidx_id on table1;多個列(將列id與":"和列name和"="連接)
  select concat(id,':',name,'=') from students;
  12、limit(選出10到20條)
  select * from students order by id limit 9,10;
  13、MySQL不支援的功能
  事務,視圖,外鍵和引用完整性,儲存過程和觸發器
  事務,視圖,外鍵與觸發完整性,儲存過程和觸發器14、 MySQL會使用索引的操作符號
  =,>,=,between,in,不帶%或_開頭的like
  15、使用索引的缺點
  1)減慢增改資料的速度;
  2)佔用磁碟空間;
  3)增加查詢優化器的負擔;
  當查詢優化器產生執行計劃時,會考慮索引,太多的索引會給查詢優化器增加工作量,導致無法選擇最優的優化器產生執行計劃時,會考慮索引,太多的索引會給查詢優化器增加工作量,導致無法選擇最優的查詢方案;
  16、分析索引效率
  方法:在一般的SQL語句前加上explain;
  分析結果的意義:
  1)table:表名;
  2)type:連結的類型,(ALL/Range/Ref)。其中ref是最理想的;
  3)possible_keys:查詢可以利用的索引名;
  4)key:實際使用的索引;
  5)key_len:索引中被使用部分的長度(字節);  5)key_len:索引中被使用部分的長度(字節); :顯示列名字或"const"(不懂什麼意思);
  7)rows:顯示MySQL認為在找到正確結果之前必須掃描的行數;
  8)extra:MySQL的建議;
  17、使用較短的定長列
  1)盡可能使用較短的資料型別;
  2)盡可能使用定長資料型別;
  a)用char取代varchar,固定長度的資料處理比變長的快些;
  b)對於變長的快些;
  b)對於變長的快一些;頻繁修改的表,磁碟容易形成碎片,從而影響資料庫的整體效能;
  c)萬一出現資料表崩潰,使用固定長度資料行的表更容易重新建構。使用固定長度的資料行,每個記錄的起始位置都是固定記錄長度的倍數,可以很容易被偵測到,但是使用可變長度的資料行就不一定了;
  d)對於MyISAM類型的資料表,雖然轉換成固定長度的資料列可以提高效能,但是佔據的空間也大;
  18、使用not null和enum
  盡量將列定義為not null,這樣可使資料的出來更快,所需的空間更少,而且在查詢時,MySQL不需要檢查是否存在特例,即null值,從而優化查詢;
  如果一列只含有有限數目的特定值,如性別,是否有效或者入學年份等,在這種情況下應該考慮將其轉換為enum列的值,MySQL處理的更快,因為所有的enum值在系統內都是以標識數值來表示的;
  19、使用optimize table
  對於經常修改的表,容易產生碎片,使在查詢資料庫時必須讀取更多的磁碟區塊,降低查詢效能。具有可變長的表都存在磁碟碎片問題,這個問題對 blob資料類型更為突出,因為其尺寸變化非常大。可以透過使用optimize table來整理碎片,確保資料庫效能不會下降,優化那些受碎片影響的資料表。 optimize table可以用於MyISAM和BDB類型的資料表。實際上任何碎片整理方法都是用mysqldump來轉存資料表,然後使用轉存後的檔案並重新建置資料表;
  20、使用procedure analyse()
  可以使用procedure analyse()顯示最佳類型的建議,使用很簡單,在select語句後面加上procedure analyse()就可以了;例如:
  select * from students procedure analyse();
  select * from students procedure analyse(  select * from students procedure analyse(  select * from students procedure analyse(16,256); )不要建議含有多於16個值,或含有多於256位元組的enum類型,如果沒有限制,輸出可能會很長;
  21、使用查詢快取
  1)查詢快取的工作方式:
 第一次執行某條select語句時,伺服器會記住該查詢的文字內容和查詢結果,儲存在快取中,下次碰到這個語句時,直接從快取中傳回結果;當更新資料表後,資料表的任何快取查詢都變成無效的,並且會被丟棄。
  2)配置快取參數:
  變數:query_cache _type,查詢快取的操作模式。有3中模式,0:不緩存;1:快取查詢,除非與select sql_no_cache開頭;2:根據需要只緩存那些以select sql_cache開頭的查詢;query_cache_size:設定查詢快取的最大結果集的大小,比這個值大的不會被緩存。
  22、調整硬體
  1)在機器上裝更多的內存;
  2)增加更快的硬碟以減少I/O等待時間;
  尋道時間是決定性能的主要因素,逐字地移動磁頭是最字地移動磁頭是最字地移動磁頭慢的,一旦磁頭定位,從磁軌讀取很快;
  3)在不同的實體硬碟裝置上重新分配磁碟活動;
  如果可能,應將最繁忙的資料庫存放在不同的實體裝置上,這跟使用同一實體設備的不同分區是不同的,因為它們將爭用相同的實體資源(磁頭)。

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn