mysql mysqldump_mysql mysqldump_mysql mysqldump

前言

在某些环境下开发经常不能使用 等数据库界面化客户端,这就要求开发人员退而求其次使用 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

结果如图所示:

mysql mysqldump_mysql mysqldump_mysql mysqldump

切换数据库

use ;
-- 示例:
use sys;

结果如图所示:

查看表查看表信息

show table status;

结果如图所示:

mysql mysqldump_mysql mysqldump_mysql mysqldump

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

mysql mysqldump_mysql mysqldump_mysql mysqldump

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

查看表结构

-- 查看表结构
describe ;
-- 示例
describe sys_config;

结果如图所示:

mysql mysqldump_mysql mysqldump_mysql mysqldump

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

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

查看表索引

-- 查看索引
show indexes from ;
-- 示例
show indexes from sys_config;

结果如图所示:

mysql mysqldump_mysql mysqldump_mysql mysqldump

主要返回字段:

例如,假设你有一个表 users,并且在 (, ) 上创建了一个复合索引,那么: 在索引中的 值将是 1, 在索引中的 值将是 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_ 的前缀开头。上述示例给 表创建了一个名为 的普通索引,索引字段是 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

清空表

-- truncate
truncate table ;
-- 示例
truncate table sys_test;
-- delete from
delete from ;
-- 示例
delete from sys_test;

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


限时特惠:
本站持续每日更新海量各大内部创业课程,一年会员仅需要98元,全站资源免费下载
点击查看详情

站长微信:Jiucxh

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注