数据表

作者: 小王同学123321 | 来源:发表于2022-04-30 15:41 被阅读0次

数据表类型
一、 创建数据表

 CREATE TABLE IF NOT EXISTS user(

id INT UNSIGNED AUTO_INCREMENT PRIMARY KEY,

name VARCHAR(255) NOT NULL UNIQUE,

Sex TINYINT  NOT NULL DEFUALT 1,

age TINYINT  NOT NULL DEFAULT 0

)ENGINE = MyISAM DEFAULT CHARSET=utf8;

CREATE  TABLE  IF NOT EXISTS 表名称(

  字段名1  类型(长度) 属性  索引,

字段名2  类型(长度) 属性  索引,

字段名3  类型(长度) 属性  索引,

字段名4  类型(长度) 属性  索引,

字段名5  类型(长度) 属性  索引,

...

字段名N  类型(长度) 属性  索引,

) ENGINE =MyISAM  DEFAULT  CHARSET =utf8;

html  设置字符集  utf-8

mysql 设置字符集  utf8

二、 mysql 数据类型

  1. 整数类型(重点重点重点)

整数类型

字节数

无符号范围

有符号范围

TINYINT(微整型)

1

+0 - +255

-128- +127

SMALLINT(小整型)

2

0-65535

-32768-32767

MEDIUMINT(中整型)

3

0-16777215

-8388608-8388607

INT(整型)

4

0-4294967295

-2147483648-2147483647

BIGINT(大整型)

8

0-188446744073709551615

mysql 支持的数据类型后面指定该类型的宽度, 基本形式如下:

数据类型(显示宽度)

默认显示宽度: 可以理解为 一个整数类型的默认宽度正好能显示该数据类型的所有值的宽度 默认长度其实是当前位数减一 为什么要减一 是因为第一位是我们的符号位

n1 | tinyint(4)

n2 | smallint(6)

n3 | mediumint(9)

n4 | int(11)

n5 | bigint(20)

在整数类型使用是 可以配置zerofill 参数 zerofill 表示数字不足的显示空间由0来填充补全

出现下面报错的原因是

Out of range value for column 'n1' at row 1

你的长度超出了范围

注意:

使用zerofill是 mysql会自动加上unsigned(无符号)属性 那么该整数类型只能表示无符号数 器显示长度比默认显示宽度小一

在设置了显示宽度时 如果插入的数据宽度大于设置的显示宽度 数据依然可以插入 且能够显示 但是该设置的宽度失效

数据的宽度不能大于默认宽度 如果大于默认宽度 那么该数据已经超出该类型的最大值 因为最大值的宽度必须小于等于默认宽度 如果一个值大于最大值 将不能插入

-- 整数类型还有一个属性 AUTO_INCREMENT 属性 自增

-- 自增属性需要配合索引使用

-- 如果出现下面报错 请在你自增属性后面加上你的索引内容

-- ERROR 1075 (42000): Incorrect table definition; there can be only one auto column and it must be defined as a key

-- key(index) 索引

-- 普通索引(index)

-- 唯一索引(unique) 唯一索引所有值不能有重复

-- 主键索引primary key 一个数据表中只能有一个 唯一作用 一般设置都是自增字段

zerofill 零填充

unsigned 无符号

auto_increment 自增

只能修饰整数类型

  1. 浮点数和定点数

mysql 中使用浮点数和定点数来表示小数

浮点数: 单精度浮点数(float) 和双精度浮点数(double)

定点数: DECIMAL

定点数在存储空间 是根据精度来决定的

mysql中可以指定浮点数的精度: 数据类型(M,D)

M 精度 是数据的总长度 小数点不占位

D 标度 小数点后的长度

在存储小数的时候 建议使用decimal类型 定点数以字符串形式存储 因此精度要比浮点数更高 而且浮点数容易出现误差 这是浮点数一直存在的问题 如果对数据的精度要求很高 还是选择定点数比较安全

如果标度超出位数那么他会进行四舍五入如果你的精度和标度一样那么我们的整数位只能是零

  1. 时间

-- 时间戳

-- 2147483647

INT 2147483647

因为php可以有date函数 你想处理什么样子都可以 所以我们使用时间戳来存储我们php的时间

  1. 字符串类型

字符串类型是mysql中用来存储字符串的数据类型 字符串类型包含: VARCHAR CHAR TEXT ENUM SET

CHAR 和VARCHAR

字符串类型(M) M-- 该字符串的最大长度 M

CHAR 定长的字符类型 0-255

VARCHAR 变长的字符类型 5.0以前 0-255 5.0版本以后 0-65535

char(5) 和 varchar(5)区别

插入值 char 占用字数 varchar占用字数

1 5 2

123 5 4

1234 5 5

12345 5 6

CHAR 定长字符类型 分配多少空间就占用多少空间 不计算需要的长度 处理数据速度快

VARCHAR 变长字符类型 根据字符串的长度来分配空间 需要计算长度 处理数据速度稍慢

什么时候用char 什么时候用varchar

当你插入的数据长度一直不变的情况下 请使用char 密码需要使用char

当你插入的数据长度是随时改变的情况下 使用varchar 用户名需要使用varchar

