一 、创建表的完整语法

create table 表名(

字段名1 类型[(宽度) 约束条件],
字段名2 类型[(宽度) 约束条件],
字段名3 类型[(宽度) 约束条件]
);

解释:

类型:使用限制字段必须以什么样的数据类型传值
约束条件:约束条件是在类型之外添加一种额外的限制

注意:

1. 在同一张表中,字段名是不能相同
2. 宽度和约束条件可选,字段名和类型是必须的
3、最后一个字段后不加逗号

除整型类型外,其他类型的宽度(字符个数)都表示存储范围,整型的宽度表示显示宽度(字符个数)

二、 基本数据类型之整型:

整型类型:

      tinyint、 smallint、 mediumint、 int、 bigint

  为该类型指定宽度时,仅仅只是指定查询结果的显示宽度,与存储范围无关

  存储范围如下:

默认的显示宽度,都是在最大值的基础上加1

默认整型都是有符号的

int的存储宽度是4个Bytes,即32个bit,即2**32

无符号最大值为:4294967296-1

有符号最大值:2147483648-1

有符号和无符号的最大数字需要的显示宽度均为10,而针对有符号的最小值则需要11位才能显示完全,所以int类型默认的显示宽度为11是非常合理的

最后:整形类型,其实没有必要指定显示宽度,使用默认的就ok

# 显示时,不够8位用0填充,如果超出8位则正常显示

create table t5(x int(8) unsigned zerofill);
#unsigned无符号 zerofill不够用0填充 insert into t5 values(4294967296123); #若没有修该改为宽松模式,则会报错,插入数据超过限制
insert into t5 values(1);

  

  注:   

参考:http://www.cnblogs.com/linhaifeng/articles/8495101.html

sql_mode一般来说很少去关注它,没有遇到实际问题之前不会去启停上面的条目。我们常设置的 sql_mode 是 ANSISTRICT_TRANS_TABLESTRADITIONAL,ansi和traditional是上面的几种组合。 ANSI模式:
  宽松模式,对插入数据进行校验,如果不符合定义类型或长度,对数据类型调整或截断保存,报warning警告。 TRADITIONAL模式:
  严格模式,当向mysql数据库插入数据时,进行数据的严格校验,保证错误数据不能插入,报error错误。用于事物时,会进行事物的回滚。

ORACLE
  相当于 PIPES_AS_CONCAT, ANSI_QUOTES, IGNORE_SPACE, NO_KEY_OPTIONS, NO_TABLE_OPTIONS, NO_FIELD_OPTIONS, NO_AUTO_CREATE_USER

STRICT_TRANS_TABLES模式:
  严格模式,进行数据的严格校验,错误数据不能插入,报error错误。


查看修改模式: # 查看sql_mode
mysql> show variables like "%sql_mode%";
+----------------------------+---------------------+
| Variable_name | Value |
+----------------------------+---------------------+
| binlogging_impossible_mode | IGNORE_ERROR |
| block_encryption_mode | aes-128-ecb |
| gtid_mode | OFF |
| innodb_autoinc_lock_mode | 1 |
| innodb_strict_mode | OFF |
| pseudo_slave_mode | OFF |
| slave_exec_mode | STRICT |
| sql_mode | ANSI |
+----------------------------+---------------------+
8 rows in set (0.00 sec) #修改sql_mode为严格模式:在该模式下,如果插入的数据超过限制,则会立即报错
mysql> set global sql_mode="strict_trans_tables";

三、基本数据类型之浮点型:

定点数类型:  DEC等同于DECIMAL  

浮点类型:

     FLOAT       单精度浮点类型

     DOUBLE    双精度浮点型

#FLOAT[(M,D)] [UNSIGNED] [ZEROFILL]
单精度浮点数(非准确小数值),m是数字总个数,d是小数点后个数。m最大值为255,d最大值为30
随着小数的增多,精度变得不准确
#DOUBLE[(M,D)] [UNSIGNED] [ZEROFILL]
双精度浮点数(非准确小数值),m是数字总个数,d是小数点后个数。m最大值为255,d最大值为30
随着小数的增多,精度比float要高,但也会变得不准确
#decimal[(m[,d])] [unsigned] [zerofill]
准确的小数值,m是数字总个数(负号不算),d是小数点后个数。 m最大值为65,d最大值为30。
随着小数的增多,精度始终准确
对于精确数值计算时需要用此类型,decaimal能够存储精确值的原因在于其内部按照字符串存储  

    

相同点:

1、对于三者来说,都能存放30位小数

不同点:

1、精度的排序从低到高:float,double,decimal
2、float与double类型能存放的整数位比decimal更多

四、基本数据类型之字符类型:

