Python流行ORM框架sqlalchemy安装与使用教程
作者:学习笔记666 发布时间:2022-10-20 06:12:20
标签:Python,ORM框架,sqlalchemy
本文实例讲述了Python流行ORM框架sqlalchemy安装与使用。分享给大家供大家参考,具体如下:
安装
http://docs.sqlalchemy.org
1、安装
#进入虚拟环境
#执行
./python3 -m pip install
import sqlalchemy
print(sqlalchemy.__version__) # 1.1.15
我这里使用的版本是1.1.15
创建连接对象
http://docs.sqlalchemy.org/en/latest/orm/tutorial.html#connecting
from sqlalchemy import create_engine
# 连接本地test数据库
engine = create_engine("mysql://root:root@localhost/test?charset=utf8")
运行时会出错,因为需要驱动库,默认会调用MySQLdb。
ImportError: No module named 'MySQLdb'
我们前面安装了pymysql,因此完整的要这么写:
engine = create_engine("mysql+pymysql://root:root@localhost/test?charset=utf8")
简单使用
SQL语句查询
result = engine.execute("select * from news")
print(result.fetchall())
#[(1, '本机新闻标题'), (2, '今天的新闻'), (3, '新闻标题1'), (4, '新闻标题2'), (5, '元组新闻1'), (6, '元组新闻2')]
创建映射
既然我们用ORM,就是为了少写甚至不写SQL语句。
ORM是数据表和对象之间的映射。
http://docs.sqlalchemy.org/en/latest/orm/tutorial.html#declare-a-mapping
1、创建一个Infos.py文件,这个文件我们来做数据表的映射
from sqlalchemy.ext.declarative import declarative_base
Base = declarative_base()
from sqlalchemy import Column, Integer, String
class News(Base):
# 表名称
__tablename__ = 'news'
# news表里id字段
id = Column(Integer, primary_key=True, autoincrement=True)
# news表里title字段
title = Column(String(length=255), nullable=False)
News类就是我们数据表news的映射(字段:id、title)。
2、使用
from sqlalchemy import create_engine
from mappers.Infos import News
from sqlalchemy.orm import sessionmaker
# 连接本地test数据库
engine = create_engine("mysql+pymysql://root:root@localhost/test?charset=utf8")
# 创建会话
session = sessionmaker(engine)
mySession = session()
# 查询结果集
result = mySession.query(News).all()
print(result[0])
我们要注意最后的查询结果,看看结果集中的元素长什么样?^_^
<mappers.Infos.News object at 0x1050c6e80>
查询处理的记录都是对象。
各种查询
只查询第一条记录
# 查询第一条
result = mySession.query(News).first()
print(result.title) #打印对象属性
通过id字段查询
# 查询id为2的
result = mySession.query(News).filter_by(id=2).first()
print(result.title)
# 查询id为2的
result = mySession.query(News).filter(News.id==2).first()
分页查询
# 分页查询 0,2
result = mySession.query(News).filter(News.id>1).limit(2).offset(0).all()
print(result)
自定义过滤条件
# 自定义过滤条件
result = mySession.query(News).filter(text("id>:id")).params(id=2).all()
根据主键查询
result = mySession.query(News).get(3)
print(result.title)
新增和修改
# 新增
news = News(title="新增测试标题")
mySession.add(news)
mySession.commit()
#修改
mySession.query(News).filter(News.id==7).update({"title":"修改之后的标题"})
mySession.commit()
希望本文所述对大家Python程序设计有所帮助。
来源:https://blog.csdn.net/github_26672553/article/details/78537605


猜你喜欢
- PHP 5.0.0 和PHP 4.0.38 于2004年7月13日同时发布,这是一个值得我们PHP爱好者的一大喜讯。期盼已久的PHP5终于出
- urls.py:URL dispatcher(路由配置文件)URL配置(URLconf)就像是Django所支撑网站的目录。它的本质是URL
- 网络下载的python代码,版本参差,从python2.x迁移python3.x的过程中,存在print语法问题,即python2.x中pr
- vue在做大型项目时,会用到多状态管理,vuex允许我们将store分割成多个模块,每个模块内都有自己的state、mutation、act
- 方法一 <%dim total(7,3) total(1,0)="ASP之家"&n
- 这个就没什么好说的了。。直接上代码啊!! 首先是HTML的代码。其中包含了登录点击按钮以及一个简陋的登录框。 <body> &l
- Example.asp<%@LANGUAGE="VBSCRIPT" CODEPAGE="65001&qu
- 导语记得很久以前写过一些中国大学MOOC上的视频下载器,不过好像都已经年久失修了。正好最近有需要,所以重新写了一个,顺便上来分享一波,寒假大
- 在曾经的 淘宝UED 招聘 中有这样一道题目:“使用纯CSS实现未知尺寸的图片(但高宽都小于200px)在200px的正方形容器中水平和垂直
- 本文详细汇总了MySQL学习中的各类技巧,分享给大家供大家参考。具体如下:/* 启动MySQL */net start mysql/* 连接
- 最近把MySQL升级到了5.6版本,无意中在任务管理器发现MySQL内存占用达到400+M,这是怎么回事呢?以前的版本可没有遇到过这种情况啊
- 一.怎样删除一个表中某个字段重复的列呀,举个例子 表[table1] id name 1 &nb
- 上个月安装的pycharm,由于当时急需要使用,就直接使用的pycharm试用版,没成想,今天早上一打开,直接给我来了个下马威,不能进入了,
- 首先将ORACLE 10g的安装光盘放入光驱,如果自动运行,一般会出现如图1安装界面: 图1 单击“开始安装”,就可以安装ORACLE 10
- 二维离散傅里叶变换(DFT)对于二维图像处理,通常使用 x , y x, yx,y 表示离散的空间域坐标变量,用 u , v u,vu,v
- 表单验证是WEB开发中经常遇到的问题,我们以前常见的做法是:在客户端对表单域进行内容的检查,看是否是满足一定的要求或满足一定的结构,比如:是
- 今天训练faster R-CNN时,发现之前跑的很好的程序(是指在运行程序过程中,显卡利用率能够一直维持在70%以上),今天看的时候,显卡利
- 1.学习sql之前回忆一下,什么是变量?变量:能存储数据的值。变量是一块内存空间的表示。数组一连串空间变量是存储数据的容器(通俗讲)2.变量
- 总有一些程序在windows平台表现不稳定,动不动一段时间就无响应,但又不得不用,每次都是发现问题了手动重启,现在写个脚本定时检测进程是否正
- 首先我是用pycharm完成的,要确定命令行和界面里是同一个环境。如果不确定可以设置再add在新增加的环境里看现在是哪个环境,只要选择已有的