ENUM 类型 枚举类型

ENUM(‘值1,值2,值3,,,,,值n’)

n--代表参数列表中的第n个值 n 65535

ENUM 的值只能去列表中的一个元素

1/65535

SET 类型

在创建表是 set类型的取值范围是以列表的形式指定的

set(‘值1,值2,值3,。。。值n’);

set 类型的值最多只是64个元素 取值可以是一个或者多个 其他特性和enum类似

1-64/64

三 查看表结构

DESC 表名 : 缩写版

DESCRIBE 表名

查看建表语句

SHOW CREATE TABLE 表名

四 创建表

  1. 建表语法

CREATE TABLE IF NOT EXISTS 表名称(

字段名1 类型(长度) 属性 索引,

字段名2 类型(长度) 属性 索引,

字段名3 类型(长度) 属性 索引,

字段名4 类型(长度) 属性 索引,

字段名5 类型(长度) 属性 索引,

...

字段名N 类型(长度) 属性 索引,

) ENGINE =MyISAM DEFAULT CHARSET =utf8;

a. 设置主键

PRIMARY KEY

字段名 数据类型 PRIMARY KEY

b. 设置表的非空约束

字段名 数据类型 NOT NULL

不为空 只是不为null

c. 设置表的唯一性

字段名 数据类型 UNIQUE

d. 设置表字段值的自增

字段名 数据类型 AUTO_INCREMENT

如果你设置自增就必须加上 索引 PRIMARY KEY

e. 设置表的字段默认值

字段名 数据类型 DEFAULT 默认值

f. 设置字段的数字类型 不能为负数

字段名 数据类型 UNSIGNED

g. 建表引擎

MyISAM

InnoDB

MyISAM 与 InnoDB 的区别

myisam 读取速度快 不支持事务

InnoDB 读取速度稍慢 支持事务 事务回滚

===================================

根据我们昨天学的内容创建一个表

ERROR 1062 (23000): Duplicate entry 'user1' for key 'name'

说明你的user1在name字段里面有值了 而且你的name字段是唯一字段

  1. 修改表(重点重点)

a) 修改表名

ALTER TABLE 表名 RENAME TO 新表名

b) 修改字段的数据类型

ALTER TABLE 表名 MODIFY 字段名 数据类型 属性 索引;

c) 修改字段名

ALTER TABLE 表名 CHANGE 老字段名 新字段名 数据类型 属性 索引;

d) 增加字段

ALTER TABLE 表名 ADD 字段名 数据类型 属性 索引 [FIRST|AFTER 字段名]

如果后面first和after 不写的情况下 默认是添加到字段末尾

e) 删除字段

ALTER TABLE 表名 DROP 字段名

ERROR 1091 (42000): Can't DROP 'phone'; check that column/key exists

删除不存在的字段 会报上面的错误

f) 修改字段的排列位置

ALTER TABLE 表名 MODIFY 字段1 数据类型 属性 索引 AFTER 字段2

g) 修改表引擎

ALTER TABLE 表名 ENGINE = 引擎名

数据量大的时候 不建议像上面一样去修改表引擎 而是先创建一个和myuser表一样的表 然后把空表的引擎修改为我们要修改的引擎之后将数据导入到新表中即可

h) 将自增改为现在的最大值

ALTER TABLE 表名 AUTO_INCREMENT=0;

相关文章

  • 数据表操作

    创建数据表: 查看数据表: 查看数据表的基本结构: 查看数据表的详细结构:(查看脚本) 修改数据表 添加字段

  • iOS中SQLite使用

    iOS中SQLite使用 创建数据表 向数据表中添加数据 从数据表中删除数据 修改数据表中的数据 读取数据表 ma...

  • Mysql的数据表创建操作

    1 创建、查看数据表 2 创建数据表(使用主键约束,2种方式) 3 创建数据表(多字段联合主键) 4 创建数据表(...

  • Python 高级 14(2)数据库增删改查

    数据表操作、DDL 数据表的增删改、DML 数据表中数据的增删改、MySQL 常用字段类型 2.4 数据表操作 学...

  • Dcat-admin初始化常用操作 --- 2022-07-05

    数据表格初始化 数据表单初始化

  • 如何利用机器人流程自动化实现业务转型

    【RPA之家视频教程5】UiPath联接数据表活动-Uipath数据表-3-Uipath数据表活动 https...

  • 表级操作、约束(键)说明

    数据表: 数据表的创建: CREATE TABLE [IF NOT EXISTS] table_name ( ...

  • MySQL学习(三)

    2018/5/2 21:17 一、数据表 *数据表(表)——基础,行是记录,列是字段。 1、创建数据表: CREA...

  • 6.数据表基本操作

    内容概括: 打开数据库(USE),创建数据表,查看所创建的数据表; 在数据表中插入记录(INSERT),查看记录(...

  • Mysql数据表相关操作

    数据表 数据表是数据库最重要的组成部分之一,是其他对象的基础; 数据表是存储数据的数据结构; 数据表是包含了特定实...

网友评论

      本文标题:数据表

      本文链接:https://www.haomeiwen.com/subject/uvsyyrtx.html