目录
MySQL创建数据表(下) 
五、数据表类型及存储位置
六、MySQL默认字符集
七、修改表
首页 数据库 mysql教程 MySQL学习笔记_4_MySQL创建数据表(下)_MySQL

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

Jun 01, 2016 pm 01:19 PM
数据库 数据表

bitsCN.com

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

七、修改表

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; #删除数据表

bitsCN.com
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

<🎜>:泡泡胶模拟器无穷大 - 如何获取和使用皇家钥匙
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
北端:融合系统,解释
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

热门话题

Java教程
1664
14
CakePHP 教程
1423
52
Laravel 教程
1318
25
PHP教程
1269
29
C# 教程
1248
24
iOS 18 新增'已恢复”相册功能 可找回丢失或损坏的照片 iOS 18 新增'已恢复”相册功能 可找回丢失或损坏的照片 Jul 18, 2024 am 05:48 AM

苹果公司最新发布的iOS18、iPadOS18以及macOSSequoia系统为Photos应用增添了一项重要功能,旨在帮助用户轻松恢复因各种原因丢失或损坏的照片和视频。这项新功能在Photos应用的"工具"部分引入了一个名为"已恢复"的相册,当用户设备中存在未纳入其照片库的图片或视频时,该相册将自动显示。"已恢复"相册的出现为因数据库损坏、相机应用未正确保存至照片库或第三方应用管理照片库时照片和视频丢失提供了解决方案。用户只需简单几步

Hibernate 如何实现多态映射? Hibernate 如何实现多态映射? Apr 17, 2024 pm 12:09 PM

Hibernate多态映射可映射继承类到数据库,提供以下映射类型:joined-subclass:为子类创建单独表,包含父类所有列。table-per-class:为子类创建单独表,仅包含子类特有列。union-subclass:类似joined-subclass,但父类表联合所有子类列。

如何在PHP中处理数据库连接错误 如何在PHP中处理数据库连接错误 Jun 05, 2024 pm 02:16 PM

PHP中处理数据库连接报错,可以使用以下步骤:使用mysqli_connect_errno()获取错误代码。使用mysqli_connect_error()获取错误消息。通过捕获并记录这些错误信息,可以轻松识别并解决数据库连接问题,确保应用程序的顺畅运行。

在PHP中使用MySQLi建立数据库连接的详尽教程 在PHP中使用MySQLi建立数据库连接的详尽教程 Jun 04, 2024 pm 01:42 PM

如何在PHP中使用MySQLi建立数据库连接:包含MySQLi扩展(require_once)创建连接函数(functionconnect_to_db)调用连接函数($conn=connect_to_db())执行查询($result=$conn->query())关闭连接($conn->close())

如何在 Golang 中使用数据库回调函数? 如何在 Golang 中使用数据库回调函数? Jun 03, 2024 pm 02:20 PM

在Golang中使用数据库回调函数可以实现:在指定数据库操作完成后执行自定义代码。通过单独的函数添加自定义行为,无需编写额外代码。回调函数可用于插入、更新、删除和查询操作。必须使用sql.Exec、sql.QueryRow或sql.Query函数才能使用回调函数。

如何在 Golang 中将 JSON 数据保存到数据库中? 如何在 Golang 中将 JSON 数据保存到数据库中? Jun 06, 2024 am 11:24 AM

可以通过使用gjson库或json.Unmarshal函数将JSON数据保存到MySQL数据库中。gjson库提供了方便的方法来解析JSON字段,而json.Unmarshal函数需要一个目标类型指针来解组JSON数据。这两种方法都需要准备SQL语句和执行插入操作来将数据持久化到数据库中。

如何用 Golang 连接远程数据库? 如何用 Golang 连接远程数据库? Jun 01, 2024 pm 08:31 PM

通过Go标准库database/sql包,可以连接到MySQL、PostgreSQL或SQLite等远程数据库:创建包含数据库连接信息的连接字符串。使用sql.Open()函数打开数据库连接。执行SQL查询和插入操作等数据库操作。使用defer关闭数据库连接以释放资源。

如何使用C++处理数据库连接和操作? 如何使用C++处理数据库连接和操作? Jun 01, 2024 pm 07:24 PM

在C++中使用DataAccessObjects(DAO)库连接和操作数据库,包括建立数据库连接、执行SQL查询、插入新记录和更新现有记录。具体步骤为:1.包含必要的库语句;2.打开数据库文件;3.创建Recordset对象执行SQL查询或操作数据;4.遍历结果或按照具体需求更新记录。

See all articles