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保存索引)
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; #刪除數據表