当前位置: 首页 > article >正文

MySQL的基础用法一

数据库的操作

对库的操作

对库中表的操作


🚘🚘🚘正片开始

SQL通用语法规则介绍

  1. SQL语句可以单行或多行书写,以分号结尾。

  2. SQL语句可以使用空格和缩进来增强语句的可读性。

  3. MySQL数据库的SQL语句不区分大小写,关键字建议使用大写,但没强制规定。

  4. 注释:

    • 单行注释:-- + 注释内容 或者 # +注释内容(MySQL特有)
    • 多行注释:/* 注释内容 */

创建数据库语法

create database [if not exists] 数据库名 [default 字符集][collate 排序规则];

注:使用上述语法时,[ ] 中的语法可以省略不写

创建数据库展示效果

mysql> create database test;
Query OK, 1 row affected (0.01 sec)

mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| my_db              |
| mysql              |
| performance_schema |
| sys                |
| test               |
+--------------------+
6 rows in set (0.00 sec)

mysql>

当test数据库已存在时我们再次创建则会怎么样呢?让我们来试试。

mysql> create database test;
ERROR 1007 (HY000): Can't create database 'test'; database exists
mysql>

可以看见它反馈的结果是说不能创建数据库,数据库已存在

不妨我们使用一下 if not exists 这个看看

mysql> create database if not exists test;
Query OK, 1 row affected, 1 warning (0.01 sec)

mysql>

现在没有报错了,只是出现了个警告,在创建数据库时,当加上这个if not exists 则系统会检测你当前库中是否有同名的test数据库如果有则不创建,没有则创建。

使用数据库语法

use 数据库名;

展示效果

mysql> use test;
Database changed
mysql>

查询所有数据库语法

show databases;

效果展示

mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| my_db              |
| mysql              |
| performance_schema |
| sys                |
| test               |
+--------------------+
6 rows in set (0.00 sec)

mysql>

查询当前所处数据库语法

select database();

展示效果

mysql> select database();
+------------+
| database() |
+------------+
| test       |  #当前处于test数据库
+------------+
1 row in set (0.00 sec)

mysql>

删除数据库语法

drop database [if exists] 数据库名;

展示效果

删除前该库中是有test数据库的

mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| my_db              |
| mysql              |
| performance_schema |
| sys                |
| test               |
+--------------------+
6 rows in set (0.00 sec)
mysql>

执行删除语句

#test删除成功

mysql> drop database test;
Query OK, 0 rows affected (0.01 sec)

mysql>

再次查看数据库中是否有test库

mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| my_db              |
| mysql              |
| performance_schema |
| sys                |
+--------------------+
5 rows in set (0.00 sec)

mysql>

可以看见已经没有了

当使用 drop database if not exists 数据库名;这条语句删数据库时 则有该数据库则删除,无则不删,更有安全保障。

创建一个表的语法

create table 表名(
		字段1 字段1的类型[comment 字段1的注释],
		字段2 字段2的类型[comment 字段2的注释],
		字段3 字段3的类型[comment 字段3的注释],
		字段4 字段4的类型[comment 字段4的注释],
		……………………………………………………………
		字段n 字段n的类型[comment 字段n的注释]
)[comment 表注释];

展示效果

mysql> create table mytable(
    ->     id tinyint comment '编号',
    ->     name varchar(5) comment '名字',
    ->     age tinyint comment '年龄',
    ->     address  varchar(15) comment '地址',
    ->     tel  char(11) comment '电话'
    -> );
Query OK, 0 rows affected (0.03 sec)

mysql>

查询当前数据库所有表的语法

show tables;

展示效果

mysql> show tables;
+----------------+
| Tables_in_test |
+----------------+
| mytable        | #mytable 已经创建出来了
+----------------+
1 row in set (0.00 sec)

mysql> select database();

查询表结构的语法

desc mytable;
mysql> desc mytable;
+---------+-------------+------+-----+---------+-------+
| Field   | Type        | Null | Key | Default | Extra |
+---------+-------------+------+-----+---------+-------+
| id      | tinyint     | YES  |     | NULL    |       |
| name    | varchar(5)  | YES  |     | NULL    |       |
| age     | tinyint     | YES  |     | NULL    |       |
| address | varchar(15) | YES  |     | NULL    |       |
| tel     | char(11)    | YES  |     | NULL    |       |
+---------+-------------+------+-----+---------+-------+
5 rows in set (0.00 sec)

mysql>

查询指定表的建表语句的语法

show create table mytable;

展示效果

mysql> show create table mytable;
CREATE TABLE `mytable` (
  `id` tinyint DEFAULT NULL COMMENT '编号',
  `name` varchar(5) DEFAULT NULL COMMENT '名字',
  `age` tinyint DEFAULT NULL COMMENT '年龄',
  `address` varchar(15) DEFAULT NULL COMMENT '地址',
  `tel` char(11) DEFAULT NULL COMMENT '电话'
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci

完结🎉🎉🎉


http://www.kler.cn/a/320378.html

相关文章:

  • HarmonyOS NEXT开发进阶(六):HarmonyOS NEXT实现嵌套 H5 及双向通信
  • CVE-2025-22777 (CVSS 9.8):WordPress | GiveWP 插件的严重漏洞
  • Rank-Analysis——LOL 排位战绩查询分析器
  • 后端技术选型 sa-token校验学习 中 文档学习
  • 网络应用技术 实验七:实现无线局域网
  • 深入 Flutter 和 Compose 在 UI 渲染刷新时 Diff 实现对比
  • 【论文阅读】视觉里程计攻击
  • 【机器学习】Zygote.jl
  • ollydbg 小记
  • 每天一道面试题(17):服务网格学习笔记
  • 社区团购的创新与变革——融合开源链动 2+1 模式、AI 智能名片及 S2B2C 商城小程序
  • 2024一线大厂网络安全面试题+答案,看完offe拿到手软!
  • .NET 反序列化加载哥斯拉内存马的工具
  • 计算机毕业设计 基于Python医院预约挂号系统 Django+Vue 前后端分离 附源码 讲解 文档
  • 大语言模型之LlaMA系列- LlaMA 2及LLaMA2_chat(上)
  • 【OSS安全最佳实践】对OSS表格文件中的敏感数据进行脱敏
  • 3分钟,教你判断自己适不适合做项目管理!
  • 前端开发之原型模式
  • FPGA题目记录2
  • 【RDMA】mlxconfig修改和查询网卡(固件)配置--驱动工具
  • 双十一好货推荐有哪些?五大双十一种草好物推荐!
  • chatgpt复旦大学张奇老师《自然语言处理导论》AI好书PDF分享,不看后悔一辈子!
  • 【计算机网络 - 基础问题】每日 3 题(二十三)
  • Java 序列化:为什么你应该手动定义 serialVersionUID?@Serial 注解有什么作用?
  • python基础:函数、模块、库
  • AI篮球投篮分析与投篮姿势的机器学习应用