程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> MySQL綜合教程 >> MySQL學習筆記_4_MySQL創建數據表(下)

MySQL學習筆記_4_MySQL創建數據表(下)

編輯:MySQL綜合教程

MySQL學習筆記_4_MySQL創建數據表(下)




MySQL創建數據表(下)


 

五、數據表類型及存儲位置

1、MySQL與大多數數據庫不同,MySQL有一個存儲引擎概念。MySQL可以針對不同的存儲需求選擇不同的存儲引擎。

2、 showengines; #查看MySQL所支持的存儲引擎storageengine

3、 showvariables like 'table_type'; #查看默認數據表類型


 

MyISAM和InnoDB最常用的存儲引擎【表類型】

4、指定表類型【使用哪一個存儲引擎】:

createtable ...() engine = InnoDB;

注意:在一個數據庫中可以在創建數據表時指定不同的表類型,即同一個庫中可以有多個不同表類型的數據表存在


 

5、不同引擎的特點:

1)MyISAM表類型:

成熟穩定,易於管理,使用一種表格鎖定的機制,需要經常使用“optimizetable表名”來恢復機制所浪費的空間。

強調可以快速讀取操作。但是也有一些功能不支持。

2)InnoDB表類型:

支持一些MyISAM所不支持的功能

缺點:占用空間大,不支持全文索引

對比:

功能

MyISAM

InnoDB

事務處理功能

No

Yes

數據行鎖定

No

Yes

外鍵約束

No

Yes

表空間占用

0

相對大(最大2倍)

全文索引

0

0

存儲(/var/lib/mysql/)

3個文件(.frm存儲表結構

1個文件(.frm)

 

.MYD保存數據

 

 

.MYI保存索引)

 


 


 

六、MySQL默認字符集

1、MySQL支持的數據編碼

ASCII碼 #7個字符存儲

ISO-8859-1/latin1字符集 #西歐字符集,經常被程序員轉碼用,8位編碼

gb2312-80 #不推薦

...

GBK【95年】 #2字節,可以用,但是不推薦,雙字節編碼

GB18030【2000年發布】#數據庫支持比較少見


 

UTF-32 #4字節,不常用

USC-2 #2字節,Windows2000內部使用

UTF-16 #2/4字節編碼,JAVA,WindowsXP,WindowsNT內部使用

UTF-8 #1~4字節編碼,Unicode是互聯網與UNIX/Linux與MySQL服務器廣泛支持的字符集,強烈推薦

e.g. GBK2字節:namevarchar(12) 6個漢字

UTF-83字節:namevarchar(12) 4個漢字


 

2、MySQL服務器,數據庫,數據表,字段都可以指定不同的字符集,用“showcharacter set;”可用於查看MySQL支持的所有字符集

注意:數據庫中UTF-8在使用時為utf8


 

3、MySQL的字符集包括 #character字符

字符集【charset】:用來定義MySQL字符串的存儲方式

校對規則【collation】:用來定義MySQL字符串的比較方式

是一對多的關系:1個字符集可以對應多個校對規則

showcollation like 'gbk%'; #可用來查看gbk所對應的校對規則

showcollation; #可用來查看所有的校對規則,以ci結尾,表示大小寫不敏感,以cs結尾,大小寫敏感,以bin結尾表示以二進制比較


 

showvariables like 'character_set_server'; #查看服務器端字符集

showvariables like 'collation_server'; #查看服務器段校對規則


 

4、指定默認字符集與校對規則

createdatabase xsdemo default character gbk collategbk_chinese_ci; #指定數據庫默認字符集

create table t1(id int not null auto_increment primary key)engine=myisam default character set gbk collategbk_chinese_ci; #制定數據表的字符集


 

5、客戶端與服務器交互時

character_set_client #客戶端字符集

character_set_connection #連接字符集

character_set_result #返回結果字符集

通常情況下這三個字符集應該是相同的,才能使得數據傳輸是相同的,使用“setnames字符集”可以同時修改這三個的值。

alterdatabase character set utf8; #修改數據庫的字符集,alter修改,更改

altertable t1 character set utf8; #修改數據表的字符集

服務器的字符集就只能改配置文件了


 

6、備份數據庫

mysqldump-u root -p --default-character-set=gbk -d xsdemo >/home/xiaofang/backup.sql #dump傾倒;傾卸

7、還原數據庫

mysql-u root -p xsdemo < /home/xiaofang/backup.sql


 

七、修改表

altertable... #更多內容參見?Alter table;

e.g. altertable t1 add price double not null default 0.00;

altertable t1 add sex varchar(5) after name; #在姓名之後添加性別

altertable t1 add height double first; #在第一位置添加身高

altertable t1 modify sex char(3); #modify適用於改類型

altertable t1 change name username varchar(5);#change既可以更改字段名,又可以更改類型

altertable t1 rename users; #直接修改表名

altertable t1 drop age; #刪除字段

droptable if exists users; #刪除數據表

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved