sqlalchemy mysql_使用SQLAlchemy操作MySQL

SQLAlchemy是Python编程语言下的一款开源软件,提供了SQL工具包及对象关系映射(ORM)工具,使用MIT许可证发行。SQLAlchemy首次发行于2006年2月,并迅速地在Python社区中最广泛使用的ORM工具之一,不亚于Django的ORM框架。

本文将介绍如何使用SQLAlchemy操作MySQL,完成基础的表创建,表格数据的新增、查询、修改、删除(CRUD)等操作。

首先我们需要确认当前的Python环境下已经安装sqlalchemy和pymysql模块。

新建表格

我们使用本地的MySQL数据库,数据库为orm_test。新建一张users表,字段为id,name,age,place。完整的Python代码(create_table.py)如下:

# -*- coding: utf-8 -*-

# author: Jclian91

# place: Sanya, Hainan

# time: 12:46

from sqlalchemy.dialects.mysql import INTEGER, VARCHAR

from sqlalchemy import Column

from sqlalchemy import create_engine

from sqlalchemy.ext.declarative import declarative_base

Base = declarative_base()

# users表结构

class Users(Base):

__tablename__ = 'users'

id = Column(INTEGER, primary_key=True)

name = Column(VARCHAR(256), nullable=False)

age = Column(INTEGER)

place = Column(VARCHAR(256), nullable=False)

def __init__(self, id, name, age, place):

self.id = id

self.name = name

self.age = age

self.place = place

def init_db():

engine = create_engine(

"mysql+pymysql://root:@localhost:3306/orm_test",

encoding= "utf-8",

echo=True

)

Base.metadata.create_all(engine)

print('Create table successfully!')

if __name__ == '__main__':

init_db()

运行后,生成的users表结构如下:

b2e0e3a95bb02943054a9ab821804404.png

数据插入

接着我们插入几条测试数据,完整的代码(db_insert.py)如下:

# -*- coding: utf-8 -*-

# author: Jclian91

# place: Sanya, Hainan

# time: 12:52

from create_table import Users

from sqlalchemy import create_engine

from sqlalchemy.orm import sessionmaker

def insert_data():

# 初始化数据库连接

engine = create_engine("mysql+pymysql://root:@localhost:3306/orm_test", encoding="utf-8")

# 创建DBSession类型

DBSession = sessionmaker(bind=engine)

# 创建session对象

session = DBSession()

# 插入单条数据

# 创建新User对象

new_user = Users(id=1, name='Jack', age=25, place='USA')

# 添加到session

session.add(new_user)

# 提交即保存到数据库

session.commit()

# 插入多条数据

user_list= [Users(id=2, name='Green', age=26, place='UK'),

Users(id=3, name='Alex', age=31, place='GER'),

Users(id=4, name='Chen', age=52, place='CHN'),

Users(id=5, name='Zhang', age=42, place='CHN')

]

session.add_all(user_list)

session.commit()

# 关闭session

session.close()

print('insert into db successfully!')

if __name__ == '__main__':

insert_data()

运行程序后,表格中的数据如下:

caa65e34fd88a501882dd63a72fc3a37.png

数据查询

接下来演示如何进行简单的查询。我们需要查询place为CHN的人名,完整的Python代码(db_query)如下:

# -*- coding: utf-8 -*-

# author: Jclian91

# place: Sanya, Hainan

# time: 12:52

from create_table import Users

from sqlalchemy import create_engine

from sqlalchemy.orm import sessionmaker

def query_data():

# 初始化数据库连接

engine = create_engine("mysql+pymysql://root:@localhost:3306/orm_test", encoding="utf-8")

# 创建DBSession类型

DBSession = sessionmaker(bind=engine)

# 创建session对象

session = DBSession()

# 查询所有place是CHN的人名

# 创建Query查询,filter是where条件

# 调用one()返回唯一行,如果调用all()则返回所有行:

users = session.query(Users).filter(Users.place == 'CHN').all()

print([use.name for use in users])

# 输出:['Chen', 'Zhang']

# 或者用如下查询

users = session.query(Users.name).filter(Users.place == 'CHN').all()

print(users)

# 输出:[('Chen',), ('Zhang',)]

session.close()

if __name__ == '__main__':

query_data()

输出结果如下:

['Chen', 'Zhang']

[('Chen',), ('Zhang',)]

数据更新

接下来我们演示数据更新。我们需要将Jack的place修改为CHN,完整的Python代码(db_update)如下:

# -*- coding: utf-8 -*-

# author: Jclian91

# place: Sanya, Hainan

# time: 12:52

