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

相关推荐

发表回复

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