MySQL数据库学习(小白一文掌握Mysql)

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS PostgreSQL,高可用系列 2核4GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: MySQL数据库学习(小白一文掌握Mysql)

Python 是一种高级编程语言,它可以轻松地与各种数据库进行交互,其中包括 MySQL 数据库。MySQL 是一种开源的关系型数据库管理系统,被广泛应用于各种应用程序和网站的后端。在本文中,我将介绍如何使用 Python 操作 MySQL 数据库,并提供一些代码示例。


安装 MySQL Connector

在开始使用 Python 操作 MySQL 数据库之前,我们需要安装一个 Python MySQL Connector。有很多 Python MySQL Connector 可供选择,其中包括 MySQLdb、PyMySQL 和 mysql-connector-python。在本文中,我将使用 mysql-connector-python。你可以使用以下命令来安装 mysql-connector-python:

pip install mysql-connector-python


连接到 MySQL 数据库

在使用 Python 操作 MySQL 数据库之前,我们需要建立一个连接。在连接到 MySQL 数据库时,我们需要提供以下信息:


  • 主机名或 IP 地址
  • 用户名
  • 密码
  • 数据库名称


我们可以使用以下代码来连接到 MySQL 数据库:

import mysql.connector

mydb = mysql.connector.connect(
  host="localhost",
  user="yourusername",
  password="yourpassword",
  database="mydatabase"
)

print(mydb)


在上面的代码中,我们使用 mysql.connector 模块来连接到 MySQL 数据库。我们提供了主机名、用户名、密码和数据库名称作为参数。如果连接成功,将打印出连接对象的详细信息。


创建数据库和表

在连接到MySQL 数据库之后,我们可以通过 Python 来创建数据库和表。下面是一些常用的 SQL 命令:


  • 创建数据库:CREATE DATABASE databasename
  • 创建表:CREATE TABLE tablename (column1 datatype, column2 datatype, column3 datatype, ... )


我们可以使用以下代码来创建一个名为 customers 的表:

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))")


在上面的代码中,我们首先连接到 MySQL 数据库,然后创建一个名为 customers 的表。这个表包含两个列:nameaddress,它们的数据类型分别为 VARCHAR(255)


插入数据

在创建表之后,我们可以使用 Python 向表中插入数据。下面是一些常用的 SQL 命令:


  • 插入数据:INSERT INTO tablename (column1, column2, column3, ...) VALUES (value1, value2, value3, ...)


我们可以使用以下代码向 customers 表中插入一条记录:

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.")

在上面的代码中,我们首先连接到 MySQL 数据库,然后向 customers 表中插入一条记录。我们使用了占位符 %s 来代替实际的值,然后在执行 SQL 语句之前将值传递给 execute() 方法。


最后,我们调用 commit() 方法来保存更改,然后打印出插入的记录数。


查询数据

在插入数据之后,我们可以使用 Python 查询表中的数据。下面是一些常用的 SQL 命令:


  • 查询数据:SELECT column1, column2, column3, ... FROM tablename
  • 条件查询:SELECT column1, column2, column3, ... FROM tablename WHERE condition


我们可以使用以下代码查询 customers 表中的所有记录:


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)

在上面的代码中,我们首先连接到 MySQL 数据库,然后执行 SELECT * FROM customers 命令查询 customers 表中的所有记录。我们使用 fetchall() 方法获取所有查询结果,然后使用循环打印出每条记录。


更新数据

在查询数据之后,我们可以使用 Python 更新表中的数据。下面是一些常用的 SQL 命令:

  • 更新数据:UPDATE tablename SET column1 = value1, column2 = value2, ... WHERE condition


我们可以使用以下代码将 address 列的值从 Highway 21 更新为 Park Lane

import mysql.connector

mydb = mysql.connector.connect(
  host="localhost",
  user="yourusername",
  password="yourpassword",
  database="mydatabase"
)

