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

MySQL命令行常用指令

csdh11 2025-02-06 14:30 16 浏览

前言

在某些环境下开发经常不能使用 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 不能。

相关推荐

pdf怎么在线阅读?这几种在线阅读方法看看

pdf怎么在线阅读?我们日常生活中经常使用到pdf文档。这种格式的文档在不同平台和设备上的可移植性,以及保留文档格式和布局的能力都很强。在阅读这种文档的时候,很多人会选择使用在线阅读的方法。在线阅读P...

PDF比对不再眼花缭乱:开源神器diff-pdf助你轻松揪出差异

PDF比对不再眼花缭乱:开源神器diff-pdf助你轻松揪出差异在日常工作和学习中,PDF文件可谓是无处不在。然而,有时我们需要比较两个PDF文件之间的差异,这可不是一件轻松的事情。手动逐页对比简直是...

全网爆火!580页Python编程快速上手,零基础也能轻松学会

Python虽然一向号称新手友好,但对完全零基础的编程小白来讲,总会在很长时间内,都对某些概念似懂非懂,每次拿起书本教程,都要从第一章看起。对于这种迟迟入不了门的情况,给大家推荐一份简单易懂的入门级教...

我的名片能运行Linux和Python,还能玩2048小游戏,成本只要20元

晓查发自凹非寺量子位报道|公众号QbitAI猜猜它是什么?印着姓名、职位和邮箱,看起来是个名片。可是右下角有芯片,看起来又像是个PCB电路板。其实它是一台超迷你的ARM计算机,不仅能够运...

由浅入深学shell,70页shell脚本编程入门,满满干货建议收藏

不会Linux的程序员不是好程序员,不会shell编程就不能说自己会Linux。shell作为Unix第一个脚本语言,结合了延展性和高效的优点,保持独有的编程特色,并不断地优化,使得它能与其他脚本语言...

真工程师:20块钱做了张「名片」,可以跑Linux和Python

机器之心报道参与:思源、杜伟、泽南对于一个工程师来说,如何在一张名片上宣告自己的实力?在上面制造一台完整的计算机说不定是个好主意。最近,美国一名嵌入式系统工程师GeorgeHilliard的名片...

《Linux 命令行大全》.pdf

今天跟大家推荐个Linux命令行教程:《TheLinuxCommandLine》,中文译名:《Linux命令行大全》。该书作者出自自美国一名开发者,兼知名Linux博客LinuxCo...

PDF转换是难题? 搜狗浏览器即开即看

由于PDF文件兼容性相当广泛,越来越多的电子图书、产品说明、公司文告、网络资料、电子邮件选择开始使用这种格式来进行内容的展示,以便给用户更好的再现原稿的细节,但需要下载专用阅读器进行转化才能浏览的问题...

彻底搞懂 Netty 线程模型

点赞再看,养成习惯,微信搜一搜【...

2022通俗易懂Redis的线程模型看完就会

Redis真的是单线程吗?我们一般说Redis是单线程,是指Redis的网络IO和键值对操作是一个线程完成的,这就是Redis对外提供键值存储服务的主要流程。Redis的其他功能,例如持久化、异步删除...

实用C语言编程(第三版)高清PDF

编写C程序不仅仅需要语法正确,最关键的是所编代码应该便于维护和修改。现在有很多介绍C语言的著作,但是本书在这一方面的确与众不同,例如在讨论C中运算优先级时,15种级别被归纳为下面两条原则:需要的...

手拉手教你搭建redis集群(redis cluster)

背景:最近需要使用redis存储数据,但是随着时间的增加,发现原本的单台redis已经不满足要求了,于是就倒腾了一下搭建redistclusterredis集群。好了,话不多说,下面开始展示:...

记录处理登录页面显示: HTTP Error 503. The service is unavailable.

某天一个系统的登录页面无法显示,显示ServiceUnavailableHTTPError503.Theserviceisunavailable,马上登录服务器上查看IIS是否正常。...

黑道圣徒杀出地狱破解版下载 免安装硬盘版

游戏名称:黑道圣徒杀出地狱英文名称:SaintsRow:GatOutofHell游戏类型:动作冒险类(ACT)游戏游戏制作:DeepSilverVolition/HighVoltage...

Exchange Server 2019 实战操作指南

...