2. MySQL数据库基础

一、数据库的操作

1. 显示当前的数据库

sql 复制代码
SHOW DATABASES;

2. 创建数据库

语法:

sql 复制代码
CREATE DATABASE [IF NOT EXISTS] db_name [create_specification...];

//create_specification包括:
  [DEFAULT] CHARACTER SET charset_name
  [DEFAULT] COLLATE collation_name

说明:

  • 大写的表示关键字
  • \] 是可选项

  • COLLATE:指定数据库字符集的校验规则

示例:

  • 创建名为 db_test1 的数据库。

    sql 复制代码
    CREATE DATABASE db_test1;
  • 如果系统没有 db_test2 的数据库,则创建一个名叫 db_test2 的数据库,如果有则不创建。

    sql 复制代码
    CREATE DATABASE IF NOT EXISTS db_test2;
  • 如果系统没有 db_test 的数据库,则创建一个使用 utf8mb4 字符集的 db_test 数据库,如果有则不创建。

    sql 复制代码
    CREATE DATABASE IF NOT EXISTS db_test CHARACTER SET utf8mb4;

3. 使用数据库

sql 复制代码
use 数据库名;

4. 删除数据库

语法:

sql 复制代码
DROP DATABASE [IF EXISTS] db_name;

**说明:**数据库删除以后,内部看不到对应的数据库,里边的表和数据全部被删除。

示例:

sql 复制代码
drop database if exists db_test1;
drop database if exists db_test2;

二、常用数据类型

1. 数值类型

分为整型和浮点型:

扩展资料:

数值类型可以指定为无符号(unsigned),表示不取负数。

1字节(bytes)= 8bit。

对于整型类型的范围:

  • 有符号范围:-2^(类型字节数*8-1)到 2^(类型字节数*8-1)-1,如int是4字节,就是 -2^31 到 2^31-1。
  • 无符号范围:0 到 2^(类型字节数*8)-1,如 int 就是 2^32-1。

尽量不使用unsigned,对于int类型可能存放不下的数据,int unsigned同样可能存放不下,与其如此,还不如设计时,将int类型提升为bigint类型。

2. 字符串类型

3. 日期类型

三、表的操作

需要操作数据库中的表时,需要先使用该数据库:

sql 复制代码
use db_test;

1. 查看表

sql 复制代码
--查看表
show tables;

--查看表结构
desc 表名;

示例:

2. 创建表

语法:

sql 复制代码
CREATE TABLE table_name (
    field1 datatype,
    field2 datatype,
    field3 datatype
);

可以使用 comment 增加字段说明。

示例:

sql 复制代码
create table stu_test (
   id int,
   name varchar(20) comment '姓名',
   password varchar(50) comment '密码',
   age int,
   sex varchar(1),
   birthday timestamp,
   amout decimal(13,2),
   resume text
);

3. 删除表

语法:

sql 复制代码
DROP [TEMPORARY] TABLE [IF EXISTS] tbl_name [, tbl_name] ...

示例:

sql 复制代码
-- 删除 stu_test 表
drop table stu_test;

-- 如果存在 stu_test 表,则删除 stu_test 表
drop table if exists stu_test;

4. 修改表

4.1 修改表名

语法1:

sql 复制代码
alter table 旧表名 rename to 新表名;

语法2:

sql 复制代码
rename table 旧表名1 to 新表名1,旧表名2 to 新表名2,旧表名3 to 新表名3,...,旧表名n to 新表名n;

4.2 增加列

**语法1:**在建表完后,需要增加一些列:

sql 复制代码
alter table 表名 add column 列名 数据类型 [列的属性];

**语法2:**把新增的这一列,放到第一列:

sql 复制代码
alter table 表名 add column 列名 数据类型 [列的属性] first;

**语法3:**在某一个列后面新增一列:

sql 复制代码
alter table 表名 add column 列名 数据类型 [列的属性] after 指定列名;

4.3 删除列

语法:

sql 复制代码
alter table 表名 drop column 列名;

4.4 修改列的信息

**注意:**在修改后的数据类型和属性一定要兼容表中现有的数据。

**语法1:**只能修改列的相关数据类型和属性。

sql 复制代码
alter table 表名 modify 列名 新数据类型 [新属性];

**语法2:**既可以修改数据类型和属性,也可以修改列名。

sql 复制代码
alter table 表名 change 旧列名 新列名 新数据类型 [新属性];

**语法3:**将某列设为表的第一列。

sql 复制代码
alter table 表名 modify 列名 列的类型 列的属性 first;

**语法4:**将某列放到指定列的后面。

sql 复制代码
alter table 表名 modify 列名 列的类型 列的属性 after 指定列名;
相关推荐
liliangcsdn10 小时前
如何使用python创建和维护sqlite3数据库
数据库·sqlite
TDengine (老段)17 小时前
TDengine 数学函数 DEGRESS 用户手册
大数据·数据库·sql·物联网·时序数据库·iot·tdengine
TDengine (老段)17 小时前
TDengine 数学函数 GREATEST 用户手册
大数据·数据库·物联网·时序数据库·iot·tdengine·涛思数据
@yanyu66617 小时前
idea中配置tomcat
java·mysql·tomcat
安当加密17 小时前
云原生时代的数据库字段加密:在微服务与 Kubernetes 中实现合规与敏捷的统一
数据库·微服务·云原生
爱喝白开水a17 小时前
LangChain 基础系列之 Prompt 工程详解:从设计原理到实战模板_langchain prompt
开发语言·数据库·人工智能·python·langchain·prompt·知识图谱
想ai抽17 小时前
深入starrocks-多列联合统计一致性探查与策略(YY一下)
java·数据库·数据仓库
武子康17 小时前
Java-152 深入浅出 MongoDB 索引详解 从 MongoDB B-树 到 MySQL B+树 索引机制、数据结构与应用场景的全面对比分析
java·开发语言·数据库·sql·mongodb·性能优化·nosql
longgyy18 小时前
5 分钟用火山引擎 DeepSeek 调用大模型生成小红书文案
java·数据库·火山引擎
ytttr87318 小时前
C# 仿QQ聊天功能实现 (SQL Server数据库)
数据库·oracle·c#