MySQL基础语句

1. 数据库操作

创建数据库

sql

复制

复制代码
CREATE DATABASE database_name;

示例:

sql

复制

复制代码
CREATE DATABASE company;
删除数据库

sql

复制

复制代码
DROP DATABASE database_name;

示例:

sql

复制

复制代码
DROP DATABASE company;
查看所有数据库

sql

复制

复制代码
SHOW DATABASES;
选择数据库

sql

复制

复制代码
USE database_name;

示例:

sql

复制

复制代码
USE company;

2. 表操作

创建表

sql

复制

复制代码
CREATE TABLE table_name (
    column1 datatype constraints,
    column2 datatype constraints,
    ...
) COMMENT '表注释';

示例:

sql

复制

复制代码
CREATE TABLE employees (
    id INT PRIMARY KEY AUTO_INCREMENT COMMENT '员工编号',
    name VARCHAR(50) NOT NULL COMMENT '姓名',
    age TINYINT UNSIGNED COMMENT '年龄',
    salary DECIMAL(10, 2) COMMENT '薪水'
) COMMENT '员工表';
查看所有表

sql

复制

复制代码
SHOW TABLES;
查看表结构

sql

复制

复制代码
DESC table_name;

示例:

sql

复制

复制代码
DESC employees;
删除表

sql

复制

复制代码
DROP TABLE table_name;

示例:

sql

复制

复制代码
DROP TABLE employees;
修改表结构
  • 添加列:

    sql

    复制

    复制代码
    ALTER TABLE table_name ADD column_name datatype;

    示例:

    sql

    复制

    复制代码
    ALTER TABLE employees ADD email VARCHAR(100);
  • 删除列:

    sql

    复制

    复制代码
    ALTER TABLE table_name DROP COLUMN column_name;

    示例:

    sql

    复制

    复制代码
    ALTER TABLE employees DROP COLUMN email;
  • 修改列数据类型:

    sql

    复制

    复制代码
    ALTER TABLE table_name MODIFY column_name new_datatype;

    示例:

    sql

    复制

    复制代码
    ALTER TABLE employees MODIFY name VARCHAR(100);
  • 重命名表:

    sql

    复制

    复制代码
    RENAME TABLE old_table_name TO new_table_name;

    示例:

    sql

    复制

    复制代码
    RENAME TABLE employees TO staff;

3. 数据操作

插入数据

sql

复制

复制代码
INSERT INTO table_name (column1, column2, ...)
VALUES (value1, value2, ...);

示例:

sql

复制

复制代码
INSERT INTO employees (name, age, salary)
VALUES ('张三', 25, 5000.00);
查询数据
  • 查询所有数据:

    sql

    复制

    复制代码
    SELECT * FROM table_name;

    示例:

    sql

    复制

    复制代码
    SELECT * FROM employees;
  • 查询特定列:

    sql

    复制

    复制代码
    SELECT column1, column2 FROM table_name;

    示例:

    sql

    复制

    复制代码
    SELECT name, salary FROM employees;
  • 条件查询:

    sql

    复制

    复制代码
    SELECT * FROM table_name WHERE condition;

    示例:

    sql

    复制

    复制代码
    SELECT * FROM employees WHERE age > 30;
  • 排序查询:

    sql

    复制

    复制代码
    SELECT * FROM table_name ORDER BY column_name ASC|DESC;

    示例:

    sql

    复制

    复制代码
    SELECT * FROM employees ORDER BY salary DESC;
  • 限制查询结果:

    sql

    复制

    复制代码
    SELECT * FROM table_name LIMIT number;

    示例:

    sql

    复制

    复制代码
    SELECT * FROM employees LIMIT 5;
更新数据

sql

复制

复制代码
UPDATE table_name
SET column1 = value1, column2 = value2, ...
WHERE condition;

示例:

sql

复制

复制代码
UPDATE employees
SET salary = 6000.00
WHERE name = '张三';
删除数据

sql

复制

复制代码
DELETE FROM table_name WHERE condition;

示例:

sql

复制

复制代码
DELETE FROM employees WHERE id = 1;

4. 约束

主键约束

sql