from create_table import Users

from sqlalchemy import create_engine

from sqlalchemy.orm import sessionmaker

def update_data():

# 初始化数据库连接

engine = create_engine("mysql+pymysql://root:@localhost:3306/orm_test", encoding="utf-8")

# 创建DBSession类型

DBSession = sessionmaker(bind=engine)

# 创建session对象

session = DBSession()

# 数据更新,将Jack的place修改为CHN

update_obj = session.query(Users).filter(Users.name=='Jack').update({"place":"CHN"})

session.commit()

session.close()

print("Update data successfully!")

if __name__ == '__main__':

update_data()

更新后的表格数据如下:

1db546e403859ccf3a1515690f4218e1.png

数据删除

接着我们演示数据删除。我们需要将Jack的记录删除,完整的Python代码(db_delete.py)如下:

# -*- coding: utf-8 -*-

# author: Jclian91

# place: Sanya, Hainan

# time: 12:52

from create_table import Users

from sqlalchemy import create_engine

from sqlalchemy.orm import sessionmaker

def delete_data():

# 初始化数据库连接

engine = create_engine("mysql+pymysql://root:@localhost:3306/orm_test", encoding="utf-8")

# 创建DBSession类型

DBSession = sessionmaker(bind=engine)

# 创建session对象

session = DBSession()

# 数据更新,将Jack的记录删除

update_obj = session.query(Users).filter(Users.name=='Jack').delete()

session.commit()

session.close()

print("Delete data successfully!")

if __name__ == '__main__':

delete_data()

运行程序后,表格中的数据如下:

31d0e3d330863294ad263ae8fa5bef3a.png

本次分享到此结束,感谢大家阅读~

本文的示例代码已经上传至Github,网址为:https://github.com/percent4/ORM_test 。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/365648.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

使用phpstorm+wamp实现php代码实时调试审计

转载自:https://www.bugbank.cn/q/article/5853afaffc0bf4f010ee6ac3.html php调试有N多好用的工具,最近研究到phpstorm配合wamp实现php实时断点调试相当不错,推荐给大家,网上有各种配置版本,但没有一个能好使的。本文…

如何使用Play框架为https配置SSL证书

我花了数小时试图使它起作用,最后,问题是我自己没有使用keytool生成CSR(证书请求)。 尝试通过https访问Play时,我一直收到此错误: javax.net.ssl.SSLPeerUnverifiedException:对等方未通过身份…

js页面加载前执行_做一名合格的前端开发工程师:Javascript加载执行问题探索

做前端开发少不了各种利器。比如我习惯用的还是Google浏览器和重型武器Fiddller。一:原始情况 首先大家看看如下的代码:估计90%的程序员都会把js文件放在head中,但是大家有没有深究过呢?很多浏览器都会使用单一的线程来做“界面UI…

【线性代数】3-5:独立性,基和维度(Independence,Basis and Dimension)

title: 【线性代数】3-5:独立性,基和维度(Independence,Basis and Dimension) categories: MathematicLinear Algebra keywords:IndependenceBasisDimensionSpan toc: true date: 2017-09-25 15:20:46Abstract: 本文是本章最重要的知识点,也是整个线性代…

APP网络测试要点和弱网模拟

当前APP网络环境比较复杂,网络制式有2G、3G、4G网络,还有越来越多的公共Wi-Fi。不同的网络环境和网络制式的差异,都会对用户使用app造成一定影响。另外,当前app使用场景多变,如进地铁、上公交、进电梯等,使…

word公式插件_再也不用担心我的公式写不出来了:一款公式输入神器实测

→ → https://mp.weixin.qq.com/s/gNRWdN-W4_Eb2MyyTpWzjw关注微信公众号:人工智能前沿讲习,重磅干货,第一时间送达本文推荐一个公式输入神器,只要截图就能识别公式,手写的公式都能识别。经过实测,几乎没有…

使用Camel在Amazon上构建分布式工作流应用程序

带有SNS-SQS的管道 工作流由按动态条件确定的特定顺序执行的独立任务组成。 工作流通常代表业务流程,例如电子商务商店中的订单处理步骤。 Amazon Web Services提供了各种工具来构建分布式和可扩展的工作流应用程序。 构建此类应用程序的一种方法是使用主题和队列来…

mysql 高版本检索外键_第05期:外键到底能不能用?

外键的设计初衷是为了在数据库端保证对逻辑上相关联的表数据在操作上的一致性与完整性。外键在大部分企业写的开发规范里会直接规避掉!外键有优缺点,也并不是说每种场景都不适用,完全没有必要一刀切。外键到底能不能用?下面会针对…

