[MySQL] 基础操作

一. 数据库的操作

1.显示当前数据库

语法 : show databases;

2.创建数据库

语法 : create database [if not exists] 数据库名 [character set utf8mb4] [collaction utf8mb4_0900_ai_ci] [encryption {'Y'|'N'}]

  • 加粗部分为关键字
  • 数据库名可以自己指定
  • {} 中为必选 , \[\] 中为可选
  • if not exists : 如果不存在 该数据库名的数据库 , 则添加
  • character set : 为数据库指定 字符集编码
  • collaction : 为数据库指定 字符集的校验规则
  • encryption : 数据库是否加密

示例 :

create database if not exists bit_mall_1017 ;

3.字符集编码和校验规则

① 查看数据库支持的字符集编码

语法 : show charset;

  • MySQL8.0 的默认字符集编码是 utf8mb4

② 查看数据库支持的排序规则

语法 : show collaction;

  • MySQL 的默认排序规则是 utf8mb4_0900_ai_ci(utf8mb4 字符集 , 0900 基于 UCA9.0.0算法 , ai 口音不敏感 , ci 大小写不敏感 )
  • as 是口音敏感 , cs 是大小写敏感 , bin 表示二进制

③ 查看系统默认字符集

语法 : show variables like '%character%';

④ 查看系统默认排序规则

语法 : show variables like '%collation%';

4.使用数据库

语法 : use 数据库名

5.删除数据库(一般禁用)

语法 : drop database [if exists] 数据库名

6 .补充

① 为了防止使用的数据库名刚好是关键字 可以子啊命名时加上反引号 ` `

② 查看警告信息

语法 :show warningss;

③ 重新另起一行 语法 : ctrl+c(^C)

④ 查看 MySQL 的帮助指令 : ?

⑤ 退出客户端 : \q

二.常用数据类型

1.数值类型

|--------------------|----------------|-------------------------------------------------------------------------|---------------------------------------|
| 数值类型 | 大小 | 说明 | 对应 Java 类型 |
| BIT(M) | M 指定位数 , 默认为 1 | 二进制数 , M 的范围从 1 到 64 , 存储数据范围从 0 到 2^M-1 | 常用 Boolean 对应 BIT , 此时默认是一位 , 只能存 0,1 |
| TINYINT(M) | 1 字节 | 范围 -2^7~2^7-1 , 无符号范围 2^8-1 | Byte |
| BOOL | 1 字节 | TINYINT(1)同义词 , 0 为假 , 非 0 为真 | Boolean |
| SMALLINT | 2 字节 | 范围 -2^15~2^15-1 , 无符号范围 2^16-1 | Short |
| MEDOUMINT(M) | 3 字节 | 范围 -2^23~2^23-1 , 无符号范围 2^24-1 | |
| INT | 4 字节 | 范围 -2^31~2^31-1 , 无符号范围 2^32-1 | Interger |
| BIGINT | 8 字节 | 范围 -2^63~2^63-1 , 无符号范围 2^64-1 | Long |
| FLOAT(M , D) | 4 字节 | 单精度浮点数 , M 是总位数 , D 是小数点后的位数 | Float |
| DOUBLE(M , D) | 8 字节 | 双精度浮点数 , M 是总位数 , D 是小数点后的位数 | Double |
| DECIMAL(M , D) | M/D+2(动态) | 不存在精度丢失 , M 是总位数 , 默认为 10(M 中不计算-号 , 和小数点) ; D 是小数点后的位数 , 默认为 0(没有小数部分) | BigDecimal |

2.字符串类型

|----------------|----------------|------------|------------|
| 数据类型 | 大小 | 说明 | 对应 Java 类型 |
| VARCHAR(M) | 0~65535 字节 | 可变长度字符串 | String |
| TEXT | 0~65535 字节 | 长文本数据 | String |
| MEDUIUMTEXT | 0~16777215 字节 | 中等长度文本数据 | String |
| BLOB | 0~65535 字节 | 二进制形式的文本数据 | Byte\[\] |

3.日期操作

|-----------|------|----------------------------------------------------------------------------|-----------------------------------|
| 数据类型 | 大小 | 说明 | 对应 Java 类型 |
| DATE | 3 字节 | 日期类型 , 范围 1000-01-01~9999-12-31 | java.util.Date java.sql.Timestamp |
| DATETIME | 8 字节 | 日期+时间类型的组合 , 范围: 1000-01-01 00:00:00.000000 ~ 9999-12-31 23:59:59.4999999 | java.util.Date java.sql.Timestamp |
| TIMESTAMP | 4 字节 | 时间戳类型 , 范围:1970-01-01 00:00:01.000000~2038-01-19 03:14:07.499999 | java.util.Date java.sql.Timestamp |

三.表的操作

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

1.查看所有表

语法 : show tables;

1.创建表

语法 : create [temporary] table [if not exists] 表名( 列名 数据类型 [comment '注释内容'] [,列名 数据类型 [comment '注释内容']] );

示例 :

复制代码
create table goods(

goods_id int comment '商品编号',

goods_name varchar(50) comment '商品名称',

unitprice int comment '单价',

category varchar(50) comment '商品类别',

provider varchar(50) comment '供应商'

);

2.修改表

语法 : ALTERTABLE 表名 alter_option \[, alter_option ...];

alter_option: {

table_options

| ADD COLUMN col_name column_definition FIRST \| AFTER col_name

| MODIFY COLUMN col_name column_definition FIRST \| AFTER col_name

| DROP COLUMN col_name

| RENAME COLUMN old_col_name TO new_col_name

| RENAME TO \| AS new_tbl_name

  • ADD : 向表中添加列
  • MODIFY : 修改表中现有列
  • DROP : 删除表中现有列
  • RENAME COLMN : 重命名表中的现有列
  • RENAME TO\|AS new_tbl_name : 重命名当前表

3.删除表

语法 : drop temporary table if exists 表名 ,表名

示例 : drop table if exists books;


相关推荐
睡不醒男孩0308233 小时前
第二篇:深入探索开源数据库高可用:构建基于CLup的PostgreSQL生产级高可用与读写分离架构
数据库·postgresql·开源·clup
Micro麦可乐5 小时前
Spring Boot 实战:从零设计一个短链系统(含完整代码与数据库设计)
数据库·spring boot·后端·哈希算法·雪花算法·短链系统
码农阿豪5 小时前
从零到一:Spring Boot快速接入金仓数据库实战
数据库·spring boot·后端
鼎讯信通6 小时前
风电光缆运维提质增效:G-4000A 光缆故障追踪仪破解风场巡检难题
运维·网络·数据库
三十..6 小时前
MySQL 从入门到高可用架构实战精要
运维·数据库·mysql
cfm_29147 小时前
Redis五大基本数据结构底层了解
数据结构·数据库·redis
真实的菜8 小时前
Redis 从入门到精通(十二):典型业务场景实战 —— 排行榜、限流器、秒杀系统、Session 共享
数据库·redis·python
你想考研啊8 小时前
mysql数据库导出导入
数据库·mysql·oracle
十年编程老舅9 小时前
Linux DRM:底层逻辑与实践架构
数据库·mysql
The Sheep 20239 小时前
Vue复习
linux·服务器·数据库