mycursor = mydb.cursor()

sql = "UPDATE customers SET address = %s WHERE address = %s"
val = ("Park Lane 38", "Highway 21")
mycursor.execute(sql, val)

mydb.commit()

print(mycursor.rowcount, "record(s) affected")


在上面的代码中,我们首先连接到 MySQL 数据库,然后使用 UPDATE 命令将 address 列的值从 Highway 21 更新为 Park Lane 38。我们使用占位符 %s 来代替实际的值,然后在执行 SQL 语句之前将值传递给 execute() 方法。


最后,我们调用 commit() 方法来保存更改,然后打印出受影响的记录数。


删除数据

在更新数据之后,我们可以使用 Python 删除表中的数据。下面是一些常用的 SQL 命令:


  • 删除数据:DELETE FROM tablename WHERE condition


我们可以使用以下代码删除 address 列的值为 Park Lane 38 的记录:

import mysql.connector

mydb = mysql.connector.connect(
  host="localhost",
  user="yourusername",
  password="yourpassword",
  database="mydatabase"
)

mycursor = mydb.cursor()

sql = "DELETE FROM customers WHERE address = %s"
adr = ("Park Lane 38", )
mycursor.execute(sql, adr)

mydb.commit()

print(mycursor.rowcount, "record(s) deleted")


在上面的代码中,我们首先连接到 MySQL 数据库,然后使用 DELETE FROM 命令删除 address 列的值为 Park Lane 38 的记录。我们使用占位符 %s 来代替实际的值,然后在执行 SQL 语句之前将值传递给 execute() 方法。


最后,我们调用 commit() 方法来保存更改,然后打印出删除的记录数。


完整示例

下面是一个完整的 Python 示例,展示了如何连接到 MySQL 数据库、创建表、插入数据、查询数据、更新数据和删除数据:

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))")

# 插入数据
sql = "INSERT INTO customers (name, address) VALUES (%s, %s)"
val = ("John", "Highway 21")
mycursor.execute(sql, val)

mydb.commit()

print(mycursor.rowcount, "record inserted.")

# 查询数据
mycursor.execute("SELECT * FROM customers")

myresult = mycursor.fetchall()

for x in myresult:
  print(x)

# 更新数据
sql = "UPDATE customers SET address = %s WHERE address = %s"
val = ("Park Lane 38", "Highway 21")
mycursor.execute(sql, val)

mydb.commit()

print(mycursor.rowcount, "record(s) affected")

# 删除数据
sql = "DELETE FROM customers WHERE address = %s"
adr = ("Park Lane 38", )
mycursor.execute(sql, adr)

mydb.commit()

print(mycursor.rowcount, "record(s) deleted")


在上面的代码中,我们首先连接到 MySQL 数据库,然后创建一个名为 customers 的表。接下来,我们向 customers 表中插入一条记录,并使用 SELECT 命令查询所有记录。然后,我们使用 UPDATE 命令将 address 列的值从 Highway 21 更新为 Park Lane 38,并使用 DELETE 命令删除 address 列的值为 Park Lane 38 的记录。最后,我们调用 commit() 方法来保存更改,并打印出插入、更新和删除的记录数。