char类型:

      定长,简单粗暴,浪费空间,存取速度快

   字符长度范围:0-255(一个中文是一个字符,是utf8编码的3个字节)

存储:

  存储char类型的值时,会往右填充空格来满足长度

例如:

  指定长度为10,存>10个字符则报错,存<10个字符则用空格填充直到凑够10个字符存储

检索:

  在检索或者说查询时,查出的结果会自动删除尾部的空格,除非我们打开pad_char_to_full_length SQL模式

   (SET sql_mode = 'PAD_CHAR_TO_FULL_LENGTH';)

  

varchar类型:

    变长,精准,节省空间,存取速度慢

字符长度范围:0-65535(如果大于21845会提示用其他类型 。

   mysql行最大限制为65535字节,字符编码为utf-8:https://dev.mysql.com/doc/refman/5.7/en/column-count-limit.html)

存储:

    varchar类型存储数据的真实内容,不会用空格填充,如果'ab ',尾部的空格也会被存起来

强调:

varchar类型会在真实数据前加1-2Bytes的前缀,该前缀用来表示真实数据的bytes字节数(1-2Bytes最大表示65535个数字,正好符合mysql对row的最大字 节限制,即已经足够使用)
如果真实的数据<255bytes则需要1Bytes的前缀(1Bytes=8bit 2**8最大表示的数字为255)
如果真实的数据>255bytes则需要2Bytes的前缀(2Bytes=16bit 2**16最大表示的数字为65535)

检索:

    尾部有空格会保存下来,在检索或者说查询时,也会正常显示包含空格在内的内容

     字符的宽度限制单位是字符个数 

create table t12(x char(4)); # 超出4个字符则报错,不够4个字符则用空格补全成4个字符
create table t13(y varchar(4));# 超出4个字符则报错,不够4个字符那么字符有几个就存几个

     注:

set global sql_mode="strict_trans_tables,PAD_CHAR_TO_FULL_LENGTH";

#PAD_CHAR_TO_FULL_LENGTH:对于CHAR类型字段,不要截断空洞数据。空洞数据就是自动填充值为0x20的数据。
#mysql在char数据存储时,对数据进行了处理,不够规定字符数补全的空格被处理掉了,加上该行,则不对存储数据进行处理

 

五、基本数据类型之时间类型:

分类:

    YEAR
YYYY(1901/2155) eg: 1999 DATE
YYYY-MM-DD(1000-01-01/9999-12-31)  eg: 1999-01-27 TIME
HH:MM:SS('-838:59:59'/'838:59:59') eg: 11:11:11 DATETIME YYYY-MM-DD HH:MM:SS(1000-01-01 00:00:00/9999-12-31 23:59:59 Y) eg: 1999-01-27 11:11:11 TIMESTAMP YYYYMMDD HHMMSS(1970-01-01 00:00:00/2037 年某时)

    例子:     

create table student(
id int,
name char(16),
born_year year,
birth date,
class_time time,
reg_time datetime
); insert into student values(1,'egon','2000','2000-01-27','08:30:00','2013-11-11 11:11:11');

datetime与timestamp的区别

在实际应用的很多场景中,MySQL的这两种日期类型都能够满足我们的需要,存储精度都为秒,但在某些情况下,会展现出他们各自的优劣。下面就来总结一下两种日期类型的区别。

1.DATETIME的日期范围是1001——9999年,TIMESTAMP的时间范围是1970——2038年。

2.DATETIME存储时间与时区无关,TIMESTAMP存储时间与时区有关,显示的值也依赖于时区。在mysql服务器,操作系统以及客户端连接都有时区的设置。

3.DATETIME使用8字节的存储空间,TIMESTAMP的存储空间为4字节。因此,TIMESTAMP比DATETIME的空间利用率更高。

4.DATETIME的默认值为null;TIMESTAMP的字段默认不为空(not null),默认值为当前时间(CURRENT_TIMESTAMP),如果不做特殊处理,并且update语句中没有指定该列的更新值,则默认更新为当前时间。

六、其他类型:    

常用字符串系列:char与varchar
注:虽然varchar使用起来较为灵活,但是从整个系统的性能角度来说,char数据类型的处理速度更快,有时甚至可以超出varchar处理速度的50%。因此,用户在设计数据库时应当综合考虑各方面的因素,以求达到最佳的平衡 其他字符串系列(效率:char>varchar>text)
TEXT系列 TINYTEXT TEXT MEDIUMTEXT LONGTEXT
BLOB 系列 TINYBLOB BLOB MEDIUMBLOB LONGBLOB
BINARY系列 BINARY VARBINARY text:text数据类型用于保存变长的大字符串,可以组多到65535 (2**16 − 1)个字符。
mediumtext:A TEXT column with a maximum length of 16,777,215 (2**24 − 1) characters.
longtext:A TEXT column with a maximum length of 4,294,967,295 or 4GB (2**32 − 1) characters.

    

七、枚举类型与集合类型

字段的值只能在给定范围中选择,如单选框,多选框
enum 单选 :

  只能在给定的范围内选一个值,如性别 sex 男male/女female

set 多选 :

  在给定的范围内可以选择一个或一个以上的值(爱好1,爱好2,爱好3...)

例子:   

create table teacher(
id int,
name char(16),
sex enum('male','female','others'),
hobbies set('play','read','music','piao')
); insert into teacher values(1,'egon','male',('play,music'));

八、表完整性约束

约束条件与数据类型的宽度一样,都是可选参数

作用:

  用于保证数据的完整性和一致性

  

常见约束:

PRIMARY KEY (PK):    标识该字段为该表的主键,可以唯一的标识记录

FOREIGN KEY (FK) :标识该字段为该表的外键

NOT NULL :标识该字段不能为空

UNIQUE KEY (UK):    标识该字段的值是唯一的

AUTO_INCREMENT:    标识该字段的值自动增长(整数类型,而且为主键)

DEFAULT :为该字段设置默认值

UNSIGNED :无符号

ZEROFILL :使用0填充

  说明:    

1. 是否允许为空,默认NULL,可设置NOT NULL,字段不允许为空,必须赋值
2. 字段是否有默认值,缺省的默认值是NULL,如果插入记录时不给字段赋值,此字段使用默认值
sex enum('male','female') not null default 'male'
age int unsigned NOT NULL default 20 必须为正值(无符号) 不允许为空 默认是20
3. 是否是key
主键 primary key
外键 foreign key
索引 (index,unique...)

1、not null与default

一般not null与default连用,设置不能为空,并为其设置默认值

  默认值,创建列时可以指定默认值,当插入数据时如果未主动设置,则自动添加默认值

  

create table t15(
id int,
name char(16) not null,
sex enum('male','female','other') not null default "male"
); alter table t15 modify name char(16) not null; insert into t15(id,name) values
(1,'egon1'),
(2,'egon2'),
(3,'egon3'); #没有为sex字段传值,默认为male,若此处没有设默认值,则会报不能为空的错

2、unique唯一约束

#单列唯一
方法一:
create table department1(
id int,
name varchar(20) unique,
comment varchar(100)
); 方法二:
create table department2(
id int,
name varchar(20),
comment varchar(100),
constraint uk_name unique(name)
); # 联合唯一
create table server(
id int unique,
ip char(15),
port int,
unique(ip,port)
);

3、将unique与not null连用    

mysql> create table t1(id int not null unique);
Query OK, 0 rows affected (0.02 sec) mysql> desc t1;
+-------+---------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------+---------+------+-----+---------+-------+
| id | int(11) | NO | PRI | NULL | |
+-------+---------+------+-----+---------+-------+
1 row in set (0.00 sec)

4、primary key主键

  primary key:单单从约束角度去看,primary key就等同于not null unique  

强调:

1、一张表中必须有,并且只能有一个主键
2、一张表中都应该有一个id字段,而且应该把id字段做成主键

    

主键primary key是innodb存储引擎组织数据的依据,innodb称之为索引组织表,一张表中必须有且只有一个主键。

一个表中可以:

单列做主键

多列做主键(复合主键)

唯一主键:    

#方法一:not null+unique
create table my_table(
id int not null unique, #主键
name char(16),
age int,
sex char(6)
); #方法二
create table my_table(
id int primary key,
name char(16),
age int,
sex char(6)
); #方法三:在所有字段后单独定义primary key
create table my_table(
id int primary key,
name char(16),
age int,
sex char(6)
constraint pk_name primary key(id); #创建主键并为其命名pk_name
);

    

    联合主键:     

#联合主键
create table t19(
ip char(15),
port int,
primary key(ip,port)
);

5、auto_increment 自增的方式自动生成    

1、通常与primary key连用,而且通常是给id字段加
2、auto_incremnt只能给被定义成key(unique key,primary key)的字段加

eg:

# primary key auto_increment
create table t20(
id int primary key auto_increment,
name char(16)
)engine=innodb;

5月8日 python学习总结 mysql 建表操作的更多相关文章

  1. 5月7日 python学习总结 MySQL数据库(一)

    一.数据库介绍 1.数据库相关概念 数据库服务器(本质就是一台计算机,该计算机之上安装有数据库管理软件的服务端) 数据库管理系统RDBMS(本质就是一个C/S机构的套接字软件) 库(文件夹)===&g ...

  2. 4月2日 python学习总结

    昨天内容回顾: 1.迭代器 可迭代对象: 只要内置有__iter__方法的都是可迭代的对象 既有__iter__,又有__next__方法 调用__iter__方法==>得到内置的迭代器对象 调 ...

  3. 4月8日 python学习总结 模块与包

    一.包 #官网解释 Packages are a way of structuring Python's module namespace by using "dotted module n ...

  4. 4月12日 python学习总结 继承和派生

    一.继承 什么是继承:   继承是一种新建类的方式,在python中支持一个子类继承多个父类   新建类称为子类或派生类   父类可以称之为基类或者超类   子类会遗传父类的属性 2.  为什么继承 ...

  5. 4月11日 python学习总结 对象与类

    1.类的定义 #类的定义 class 类名: 属性='xxx' def __init__(self): self.name='enon' self.age=18 def other_func: pas ...

  6. 4月9日 python学习总结 模块

    1.XML模块 xml是实现不同语言或程序之间进行数据交换的协议,跟json差不多,但json使用起来更简单,不过,古时候,在json还没诞生的黑暗年代,大家只能选择用xml呀,至今很多传统公司如金融 ...

  7. 6月15日 python学习总结 Django模板语言相关内容

    Django模板语言相关内容   Django模板系统 官方文档 常用语法 只需要记两种特殊符号: {{  }}和 {% %} 变量相关的用{{}},逻辑相关的用{%%}. 变量 {{ 变量名 }} ...

  8. 5月31日 python学习总结 JavaScript概述

    JavaScript概述 ECMAScript和JavaScript的关系 1996年11月,JavaScript的创造者--Netscape公司,决定将JavaScript提交给国际标准化组织ECM ...

  9. 5月14日 python学习总结 视图、触发器、事务、存储过程、函数、流程控制、索引

    一.视图 1.什么是视图 视图就是通过查询得到一张虚拟表,然后保存下来,下次用的直接使用即可 2.为什么要用视图 如果要频繁使用一张虚拟表,可以不用重复查询 3.如何用视图 create view t ...

随机推荐

  1. suse 12 安装git客户端

    suse-linux:~ # zypper addrepo http://download.opensuse.org/repositories/devel:/tools:/scm/SLE_12_SP5 ...

  2. OpenGL ES 3D空间中自定义显示空间

    在Android中,我们所熟知的是在ES管线中,其在图元装配时,会进行图元组装与图元分配,这样就回剪裁出来视景体中的物体.但是如果我想在3D场景中规定一个区域,凡是在这个区域中的物体就能显示出来,非这 ...

  3. 完爆Excel!一个令人惊艳的数据展示工具,让你做图更轻松高效

    数据展示应该是最常见的需求,我们经常利用数据做总结.用数据做分享.但是我们该如何更好地展示给我们需要展示的人,如何才能让我们的数据表达更加动人,这个值得让人思索. 说到数据表达,常用的数据展示方式无非 ...

  4. 别人都在用数据分析软件,你还在用excel做数据分析?

    之前听朋友吐槽过,他们是上千人的企业,但做数据分析居然还是靠手动上传数据,而且还是用的excel做的.但其实excel并不是企业做数据分析的好工具. 数据分析是指用适当的统计分析方法对收集来的大量数据 ...

  5. 【基础知识】Intel CPU体系结构|x86是什么意思

    看了<计算机系统结构>.<深入理解计算机系统>.<大话处理器>等经典书籍,也在google上搜了一大堆资料,前前后后.断断续续的折腾了一个多月,终于想通了,现在把自 ...

  6. 5、CPU 的线程与操作系统的线程有何关系?操作系统中的进程和线程是什么关系?

    CPU中的线程和操作系统(OS)中的线程即不同,在调度的时候又有些关联.CPU中的线程,我们叫它们Thread,和OS中的线程的名字一样.它来自同步多线程(SMT,Simultaneous Multi ...

  7. 图解volatile

    volatile是什么 出去面试的时候,很多面试官都会问你:说说你对volatile的理解. 下面我将用图的方式告诉大家,volatile是什么? 如上图所示:每个线程都有自己的工作内存,同时还能访问 ...

  8. LVM--逻辑卷管理@安装、格式化、挂载、开机自动挂载完整篇

    转至:https://blog.51cto.com/xiguatailang/1256606      LVM的重要性在这里我也就不多说了,今天和大家分享一下,LVM的安装方式,以及挂载方式. 首先呢 ...

  9. linux 解决磁盘占用100%

    df -h 查看磁盘使用情况 ll -h 查看文件的大小   使用如下命令查找大于100M的大文件,发现有几个日志文件及临时文件比较大,使用rm –rf删除即可.   find / -size +10 ...

  10. C# Stopwatch计时统计

    using System; using System.Collections.Generic; using System.Diagnostics; using System.Linq; using S ...