MySQL 常规操作指南

1. 连接MySQL服务器

(1)通过命令行连接

mysql -u username -p

在提示下输入对应用户的密码,即可进入MySQL命令行界面。

(2)指定数据库连接

mysql -u username -p -D database_name

这里会直接连接到名为database_name的数据库。

2. 数据库管理

(1)创建数据库

CREATE DATABASE database_name;

(2)查看所有数据库

SHOW DATABASES;

(3)选择当前工作数据库

USE database_name;

(4)删除数据库

DROP DATABASE IF EXISTS database_name;

3. 表管理

(1)创建表

CREATE TABLE table_name (
    column1 datatype,
    column2 datatype,
    ...
);

例如:

CREATE TABLE Users (
    id INT PRIMARY KEY,
    username VARCHAR(50),
    password VARCHAR(100)
);

(2)查看所有表

SHOW TABLES;

(3)查看表结构

DESCRIBE table_name;

(4)插入数据

INSERT INTO table_name (column1, column2, ...) VALUES (value1, value2, ...);

(5)查询数据

SELECT * FROM table_name;

(6)更新数据

UPDATE table_name SET column1 = new_value WHERE condition;

(7)删除数据

DELETE FROM table_name WHERE condition;

(8)删除表

DROP TABLE IF EXISTS table_name;

4. 用户与权限管理

(1)创建用户

CREATE USER 'username'@'localhost' IDENTIFIED BY 'password';

(2)赋予用户对数据库的权限

GRANT ALL PRIVILEGES ON database_name.* TO 'username'@'localhost';

(3)撤销权限

REVOKE ALL PRIVILEGES, GRANT OPTION FROM 'username'@'localhost';

(4)更改用户密码

SET PASSWORD FOR 'username'@'localhost' = PASSWORD('new_password');

(5)查看用户权限

SHOW GRANTS FOR 'username'@'localhost';

5. 导入与导出数据

(1)导出数据为SQL文件(备份)

mysqldump -u username -p database_name > backup.sql

(2)导入SQL文件(恢复)

mysql -u username -p database_name < backup.sql

以上涵盖了MySQL中常见的基本操作,包括连接服务器、数据库和表的管理、数据操作以及用户权限管理等。

6. 查询操作

(1)基本查询

SELECT column1, column2, ...
FROM table_name;

这将从table_name表中选择指定的列进行查询。

(2)条件查询

SELECT * FROM table_name
WHERE condition;

例如,查找年龄大于30的所有用户:

SELECT * FROM Users WHERE age > 30;

(3)排序查询

SELECT * FROM table_name
ORDER BY column1 [ASC | DESC], column2 [ASC | DESC];

示例:按年龄降序排列所有用户信息:

SELECT * FROM Users ORDER BY age DESC;

(4)分组查询与聚合函数

SELECT column1, COUNT(column2), AVG(column3)
FROM table_name
GROUP BY column1;

例如,计算每个年龄段用户的平均工资:

SELECT age_group, AVG(salary) 
FROM (
    SELECT id, FLOOR(age / 10) * 10 AS age_group, salary
    FROM Employees
) AS grouped_data
GROUP BY age_group;

(5)连接查询(JOIN)

SELECT t1.column1, t2.column2
FROM table1 AS t1
JOIN table2 AS t2
ON t1.common_column = t2.common_column;

例如,查询每个员工及其所在的部门名称:

SELECT Employees.name, Departments.department_name
FROM Employees
JOIN Departments ON Employees.department_id = Departments.id;

(6)子查询

SELECT * FROM table_name
WHERE column IN (SELECT column FROM another_table WHERE condition);

例如,找出和某个部门有相同员工数量的其他部门:

SELECT d1.department_name, COUNT(e1.id) as employee_count
FROM Departments d1
JOIN Employees e1 ON d1.id = e1.department_id
GROUP BY d1.id
HAVING COUNT(e1.id) = (
    SELECT COUNT(*) 
    FROM Employees 
    WHERE department_id = (SELECT id FROM Departments WHERE department_name = 'Sales')
);

7. CASE表达式或IF()函数实现条件判断的功能

(1)使用CASE表达式实现类似if-else逻辑

SELECT 
    column1,
    CASE 
        WHEN condition1 THEN result1
        WHEN condition2 THEN result2
        ELSE default_result
    END AS computed_column
FROM table_name;

例如,计算员工工资等级:

SELECT 
    employee_name,
    salary,
    CASE 
        WHEN salary > 5000 THEN 'High'
        WHEN salary BETWEEN 3000 AND 5000 THEN 'Medium'
        ELSE 'Low'
    END AS salary_level
FROM Employees;
(2)使用IF()函数实现简单条件判断

MySQL中的IF()函数接收三个参数:条件、满足条件时的结果和不满足条件时的结果。

SELECT 
    column1,
    IF(condition, result_if_true, result_if_false) AS computed_column
FROM table_name;

例如,判断员工是否满勤:

SELECT 
    employee_name,
    attendance_days,
    IF(attendance_days = 30, 'Full Attendance', 'Not Full Attendance') AS attendance_status
FROM EmployeeAttendance;

以上两种方式都可以帮助我们在SQL查询中实现类似if-else的逻辑控制。在更复杂的场景下,可能需要结合多个CASE表达式或者嵌套使用IF()函数来完成更为复杂的业务逻辑处理。

以上是MySQL中的常见查询操作,涵盖了基本查询、条件筛选、排序、分组统计、连接查询以及子查询等场景

  • 13
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
当你需要在Python中使用MySQL数据库时,你需要安装Python的MySQL驱动程序。Python的MySQL驱动程序有很多,比如MySQLdb、PyMySQLmysql-connector-python等。这里我们以mysql-connector-python为例进行介绍。 1. 安装mysql-connector-python 你可以使用pip命令来安装mysql-connector-python: ``` pip install mysql-connector-python ``` 2. 连接MySQL数据库 在使用mysql-connector-python之前,你需要先连接到MySQL数据库。连接MySQL数据库的代码如下: ```python import mysql.connector mydb = mysql.connector.connect( host="localhost", user="yourusername", password="yourpassword", database="mydatabase" ) print(mydb) ``` 在上面的代码中,你需要将host、user、password和database替换为你自己的MySQL数据库信息。 3. 创建数据库表 在连接到MySQL数据库之后,你可以使用execute()方法来执行SQL语句。下面的代码演示了如何创建一个名为customers的数据库表: ```python import mysql.connector mydb = mysql.connector.connect( host="localhost", user="yourusername", password="yourpassword", database="mydatabase" ) mycursor = mydb.cursor() mycursor.execute("CREATE TABLE customers (name VARCHAR(255), address VARCHAR(255))") ``` 4. 插入数据 插入数据的代码如下: ```python import mysql.connector mydb = mysql.connector.connect( host="localhost", user="yourusername", password="yourpassword", database="mydatabase" ) mycursor = mydb.cursor() sql = "INSERT INTO customers (name, address) VALUES (%s, %s)" val = ("John", "Highway 21") mycursor.execute(sql, val) mydb.commit() print(mycursor.rowcount, "record inserted.") ``` 5. 查询数据 查询数据的代码如下: ```python import mysql.connector mydb = mysql.connector.connect( host="localhost", user="yourusername", password="yourpassword", database="mydatabase" ) mycursor = mydb.cursor() mycursor.execute("SELECT * FROM customers") myresult = mycursor.fetchall() for x in myresult: print(x) ``` 以上就是Python使用MySQL数据库的基本操作,你可以根据自己的需求进行修改和扩展。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值