这就是使用 Python 操作 MySQL 数据库的基本方法。使用 Python 和 MySQL,你可以轻松地创建、操作和管理数据库。

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
相关文章
|
1月前
|
NoSQL 算法 Redis
【Docker】(3)学习Docker中 镜像与容器数据卷、映射关系!手把手带你安装 MySql主从同步 和 Redis三主三从集群!并且进行主从切换与扩容操作,还有分析 哈希分区 等知识点!
Union文件系统(UnionFS)是一种**分层、轻量级并且高性能的文件系统**,它支持对文件系统的修改作为一次提交来一层层的叠加,同时可以将不同目录挂载到同一个虚拟文件系统下(unite several directories into a single virtual filesystem) Union 文件系统是 Docker 镜像的基础。 镜像可以通过分层来进行继承,基于基础镜像(没有父镜像),可以制作各种具体的应用镜像。
333 5
|
2月前
|
关系型数据库 MySQL 分布式数据库
阿里云PolarDB云原生数据库收费价格:MySQL和PostgreSQL详细介绍
阿里云PolarDB兼容MySQL、PostgreSQL及Oracle语法,支持集中式与分布式架构。标准版2核4G年费1116元起,企业版最高性能达4核16G,支持HTAP与多级高可用,广泛应用于金融、政务、互联网等领域,TCO成本降低50%。
|
2月前
|
关系型数据库 MySQL 数据库
阿里云数据库RDS费用价格:MySQL、SQL Server、PostgreSQL和MariaDB引擎收费标准
阿里云RDS数据库支持MySQL、SQL Server、PostgreSQL、MariaDB,多种引擎优惠上线!MySQL倚天版88元/年,SQL Server 2核4G仅299元/年,PostgreSQL 227元/年起。高可用、可弹性伸缩,安全稳定。详情见官网活动页。
|
2月前
|
关系型数据库 分布式数据库 数据库
阿里云数据库收费价格:MySQL、PostgreSQL、SQL Server和MariaDB引擎费用整理
阿里云数据库提供多种类型,包括关系型与NoSQL,主流如PolarDB、RDS MySQL/PostgreSQL、Redis等。价格低至21元/月起,支持按需付费与优惠套餐,适用于各类应用场景。
|
2月前
|
SQL 关系型数据库 MySQL
Mysql数据恢复—Mysql数据库delete删除后数据恢复案例
本地服务器,操作系统为windows server。服务器上部署mysql单实例,innodb引擎,独立表空间。未进行数据库备份,未开启binlog。 人为误操作使用Delete命令删除数据时未添加where子句,导致全表数据被删除。删除后未对该表进行任何操作。需要恢复误删除的数据。 在本案例中的mysql数据库未进行备份,也未开启binlog日志,无法直接还原数据库。
|
2月前
|
缓存 关系型数据库 BI
使用MYSQL Report分析数据库性能(下)
使用MYSQL Report分析数据库性能
128 3
|
2月前
|
关系型数据库 MySQL 数据库
自建数据库如何迁移至RDS MySQL实例
数据库迁移是一项复杂且耗时的工程,需考虑数据安全、完整性及业务中断影响。使用阿里云数据传输服务DTS,可快速、平滑完成迁移任务,将应用停机时间降至分钟级。您还可通过全量备份自建数据库并恢复至RDS MySQL实例,实现间接迁移上云。
|
3月前
|
存储 运维 关系型数据库
从MySQL到云数据库,数据库迁移真的有必要吗?
本文探讨了企业在业务增长背景下,是否应从 MySQL 迁移至云数据库的决策问题。分析了 MySQL 的优势与瓶颈,对比了云数据库在存储计算分离、自动化运维、多负载支持等方面的优势,并提出判断迁移必要性的五个关键问题及实施路径,帮助企业理性决策并落地迁移方案。
|
2月前
|
Ubuntu 安全 关系型数据库
安装与配置MySQL 8 on Ubuntu,包括权限授予、数据库备份及远程连接指南
以上步骤提供了在Ubuntu上从头开始设置、配置、授权、备份及恢复一个基础但完整的MySQL环境所需知识点。
399 7
|
2月前
|
缓存 监控 关系型数据库
使用MYSQL Report分析数据库性能(上)
最终建议:当前系统是完美的读密集型负载模型,优化重点应放在减少行读取量和提高数据定位效率。通过索引优化、分区策略和内存缓存,预期可降低30%的CPU负载,同时保持100%的缓冲池命中率。建议每百万次查询后刷新统计信息以持续优化
213 6

热门文章

最新文章

推荐镜像

更多
下一篇
oss云网关配置