MySQL 常用操作指南(Shell 环境)

一、Shell 中导入/导出数据

1. 本地导入数据(LOAD DATA LOCAL INFILE)

复制代码
mysql -u root -p -e "LOAD DATA LOCAL INFILE '/path/to/file.csv' INTO TABLE stu.students FIELDS TERMINATED BY ',' LINES TERMINATED BY '\n' IGNORE 1 ROWS;"

注意: 需确保 MySQL 启用了 local_infile(默认可能关闭):

复制代码
SHOW VARIABLES LIKE 'local_infile'; -- 查看
SET GLOBAL local_infile = 'ON';     -- 临时开启(需权限)
  • 客户端连接时也要加 --local-infile=1

    复制代码
    mysql --local-infile=1 -u root -p
  • IGNORE 1 ROWS 跳过 CSV 的标题行。

  • 文件路径是客户端所在机器的路径(不是数据库服务器)。


2. 导出数据(mysqldump)

基础导出表结构+数据:
复制代码
mysqldump -u root -p123456 stu students > /root/data/mydb.sql

⚠️ 安全警告 :密码明文写在命令行会泄露(可通过 history 查看)。
推荐做法

  • 使用配置文件(~/.my.cnf):

    复制代码
    [client]
    user=root
    password=123456

    然后:

    复制代码
    mysqldump stu students > /root/data/mydb.sql
  • 或交互式输入密码(不写 -p123456,只写 -p

导出仅数据(无建表语句):
复制代码
mysqldump -u root -p --no-create-info stu students > data_only.sql
导出仅结构(无数据):
复制代码
mysqldump -u root -p --no-data stu students > schema_only.sql
备份并压缩(推荐):
复制代码
alias db_backup='mysqldump -u root -p --single-transaction --quick --lock-tables=false stu students | gzip > /root/data/mydb_$(date +%Y%m%d).sql.gz'

参数说明

  • --single-transaction:InnoDB 一致性快照(避免锁表)
  • --quick:逐行读取,防内存溢出
  • --lock-tables=false:配合 --single-transaction 避免锁

二、查看 DDL 与当前数据库

复制代码
-- 查看建表语句(修正拼写错误:show create table)
SHOW CREATE TABLE students\G

-- 查看当前数据库
SELECT DATABASE();
-- 或
STATUS;  -- 显示更多信息,包括当前库

三、LIMIT 限制查询

复制代码
-- 前10条
SELECT * FROM students LIMIT 10;

-- 分页:跳过前20条,取10条(第3页)
SELECT * FROM students LIMIT 20, 10;
-- 或
SELECT * FROM students LIMIT 10 OFFSET 20;

注意LIMITORDER BY 时结果顺序不确定!


四、ALTER TABLE 表结构修改(扩展与规范)

增加字段(ADD)

复制代码
-- 推荐指定位置(如 FIRST / AFTER)
ALTER TABLE students ADD COLUMN enroll_date DATE DEFAULT '2025-12-12' AFTER name;

修改字段(MODIFY vs CHANGE)

操作 语法 用途
MODIFY MODIFY column_name new_type [options] 改类型/属性,不改名
CHANGE CHANGE old_name new_name new_type [options] 可改名+改类型
复制代码
-- MODIFY:只改类型和注释
ALTER TABLE students MODIFY dateT DATETIME COMMENT '入学时间';

-- CHANGE:改名 + 改类型
ALTER TABLE students CHANGE stu_id student_id VARCHAR(50) NOT NULL;

🔔 重要MODIFY 必须重写完整字段定义(类型、是否为空、默认值等),否则会被重置!

删除字段(DROP)

复制代码
ALTER TABLE students DROP COLUMN length;

修改字符集

复制代码
-- 修改表字符集(不影响已有数据编码!)
ALTER TABLE students CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;

-- 更彻底(同时转数据):
ALTER TABLE students CONVERT TO CHARACTER SET utf8mb4;

建议使用 utf8mb4(支持 emoji),而非 utf8(MySQL 的伪 utf8)

重命名表

复制代码
RENAME TABLE students TO student_info;
-- 或
ALTER TABLE students RENAME TO student_info;

五、删除表(DROP)

复制代码
-- 删除表(结构+数据全丢)
DROP TABLE students;

-- 安全写法:先检查是否存在
DROP TABLE IF EXISTS students;

六、补充:实用 Shell 脚本技巧

1. 自动备份脚本(带日期、压缩、日志)

复制代码
#!/bin/bash
DATE=$(date +%Y%m%d_%H%M)
BACKUP_DIR="/backup/mysql"
DB="stu"
TABLE="students"
USER="root"

mkdir -p $BACKUP_DIR

mysqldump --single-transaction -u$USER $DB $TABLE | gzip > $BACKUP_DIR/${DB}_${TABLE}_$DATE.sql.gz

echo "$(date): Backup completed: ${DB}_${TABLE}_$DATE.sql.gz" >> /var/log/db_backup.log

2. 设置定时任务(crontab)

复制代码
# 每天凌晨2点备份
0 2 * * * /root/scripts/db_backup.sh

七、安全与最佳实践总结

项目 建议
密码 不要明文写命令行,用 .my.cnf 或交互输入
备份 --single-transaction + 压缩 + 保留多版本
字符集 统一用 utf8mb4
ALTER 大表结构变更谨慎操作(可能锁表)
LOAD DATA 注意文件权限、路径、分隔符匹配
权限 生产环境避免用 root,创建专用账号
相关推荐
数据知道2 小时前
PostgreSQL 性能优化:连接数过多的原因分析与连接池方案
数据库·postgresql·性能优化
怣502 小时前
MySQL子查询实战指南:数据操作(增删改查)与通用表达式
数据库·chrome·mysql
范纹杉想快点毕业2 小时前
从单片机基础到程序框架:构建嵌入式系统的完整路径
数据库·mongodb
数据知道2 小时前
PostgreSQL性能优化:如何定期清理无用索引以释放磁盘空间(索引膨胀监控)
数据库·postgresql·性能优化
喵叔哟2 小时前
67.【.NET8 实战--孢子记账--从单体到微服务--转向微服务】--新增功能--分摊功能总体设计与业务流程
数据库·微服务·架构
tryCbest2 小时前
Oracle查看存储过程
数据库·oracle
咩咩不吃草2 小时前
【MySQL】表和列、增删改查语句及数据类型约束详解
数据库·mysql·语法
不懒不懒2 小时前
【MySQL 实战:从零搭建规范用户表(含完整 SQL 与避坑指南)】
数据库
ID_180079054732 小时前
Python结合淘宝关键词API进行商品价格监控与预警
服务器·数据库·python