从Ant Build演进Gradle Build:导入Ant Build文件

在大型项目上更改构建系统可能很困难并且需要大量工作。 幸运的是,对于那些将Ant版本迁移到Gradle版本的人,Gradle提供了特别方便的机制来促进这种迁移 。 由于Gradle基于Groovy构建,并且Groovy通过AntBuilder包含内置的Ant支持,因…

HTML5 之 简单汇总

参考: HTML5的十大新特性 前端面试必备之html5的新特性 HTML5 主要内容:语义化、增强型表单、多媒体标签、Canvas、SVG、地理定位、拖放API、Web Worker、Web Storage、WebSocket、HTML 5 应用程序缓存 1.语义化元素 1.1结构元素 标签描述article表示与上…

个人信息管理系统代码_Thymeleaf+SpringBoot+Mybatis实现的易游网旅游信息管理系统...

项目简介项目源码:麻烦转发后关注JAVA梦想口服液私信回复【源码】即可获取!本系统是基于ThymeleafSpringBootMybatis。是非常标准的SSM三大框架(SpringBoot就是一个大框架,里面包含了许多的东西,其中Spring就是最核心的内容&#…

被问到有没有内核开发经验_一个人就是一个开发团队!成电硬核毕业生自制迷你电脑走红!...

△小视频近日,一段长3分多钟的小视频在B站突然爆红,不仅登上首页,获得超过200万的播放量,还被众多观众“膜拜”。有网友在评论区说:“其实这些东西吧,外行看起来很牛,但我这种内行看起来&#x…

matlab2010a连接mysql_MATLAB2010a+OpenCV2.3.1+VS2010运行TLD

出现matlab不显示C编译器的原因主要还是当前Matlab版本相对于VS来说不够新,比如14版的肯定支持10的VS。 本文引用地址: http://blog.csdn.net/shanpohe/article/details/7596401 http://blog.sina.com.cn/s/blog_adfd55190101ejvr.html TLD(Tracking Lea…

更改span标签样式_CSS 内嵌样式

前面一节我们讲了行内样式,但是行内样式的缺点就是样式不能重用。例如当有好多个 标签,我们希望所有的 标签的样式都一致,那么需要在每个标签中都写一遍,这么会很麻烦,也会增加很多代码。那么为了解决这个问题&#…

mysql 6安装当前密码_MySQL8.0 安装踩坑指南

就在昨天上午,刚为云服务器安装好Apache2.4.33和PHP7.2.4环境,准备再来一个最新的MySQL5.7.22。寻找5.7版本的rpm包时下到mysql80xxx.rpm,看人家的教程是mysql57,难道80是MySQL出出…出了8版,一搜新闻2个小时前MySQL发…

Elasticsearch环境搭建和介绍(Windows)

一、Elasticsearch介绍和安装 1.1 介绍 Elastic Elastic官网:https://www.elastic.co/cn/ Elastic有一条完整的产品线:Elasticsearch、Kibana、Logstash等,前面说的三个就是大家常说的ELK技术栈。 Elasticsearch Elasticsearch官网&#xff1…

Jar Hell变得轻松–用jHades揭秘classpath

Java开发人员将不得不面对的最困难的问题是类路径错误: ClassNotFoundException , NoClassDefFoundError ,Jar Hell, Xerces Hell和company。 在本文中,我们将探究这些问题的根本原因,并了解最小的工具&am…

程序控制发送文件到邮箱_Kindle电子邮箱推送

Kindle 推送支持的格式目前 Kindle 推送仅支持以下几种格式。需要注意的是,AZW 和 AZW3 是两种不同的格式,虽然这两种格式 Kindle 设备都支持阅读,但是亚马逊的个人文档服务支持推送 AZW 但是不支持 AZW3。Kindle 格式 (.mobi 或 .azw) * 推荐…

mysql的英文字母_MySQL中查询的有关英文字母大小写问题的分析

mysql数据库在做查询时候,有时候是英文字母大小写敏感的,有时候又不是的,主要是由mysql的字符校验规则的设置决定的,通常默认是不支持的大小写字母敏感的。1. 什么是字符集和校验规则?字符集是一套符号和编码。校对规则…

写接口给别人调用 推送数据到我们_我们写了一个超好用的抖音矩阵数据管理工具...

我最近跑了十来个抖音号,遇到一些问题,然后通过我们NB的程序员解决了。如果你也在做抖音矩阵,那这些问题你肯定也会遇到,所以我把解决问题的方法工具化了,给大家用。我遇到的最大的问题,就是账号数据的同步…