python和mysql、Python与MySQL数据交互

python和mysql、Python与MySQL数据交互

Image

Python与MySQL数据交互:让数据处理更简单便捷

随着数据时代的到来,数据处理成为了各个领域中不可或缺的一部分。而Python作为一门高效、简洁的编程语言,已经成为了数据科学领域中的重要工具。而MySQL作为一款高性能、可靠的关系型数据库管理系统,也是数据处理中常用的数据库之一。Python与MySQL数据交互的技术,可以让数据处理更加简单便捷,为数据分析、数据挖掘等领域提供了强有力的支持。

一、连接MySQL数据库

使用PyMySQL连接MySQL数据库

在Python中,可以使用PyMySQL模块来连接MySQL数据库。该模块提供了一个connect()函数,用于连接MySQL数据库。在连接MySQL数据库之前,需要先安装PyMySQL模块。安装完成后,可以使用以下代码来连接MySQL数据库:

import pymysql

# 打开数据库连接

db = pymysql.connect("localhost","testuser","test123","testdb" )

# 使用cursor()方法获取操作游标

cursor = db.cursor()

# 关闭数据库连接

db.close()

使用MySQLdb连接MySQL数据库

除了PyMySQL模块,还可以使用MySQLdb模块来连接MySQL数据库。MySQLdb模块是Python中一个比较老的连接MySQL数据库的模块,但是仍然被广泛使用。使用MySQLdb模块连接MySQL数据库的代码如下:

import MySQLdb

# 打开数据库连接

db = MySQLdb.connect("localhost","testuser","test123","testdb" )

# 使用cursor()方法获取操作游标

cursor = db.cursor()

# 关闭数据库连接

db.close()

二、执行MySQL查询

执行SELECT语句

在Python中,可以使用execute()方法来执行MySQL查询语句。对于SELECT语句,可以使用fetchall()方法来获取查询结果。以下是一个使用execute()方法执行SELECT语句的示例代码:

import pymysql

# 打开数据库连接

db = pymysql.connect("localhost","testuser","test123","testdb" )

# 使用cursor()方法获取操作游标

cursor = db.cursor()

# SQL 查询语句

sql = "SELECT * FROM EMPLOYEE

WHERE INCOME > %s" % (1000)

try:

# 执行SQL语句

cursor.execute(sql)

# 获取所有记录列表

results = cursor.fetchall()

for row in results:

fname = row[0]

lname = row[1]

age = row[2]

sex = row[3]

income = row[4]

# 打印结果

print ("fname=%s,lname=%s,age=%d,sex=%s,income=%d" %

(fname, lname, age, sex, income ))

except:

print ("Error: unable to fetch data")

# 关闭数据库连接

db.close()

执行INSERT语句

在Python中,可以使用execute()方法执行INSERT语句来向MySQL数据库中插入数据。以下是一个使用execute()方法执行INSERT语句的示例代码:

import pymysql

# 打开数据库连接

db = pymysql.connect("localhost","testuser","test123","testdb" )

# 使用cursor()方法获取操作游标

cursor = db.cursor()

# SQL 插入语句

sql = "INSERT INTO EMPLOYEE(FIRST_NAME,

LAST_NAME, AGE, SEX, INCOME)

VALUES ('%s', '%s', '%d', '%c', '%d' )" %

('Mac', 'Mohan', 20, 'M', 2000)

try:

# 执行SQL语句

cursor.execute(sql)

# 提交到数据库执行

db.commit()

except:

# 如果发生错误则回滚

db.rollback()

# 关闭数据库连接

db.close()

三、使用ORM框架操作MySQL数据库

使用SQLAlchemy操作MySQL数据库

SQLAlchemy是Python中一个流行的ORM框架。ORM(Object-Relational Mapping)是一种将关系型数据库中的数据映射到对象的编程技术。使用ORM框架可以让开发者更加方便地操作数据库。以下是一个使用SQLAlchemy操作MySQL数据库的示例代码:

from sqlalchemy import create_engine, Column, Integer, String

from sqlalchemy.orm import sessionmaker

from sqlalchemy.ext.declarative import declarative_base

# 创建连接到MySQL数据库的引擎

engine = create_engine('mysql+pymysql://testuser:test123@localhost/testdb')

# 创建一个会话工厂

Session = sessionmaker(bind=engine)

# 创建一个ORM基类

Base = declarative_base()

# 定义一个ORM模型

class User(Base):

__tablename__ = 'users'

id = Column(Integer, primary_key=True)

name = Column(String(50))

age = Column(Integer)

# 创建所有的表

Base.metadata.create_all(engine)

# 创建一个会话

session = Session()

# 插入数据

user = User(name='John', age=20)

session.add(user)

session.commit()

# 查询数据

users = session.query(User).all()

for user in users:

print(user.name, user.age)

# 关闭会话

session.close()

使用Django操作MySQL数据库

Django是Python中一个流行的Web框架,它也集成了ORM框架。使用Django可以快速地开发Web应用程序,并且可以方便地操作数据库。以下是一个使用Django操作MySQL数据库的示例代码:

# 安装Django

pip install django

# 创建一个Django项目

django-admin startproject myproject

# 进入项目目录

cd myproject

# 创建一个Django应用

python manage.py startapp myapp

# 修改settings.py文件,配置MySQL数据库

DATABASES = {

'default': {

'ENGINE': 'django.db.backends.mysql',

'NAME': 'testdb',

'USER': 'testuser',

'PASSWORD': 'test123',

'HOST': 'localhost',

'PORT': '3306',

}

# 创建一个ORM模型

from django.db import models

class User(models.Model):

name = models.CharField(max_length=50)

age = models.IntegerField()

# 创建数据库表

python manage.py makemigrations

python manage.py migrate

# 插入数据

user = User(name='John', age=20)

user.save()

# 查询数据

users = User.objects.all()

for user in users:

print(user.name, user.age)

四、

Python与MySQL数据交互是数据处理中的重要技术,可以让数据处理更加简单便捷。Python中有多种方法可以连接MySQL数据库,包括使用PyMySQL模块、MySQLdb模块以及ORM框架。对于不同的应用场景,可以选择不同的方法来操作MySQL数据库。掌握Python与MySQL数据交互的技术,可以让开发者更加高效地处理数据,为数据分析、数据挖掘等领域提供强有力的支持。

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/78322.html<

(0)
运维的头像运维
上一篇2025-02-09 01:39
下一篇 2025-02-09 01:40

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注