MySQL常用指令

一、连接与退出 MySQL

复制代码
-- 连接本地MySQL(默认端口3306)
mysql -u 用户名 -p

-- 连接远程MySQL
mysql -h 主机地址 -u 用户名 -p 端口号

-- 退出MySQL
exit; 或 quit;

二、数据库操作

复制代码
-- 查看所有数据库
show databases;

-- 创建数据库
create database 数据库名;

-- 创建数据库并指定字符集
create database 数据库名 character set utf8mb4;

-- 选择数据库
use 数据库名;

-- 删除数据库
drop database 数据库名;

-- 查看当前使用的数据库
select database();

三、数据表操作

复制代码
-- 查看当前数据库所有表
show tables;

-- 创建表
create table 表名 (
  字段1 数据类型 [约束],
  字段2 数据类型 [约束],
  ...
  primary key (主键字段)
);

-- 示例:创建用户表
create table users (
  id int auto_increment,
  name varchar(50) not null,
  age int,
  email varchar(100) unique,
  primary key (id)
);

-- 查看表结构
desc 表名; 或 describe 表名;

-- 修改表名
alter table 旧表名 rename to 新表名;

-- 添加字段
alter table 表名 add 字段名 数据类型 [约束];

-- 修改字段
alter table 表名 modify 字段名 新数据类型 [新约束];

-- 删除字段
alter table 表名 drop 字段名;

-- 删除表
drop table 表名;

四、数据操作(CRUD)

复制代码
-- 插入数据
insert into 表名 (字段1, 字段2, ...) values (值1, 值2, ...);

-- 示例
insert into users (name, age, email) values ('张三', 25, 'zhangsan@example.com');

-- 查询数据
select 字段1, 字段2 from 表名 [where 条件];

-- 查询所有字段
select * from 表名;

-- 带条件查询
select * from users where age > 18;

-- 排序查询
select * from users order by age desc; -- 降序
select * from users order by age asc;  -- 升序(默认)

-- 更新数据
update 表名 set 字段1=值1, 字段2=值2 where 条件;

-- 示例
update users set age=26 where name='张三';

-- 删除数据
delete from 表名 where 条件;

-- 示例
delete from users where id=1;

五、条件查询与高级操作

复制代码
-- 模糊查询
select * from users where name like '%张%';

-- 范围查询
select * from users where age between 18 and 30;

-- 聚合函数
select count(*) from users; -- 统计总数
select avg(age) from users; -- 平均值
select max(age) from users; -- 最大值
select min(age) from users; -- 最小值
select sum(age) from users; -- 总和

-- 分组查询
select age, count(*) from users group by age;

-- 分页查询(MySQL特有)
select * from users limit 10 offset 0; -- 从第0条开始,查询10条
select * from users limit 10; -- 简写,默认从0开始

六、索引操作

复制代码
-- 创建索引
create index 索引名 on 表名(字段名);

-- 查看表索引
show index from 表名;

-- 删除索引
drop index 索引名 on 表名;

七、用户与权限管理

复制代码
-- 创建用户
create user '用户名'@'主机地址' identified by '密码';

-- 授权(所有权限)
grant all privileges on 数据库名.* to '用户名'@'主机地址';

-- 刷新权限
flush privileges;

-- 查看用户权限
show grants for '用户名'@'主机地址';

-- 撤销权限
revoke 权限 on 数据库名.* from '用户名'@'主机地址';

-- 删除用户
drop user '用户名'@'主机地址';
相关推荐
马尔代夫哈哈哈3 小时前
Spring IoC&DI
数据库·sql
液态不合群5 小时前
[特殊字符] MySQL 覆盖索引详解
数据库·mysql
计算机毕设VX:Fegn08955 小时前
计算机毕业设计|基于springboot + vue蛋糕店管理系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
瀚高PG实验室5 小时前
PostgreSQL到HighgoDB数据迁移
数据库·postgresql·瀚高数据库
打码人的日常分享6 小时前
智能制造数字化工厂解决方案
数据库·安全·web安全·云计算·制造
三水不滴6 小时前
Redis 过期删除与内存淘汰机制
数据库·经验分享·redis·笔记·后端·缓存
-孤存-7 小时前
MyBatis数据库配置与SQL操作全解析
数据库·mybatis
2301_822366358 小时前
使用Scikit-learn构建你的第一个机器学习模型
jvm·数据库·python
万邦科技Lafite9 小时前
一键获取京东商品评论信息,item_reviewAPI接口指南
java·服务器·数据库·开放api·淘宝开放平台·京东开放平台
自可乐9 小时前
Milvus向量数据库/RAG基础设施学习教程
数据库·人工智能·python·milvus