百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT技术 > 正文

MySQL命令行常用指令

wptr33 2025-03-04 14:21 23 浏览

前言

在某些环境下开发经常不能使用 Navicat 等数据库界面化客户端,这就要求开发人员退而求其次使用 MySQL自带的命令行客户端。本文主要介绍MySQL 常用的命令,基本上可以平替界面话的操作。

常用命令

常用命令主要有数据库连接、切换数据库、查看表信息、创建索引、创建表、修改表和清空表等。

查看MySQL版本

# 注意 V 是大写
mysql -V

结果如图所示:

用户

-- 创建用户
 create user '<用户名>'@'%' identified by '<密码>';
 
-- 赋予权限
GRANT ALL PRIVILEGES ON *.* TO '<用户名>'@'%';

-- 刷新更改
flush privileges;

连接数据库

mysql -h -u<用户名> -p<密码>

# 示例
mysql -hlocalhost -uroot -p123456

结果如图所示:

切换数据库

use <数据库名>;

-- 示例:
use sys;

结果如图所示:

查看表

查看表信息

show table status;

结果如图所示:

如果列比较多,可以在结尾处将 ; 号改成 \G ,表示每行数据竖向展示。

由上图可以看到 sys 数据库只有一张表 sys_config ,我们可以了解到这张表的数据库引擎是 InnoDB ,还能查询到这张表的创建时间、更新时间、表注释等信息。

查看表结构

-- 查看表结构
describe <表名>;

-- 示例
describe sys_config;

结果如图所示:

由上图可知, sys_config 表有四个字段,它们的字段类型是 varchar 和 timestamp ,字段是否可以为空,字段的默认值等。

但是 describe 命令并不能得到表的索引信息,所以我们还需要 show indexes 命令单独查询表的索引。

查看表索引

-- 查看索引
show indexes from <表名>;

-- 示例
show indexes from sys_config;

结果如图所示:

主要返回字段:

  • Non_unique: 0表示是唯一索引,1表示不是唯一索引
  • Key_name: PRIMARY 表示索引的名字是主键索引
  • Seq_in_index : 索引项在索引定义中的顺序位置。对于单列索引,Seq_in_index 的值总是 1,因为它只有一个列;对于多列复合索引,每一列都会有一个递增的 Seq_in_index 值,指示该列在索引定义中的位置。

例如,假设你有一个表 users,并且在 (first_name, last_name) 上创建了一个复合索引,那么:first_name 在索引中的 Seq_in_index 值将是 1,last_name 在索引中的 Seq_in_index 值将是 2。


创建表

CREATE TABLE table_name (
    column1 datatype constraints,
    column2 datatype constraints,
    column3 datatype constraints,
    ...
    CONSTRAINT constraint_name PRIMARY KEY (column_list)
);

