日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

MySQL学习笔记_4_MySQL创建数据表(下)

發布時間:2025/3/17 数据库 14 豆豆
生活随笔 收集整理的這篇文章主要介紹了 MySQL学习笔记_4_MySQL创建数据表(下) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

MySQL創建數據表(下)



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

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



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

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



MyISAMInnoDB最常用的存儲引擎【表類型】

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

createtable ...() engine = InnoDB;

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



5、不同引擎的特點:

1MyISAM表類型:

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

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

2InnoDB表類型:

支持一些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 #不推薦

...

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

GB180302000年發布】#數據庫支持比較少見



UTF-32 #4字節,不常用

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

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

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

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; #刪除數據表

總結

以上是生活随笔為你收集整理的MySQL学习笔记_4_MySQL创建数据表(下)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。