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

表空间占用

倍)

全文索引

存储(/var/lib/mysql/)

个文件(.frm存储表结构

个文件(.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; #删除数据表

MySQL学习笔记_4_MySQL创建数据表(下)的更多相关文章

  1. MySQL学习笔记_2_MySQL创建数据表(上)

    MySQL创建数据表(上) 一.创建数据表的SQL语句模型[弱类型] CREATETABLE [IF NOT EXISTS] 表名称( 字段名1列的类型[属性][索引], 字段名2 列的类型[属性][ ...

  2. MySQL学习笔记_3_MySQL创建数据表(中)

    MySQL创建数据表(中) 三.数据字段属性 1.unsigned[无符号] 可以让空间增加一倍 比如可以让-128-127增加到0-255 注意:只能用在数值型字段 2.zerofill[前导零] ...

  3. mysql学习(八)数据表类型-字符集

    数据存储引擎: MyISAM:强化快速读取操作. 也有缺点.一些功能不支持 InnoDB:支持一些MyIASM一些不支持的功能                 缺点:占用空间大 对比          ...

  4. MySQL学习(三): 初识数据表

    打开数据库: USE db_name : 打开数据库. 创建数据表: 查看数据表: 查看数据表结构: 数据简单的插入与查找: 插入:INSERT [INTO] tbl_name [(col_name) ...

  5. MySQL学习(一) 数据表基本操作

    创建数据库:create database db_name 查看数据库结构:show create database db_name 删除数据库:drop database db_name 查看数据库 ...

  6. MySQL学习笔记_10_MySQL高级操作(下)

    MySQL高级操作(下) 五.MySQL预处理语句 1.设置预处理stmt,传递一个数据作为where的判断条件 prepare stmt from "select * from table ...

  7. MySQL学习笔记02_数据库和表的基本操作

    02_1 操作数据库 (1)创建数据库 CREATE DATABASE [IF NOT EXISTS] db_name [create_specification[, create_specifica ...

  8. MySQL学习笔记十一:数据导入与导出

    数据导入 1.mysqlimport命令行导入数据 在使用mysqlimport命令导入数据时,数据来源文件名要和目标表一致,不想改文件名的话,可以复制一份创建临时文件,示例如下. 建立一个文本use ...

  9. MySQL学习笔记2(多表操作)

    外键:使两张表之间存在关联 特点: 1.从表外键的值是对主表主键的引用 2.从表外键类型,必须与主表主键类型一致 示例: 创建两个表并准备数据: USE mybase; CREATE TABLE ca ...

随机推荐

  1. mysql 数据类型别名参考

    To facilitate the use of code written for SQL implementations from other vendors, MySQL maps data ty ...

  2. 六星经典CSAPP-笔记(7)加载与链接(上)

    六星经典CSAPP-笔记(7)加载与链接 1.对象文件(Object File) 1.1 文件类型 对象文件有三种形式: 可重定位对象文件(Relocatable object file):包含二进制 ...

  3. Compile C++ code in Matlab with OpenCV support

    Provides a function named as "mex_opencv(src)" The code function mex_opencv(src) ARC = 'x6 ...

  4. 如何找出Xcode中不同版本Swift的路径

    我们知道Xcode中可能包含不知一个Swift的版本,那么我们如何找到它们对应的路径呢? 熟悉unix shell命令的童鞋都知道有一个find指令,在我们已知Xcode路径时,我们可以在其中找到Sw ...

  5. 实现Android5.0过渡动画兼容库

    Android5.0之后为我们提供了许多炫酷的界面过渡效果,其中共享元素过渡也是很有亮点的一个效果,但这个效果只能在Android5.0之后使用,那今天我们就来将共享元素过渡效果兼容到Android4 ...

  6. 用scheme最基本的元素定义排序函数

    用到的元素有9个: define,if,null?,cons car,cdr,lambda,let,named let, 其实let 和 named let可以去掉.但那样会带来性能和可读性下降的问题 ...

  7. static 变量(静态变量)

    在C++的面向对象编程中,static还可以加在类的数据成员或成员函数之前.这样定义的数据成员或成员函数就被类所拥有,而不再属于类的对象. #include <iostream> usin ...

  8. Dynamics CRM2016 Web API之删除

    相比之前的增改查,删除就显得简单的多了. 这里的request的type为delete,删除成功的status为204,404则是要删除的记录不存在 var id = 'BAD90A95-7FEA-E ...

  9. Servlet - 基础

    Servlet 标签 : Java与Web HTTP协议 HTTP(hypertext transport protocol),即超文本传输协议.这个协议详细规定了浏览器(Browser)和万维网服务 ...

  10. Dynamics CRM 插件注册时报Assembly must be registered in isolation的解决方法

    在插件注册的时候经常会遇到"Assembly must be registered in isolation"的问题导致无法注册,之前经常会被同事或者朋友问到这个问题,遇到这个问题 ...