-- 示例
CREATE TABLE `sys_test` (
  `id` bigint NOT NULL AUTO_INCREMENT COMMENT '主键id',
  `name` varchar(255) DEFAULT NULL COMMENT '名称',
  `status` tinyint DEFAULT NULL COMMENT '状态,0:禁用,1:正常',
  `create_time` datetime DEFAULT NULL COMMENT '创建时间',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='测试表';

修改表

添加表字段

ALTER TABLE <表名> ADD COLUMN <字段名> <字段类型>(<字段长度>) NOT[DEFAULT] NULL;

-- 示例
ALTER TABLE sys_test ADD COLUMN name VARCHAR(255) DEFAULT NULL;

修改表字段

ALTER TABLE <表名> MODIFY COLUMN <字段名> <字段类型>(<字段长度>) NOT[DEFAULT] NULL;

-- 示例
ALTER TABLE sys_test MODIFY COLUMN name VARCHAR(255) DEFAULT NULL;

创建唯一索引

CREATE UNIQUE INDEX <索引名> ON <表名>(<字段名>[(字段长度)]);

-- 示例
CREATE UNIQUE INDEX `uk_name` ON `sys_test`(`name`(255));

唯一索引的名字一般是以 uk_ 的前缀开头。如果唯一索引字段是 text 类型的,需要在创建唯一索引的时候指定索引的长度。

创建普通索引

ALTER TABLE <表名> ADD INDEX <索引名>(<字段名>) USING BTREE;

-- 示例
ALTER TABLE `sys_test` ADD INDEX `idx_name`(`name`) USING BTREE;

普通索引的名字一般是以 idx_ 的前缀开头。上述示例给 sys_test 表创建了一个名为 idx_name 的普通索引,索引字段是 name 。

删除索引

-- 两种删除索引的方式
ALTER TABLE <表名> DROP INDEX <索引名>;
DROP INDEX <索引名> ON <表名>;

-- 示例
ALTER TABLE sys_test DROP INDEX idx_name;
DROP INDEX idx_name ON sys_test ;

导出

-- 导出表结构
mysqldump -u[username] -p[password] --no-data --routines --triggers [dbname] > file.sql

-- 示例
mysqldump -uroot -p123456 --no-data --routines --triggers dp-pro > d:\dp-pro.sql
  • u [username] 是你的MySQL用户名;
  • p[password] 之后直接跟上你的密码,或者可以输入p然后按回车键输入密码;
  • -no-data 表示只导出表结构而不导出数据;
  • -routines 和 -triggers 是可选的,如果你的数据库包含存储过程或触发器的话,可以加上这两个选项来包含它们;
  • [dbname] 是你要导出的数据库名。
  • 要将输出保存到一个文件中,可以使用重定向操作符>

清空表

-- truncate
truncate table <表名>;

-- 示例
truncate table sys_test;

-- delete from
delete from <表名>;

-- 示例
delete from sys_test;

truncate 和 delete from 两种清空方式的区别:

  • 清空速度:truncate 不需要逐条删除记录,而delete from 是逐条删除,所以truncate更快,truncate会删除所有数据页,并重置表的大小;
  • 事务处理:truncate 是非事务性操作,而delete from是事务性操作。truncate 之后不能回滚;
  • 自增字段重置:truncate 可以重置 AUTO_INCREMENT 自增字段,delete from 不能重置;
  • 返回行数:truncate 返回0行被影响,因为truncate 是 DDL(数据定义语言) 命令,而delete from是 DML(数据操作语言) 命令;
  • 权限要求:TRUNCATE 需要 DROP 权限,而不仅仅是 DELETE 权限;
  • 条件过滤:DELETE 可以带有 WHERE 子句来删除指定的行,而 TRUNCATE TABLE 不能。

相关推荐

oracle数据导入导出_oracle数据导入导出工具

关于oracle的数据导入导出,这个功能的使用场景,一般是换服务环境,把原先的oracle数据导入到另外一台oracle数据库,或者导出备份使用。只不过oracle的导入导出命令不好记忆,稍稍有点复杂...

继续学习Python中的while true/break语句

上次讲到if语句的用法,大家在微信公众号问了小编很多问题,那么小编在这几种解决一下,1.else和elif是子模块,不能单独使用2.一个if语句中可以包括很多个elif语句,但结尾只能有一个else解...

python continue和break的区别_python中break语句和continue语句的区别

python中循环语句经常会使用continue和break,那么这2者的区别是?continue是跳出本次循环,进行下一次循环;break是跳出整个循环;例如:...

简单学Python——关键字6——break和continue

Python退出循环,有break语句和continue语句两种实现方式。break语句和continue语句的区别:break语句作用是终止循环。continue语句作用是跳出本轮循环,继续下一次循...

2-1,0基础学Python之 break退出循环、 continue继续循环 多重循

用for循环或者while循环时,如果要在循环体内直接退出循环,可以使用break语句。比如计算1至100的整数和,我们用while来实现:sum=0x=1whileTrue...

Python 中 break 和 continue 傻傻分不清

大家好啊,我是大田。今天分享一下break和continue在代码中的执行效果是什么,进一步区分出二者的区别。一、continue例1:当小明3岁时不打印年龄,其余年龄正常循环打印。可以看...

python中的流程控制语句:continue、break 和 return使用方法

Python中,continue、break和return是控制流程的关键语句,用于在循环或函数中提前退出或跳过某些操作。它们的用途和区别如下:1.continue(跳过当前循环的剩余部分,进...

L017:continue和break - 教程文案

continue和break在Python中,continue和break是用于控制循环(如for和while)执行流程的关键字,它们的作用如下:1.continue:跳过当前迭代,...

作为前端开发者,你都经历过怎样的面试?

已经裸辞1个月了,最近开始投简历找工作,遇到各种各样的面试,今天分享一下。其实在职的时候也做过面试官,面试官时,感觉自己问的问题很难区分候选人的能力,最好的办法就是看看候选人的github上的代码仓库...

面试被问 const 是否不可变?这样回答才显功底

作为前端开发者,我在学习ES6特性时,总被const的"善变"搞得一头雾水——为什么用const声明的数组还能push元素?为什么基本类型赋值就会报错?直到翻遍MDN文档、对着内存图反...

2023金九银十必看前端面试题!2w字精品!

导文2023金九银十必看前端面试题!金九银十黄金期来了想要跳槽的小伙伴快来看啊CSS1.请解释CSS的盒模型是什么,并描述其组成部分。答案:CSS的盒模型是用于布局和定位元素的概念。它由内容区域...

前端面试总结_前端面试题整理

记得当时大二的时候,看到实验室的学长学姐忙于各种春招,有些收获了大厂offer,有些还在苦苦面试,其实那时候的心里还蛮忐忑的,不知道自己大三的时候会是什么样的一个水平,所以从19年的寒假放完,大二下学...

由浅入深,66条JavaScript面试知识点(七)

作者:JakeZhang转发链接:https://juejin.im/post/5ef8377f6fb9a07e693a6061目录由浅入深,66条JavaScript面试知识点(一)由浅入深,66...

2024前端面试真题之—VUE篇_前端面试题vue2020及答案

添加图片注释,不超过140字(可选)1.vue的生命周期有哪些及每个生命周期做了什么?beforeCreate是newVue()之后触发的第一个钩子,在当前阶段data、methods、com...

今年最常见的前端面试题,你会做几道?

在面试或招聘前端开发人员时,期望、现实和需求之间总是存在着巨大差距。面试其实是一个交流想法的地方,挑战人们的思考方式,并客观地分析给定的问题。可以通过面试了解人们如何做出决策,了解一个人对技术和解决问...