MySQL学习笔记

SQL

注释

单行注释: –-#注释内容

多行注释:/*注释内容*/

SQL分类

分类 说明
DDL 数据定义语言,用来定义数据库对象
DMI 数据操作语言,用来对数据库表中的数据进行增删改
DQL 数据查询语言,用来查询数据库中表的记录
DCL 数据控制语言,用来创建数据库用户,控制数据库的访问权限

DDL

DDL-数据库操作

查询

查询所有数据库:

SHOW DATABASES;

查询当前数据库:

SELECT DATABASE();

创建

CREATE DATABASE [IF NOT EXISTS] 数据库名 [DEFAULT CHARSET 字符集] [COLLATE 排序规则];

删除

DROP DATABASE [IF EXISTS] 数据库名;

使用

USE 数据库名;

DDL-表操作

查询

查询当前数据库所有表:

SHOW TABLES;

查询表结构:

DESC 表名;

查询指定表的建表语句:

SHOW CREATE TABLE 表名;
创建
CREATE TABLE 表明(
	字段1 字段1类型 [COMMENT 字段1注释],
	字段2 字段2类型 [COMMENT 字段2注释],
	字段3 字段3类型 [COMMENT 字段3注释],
	...
	字段n 字段n类型 [COMMENT 字段n注释]
) [COMMENT 表注释];
数据类型

无符号后面加UNSIGNES

数值类型

类型 大小 范围(有符号)
TINYINT 1 byte (-128,127)
SMALLINT 2 byte (-32768,32767)
MEDIUMINT 3 byte (-8388608,8388607)
INT 或 INTEGER 4 byte (-2147483648,2147483647)
BIGINT 8 byte (-263,263-1)
FLOAT 4 byte (-3.402823466 E+30,3.402023466351 E+30)
DOUBLE 8 byte (-1.7976931348623157 E+308,1.7976931348623157 E+308)
DECTMAL 依赖与M(精度)和D(标度)的值

字符串类型

类型 大小 描述
CHAR 0-255 bytes 定长字符串(性能好)
VARCHAR 0-65535 bytes 变长字符串 (性能较差)
TINYBLOB 0-255 bytes 不超过255个字符的二进制数据
TINYTEXT 0-255 bytes 短文本字符串
BLOB 0-65535 bytes 二进制形式的长文本数据
TEXT 0-65535 bytes 长文本数据
MEDIUMBLOB 0-16777215 bytes 二进制形式的中等长度文本数据
MEDIUMTEXT 0-16777215 bytes 中等长度文本数据
LONGBLOB 0-4294967295 bytes 二进制形式的极大文本数据
LONGTEXE 0-4294967295 bytes 极大文本数据

日期类型

类型 大小 范围 格式 描述
DATE 3 1000-01-01 至 9999-12-31 YYY-MM-DD 日期值
TIME 3 -838:59:59 至 838:59:59 HH:MM:SS 时间值或持续时间
YEAR 1 1901 至 2155 YYYY 年份值
DATETIME 8 1000-01-10 00:00:00 至 9999-12-31 23:59:59 YYYY-MM-DD HH:MM:SS 混合日期和时间值
TIMESTAMP 4 1970-01-01 00:00:00 至 2030-01-19 03:14:07 YYYY-MM-DD HH:MM:SS 混合日期和时间值,时间戳
修改

添加字段:

ALTER TABLE 表名 ADD 字段名 类型(长度) [COMMENT 注释] [约束];

修改数据类型:

ALTER TABLE 表名 MODIFY 字段名 新数据类型(长度);

修改字段名和字段类型:

ALTER TABLE 表名 CHANGE 旧字段名 新字段名 类型(长度) [COMMENT 注释] [约束];

删除字段:

ALTER TABLE 表名 DROP 字段名;

修改表名:

ALTER TABLE 表名 RENAME TO 新表名;
删除

删除表:

DROP TABLE [IF EXISTS] 表名;

删除指定表,并重新创建该表:

TRUNCATE TABLE 表名;

DML

添加数据

给指定字段添加数据:

INSERT INTO 表名 (字段名1,字段名2,...) VALUES(值1,值2,...);

给全部的字段添加数据:

INSERT INTO 表名 VALUES (值1,值2,...);

批量添加数据:

INSERT INTO 表名 (字段名1,字段名2,...) VALUES (值1,值2,...),(值1,值2,...),(值1,值2,...);
INSERT INTO 表名 VALUES (值1,值2,...),(值1,值2,...),(值1,值2,...);

注意:

  1. 字符串和日期型数据应该包含在引号中
  2. 插入数据的大小,应该在字段的规定范围内
posted @ 2023-08-27 23:37  -37-  阅读(5)  评论(0编辑  收藏  举报