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. webpack 4 + mockjs

    一.创建项目目录 二.添加开发依赖( html-webpack-plugin.webpack.webpack-cli.webpack-dev-server.webpack-api-mocker) 如下 ...

  2. JavaScript中的事件模型

    JS中的事件 1.鼠标事件 onclick   ondbclick   onmouseover   onmouseout 2.HTML事件 onload   onunload   onsubmit   ...

  3. Django 缓存模块 page_cache 源码阅读

    Django cache中比较常用的有 cache_page 这么个 decorators, 下面就根据请求流程,结合源码来说说它是怎么工作的? 版本是django1.8,不同版本可能函数等会变化,逻 ...

  4. Dynamics CRM2016 Web Api之更新时间字段值

    前篇我们论述了时间字段的查询,本篇来论述下时间字段的更新. 还是以之前建的当地时间(时间行为为用户当地时间)字段来测试 可以看到web api更新的是数据库的时间,而在前台的反映就是做了加8处理,所以 ...

  5. mxgraph进阶(四)mxGraph再启程

    mxgraph进阶(四)mxGraph再启程 前言   小论文Constructing User Interaction Behaviors Net from System Log. (AICE 20 ...

  6. github pages + Hexo + 域名绑定搭建个人博客增强版

    概述 前面我们用github pages + Hexo 搭建了一个简单版的个人博客系统,但是里面的内容单调,很多功能不够完善,所以我们需要对yelle 的主题进行优化和完善.基本搭建请访问:http: ...

  7. Android Topeka介绍

    概述 当你已经做Android开发一段时间,并苦于进入瓶颈,这个时候阅读一些优秀App的源码是最好的学习进阶方式,前几天,邀请去参加一个Android大会,我作为其中一个演讲者,专门讲解了Androi ...

  8. WebView 的使用案例

    package com.example.day20_webview; import android.os.Bundle; import android.annotation.SuppressLint; ...

  9. Spark-1.6.0中的Sort Based Shuffle源码解读

    从Spark-1.2.0开始,Spark的Shuffle由Hash Based Shuffle升级成了Sort Based Shuffle.即Spark.shuffle.manager从Hash换成了 ...

  10. 【ShaderToy】水彩画

    写在前面 好久没有更新shadertoy系列了,我万万没想到有童鞋还惦记着它...之前说过希望可以一周更新一篇,现在看来是不怎么可能了,一个月更新一篇的希望比较大(不要再相信我了...) 我把之前实现 ...