复制

复制代码
CREATE TABLE table_name (
    id INT PRIMARY KEY,
    ...
);
唯一约束

sql

复制

复制代码
CREATE TABLE table_name (
    email VARCHAR(100) UNIQUE,
    ...
);
非空约束

sql

复制

复制代码
CREATE TABLE table_name (
    name VARCHAR(50) NOT NULL,
    ...
);
外键约束

sql

复制

复制代码
CREATE TABLE orders (
    order_id INT PRIMARY KEY,
    user_id INT,
    FOREIGN KEY (user_id) REFERENCES users(id)
);

5. 其他常用操作

清空表数据

sql

复制

复制代码
TRUNCATE TABLE table_name;

示例:

sql

复制

复制代码
TRUNCATE TABLE employees;
复制表结构

sql

复制

复制代码
CREATE TABLE new_table LIKE old_table;

示例:

sql

复制

复制代码
CREATE TABLE employees_backup LIKE employees;
复制表数据

sql

复制

复制代码
INSERT INTO new_table SELECT * FROM old_table;

示例:

sql

复制

复制代码
INSERT INTO employees_backup SELECT * FROM employees;

6. 查询优化

添加索引

sql

复制

复制代码
CREATE INDEX index_name ON table_name (column_name);

示例:

sql

复制

复制代码
CREATE INDEX idx_name ON employees (name);
查看索引

sql

复制

复制代码
SHOW INDEX FROM table_name;

示例:

sql

复制

复制代码
SHOW INDEX FROM employees;
删除索引

sql

复制

复制代码
DROP INDEX index_name ON table_name;

示例:

sql

复制

复制代码
DROP INDEX idx_name ON employees;

7. 用户和权限管理

创建用户

sql

复制

复制代码
CREATE USER 'username'@'host' IDENTIFIED BY 'password';

示例:

sql

复制

复制代码
CREATE USER 'admin'@'localhost' IDENTIFIED BY '123456';
授予权限

sql

复制

复制代码
GRANT permission ON database_name.table_name TO 'username'@'host';

示例:

sql

复制

复制代码
GRANT ALL PRIVILEGES ON company.* TO 'admin'@'localhost';
撤销权限

sql

复制

复制代码
REVOKE permission ON database_name.table_name FROM 'username'@'host';

示例:

sql

复制

复制代码
REVOKE ALL PRIVILEGES ON company.* FROM 'admin'@'localhost';
刷新权限

sql

复制

复制代码
FLUSH PRIVILEGES;

以上是 MySQL 的基本语句,涵盖了数据库、表、数据的操作。如果你有更具体的需求或问题,可以随时告诉我!

相关推荐
较劲男子汉7 分钟前
CANN Runtime零拷贝传输技术源码实战 彻底打通Host与Device的数据传输壁垒
运维·服务器·数据库·cann
java搬砖工-苤-初心不变12 分钟前
MySQL 主从复制配置完全指南:从原理到实践
数据库·mysql
WangYaolove13142 小时前
基于python的在线水果销售系统(源码+文档)
python·mysql·django·毕业设计·源码
山岚的运维笔记2 小时前
SQL Server笔记 -- 第18章:Views
数据库·笔记·sql·microsoft·sqlserver
roman_日积跬步-终至千里3 小时前
【LangGraph4j】LangGraph4j 核心概念与图编排原理
java·服务器·数据库
汇智信科3 小时前
打破信息孤岛,重构企业效率:汇智信科企业信息系统一体化运营平台
数据库·重构
野犬寒鸦3 小时前
从零起步学习并发编程 || 第六章:ReentrantLock与synchronized 的辨析及运用
java·服务器·数据库·后端·学习·算法
霖霖总总3 小时前
[小技巧66]当自增主键耗尽:MySQL 主键溢出问题深度解析与雪花算法替代方案
mysql·算法
晚霞的不甘5 小时前
揭秘 CANN 内存管理:如何让大模型在小设备上“轻装上阵”?
前端·数据库·经验分享·flutter·3d
市场部需要一个软件开发岗位5 小时前
JAVA开发常见安全问题:纵向越权
java·数据库·安全