Python使用sqlalchemy模块连接数据库操作示例


Posted in Python onMarch 13, 2019

本文实例讲述了Python使用sqlalchemy模块连接数据库操作。分享给大家供大家参考,具体如下:

安装:

pip install sqlalchemy
# 安装数据库驱动:
pip install pymysql
pip install cx_oracle

举例:(在url后面加入?charset=utf8可以防止乱码)

from sqlalchemy import create_engine
engine=create_engine('mysql+pymysql://username:password@hostname:port/dbname', echo=True) #echo=True 打印sql语句信息

create_engine接受一个url,格式为:

# '数据库类型+数据库驱动名称://用户名:口令@机器地址:端口号/数据库名'
# 常用的
engine = create_engine('sqlite:///:memory:', echo=True)   # sqlite内存
engine = create_engine('sqlite:///./cnblogblog.db',echo=True) # sqlite文件
engine = create_engine("mysql+pymysql://username:password@hostname:port/dbname",echo=True) # mysql+pymysql
engine = create_engine('mssql+pymssql://username:password@hostname:port/dbname',echo=True) # mssql+pymssql
engine = create_engine('postgresql://scott:tiger@hostname:5432/dbname') # postgresql示例
engine = create_engine('oracle://scott:tiger@hostname:1521/sidname') # oracle
engine = create_engine('oracle+cx_oracle://scott:tiger@tnsname') #pdb就可以用tns连接

简单demo:

from sqlalchemy import create_engine, Column, Integer, String
from sqlalchemy.orm import sessionmaker
from sqlalchemy.ext.declarative import declarative_base 
engine = create_engine('oracle://spark:a@orclpdb',echo=True) #echo要求打印sql语句等调试信息
session_maker = sessionmaker(bind=engine)
session = session_maker()
Base = declarative_base()
#对应一张表
class Student(Base): 
  __tablename__ = 'STUDENT'
  id = Column('STUID', Integer, primary_key=True)
  name = Column('STUNAME', String(32), nullable=False)
  age = Column('STUAGE', Integer)
  def __repr__(self):
    return '<Student(id:%s, name:%s, age:%s)>' % (self.id, self.name, self.age)
Base.metadata.create_all(engine) #若存在STUDENT表则不做,不存在则创建。
queryObject = session.query(Student).order_by(Student.id.desc())
for ins in queryObject:
  print(ins.id, ins.name, ins.age)
'''
4 hey 24
3 lwtxxs 27
2 gyb 89
1 ns 23
'''

将查询结果映射为DataFrame:

import pandas as pd
df = pd.read_sql(session.query(Student).filter(Student.id > 1).statement, engine) 
print(df)
'''
  STUID STUNAME STUAGE
0   4   hey   24
1   2   gyb   89
2   3 lwtxxs   27
'''

查询:

session的query方法除了可以接受Base子类对象作为参数外,还可以是字段,如:

query = session.query(Student.name, Student.age) # query为一个sqlalchemy.orm.query.Query对象
for stu_name, stu_age in query:
  print(stu_name, stu_age)

查询条件filter:

# = / like
query.filter(Student.name == 'wendy')
query.filter(Student.name.like('%ed%'))
# in
query.filter(Student.name.in_(['wendy', 'jack']))
query.filter(Student.name.in_(
    session.query(User.name).filter(User.name.like('%ed%'))
))
# not in
query.filter(~Student.name.in_(['ed', 'wendy', 'jack']))
# is null / is not null
query.filter(Student.name == None)
query.filter(Student.name.is_(None))
query.filter(Student.name != None)
query.filter(Student.name.isnot(None))
# and
from sqlalchemy import and_, or_
query.filter(and_(Student.name == 'ed', Student.age != 23))
query.filter(Student.name == 'ed', Student.age != 23)
query.filter(Student.name == 'ed').filter(Student.age != 23)
# or
query.filter(or_(Student.name == 'ed', Student.name == 'wendy'))
# match
query.filter(Student.name.match('wendy'))

Query的方法:

all()方法以列表形式返回结果集:

from sqlalchemy import or_, and_
queryObject = session.query(Student).filter(or_(Student.id == 1, Student.id == 2))
print(queryObject.all())  # [<Student(id:1, name:ns, age:23)>, <Student(id:2, name:gyb, age:89)>]
queryObject = session.query(Student.name).filter(or_(Student.id == 1, Student.id == 2))
print(queryObject.all())  # [('ns',), ('gyb',)]

first()方法返回单个结果。(若结果集为空则返回None)

print(queryObject.first())  # ('ns',)

one()方法返回单个结果,与first()方法不同的是:当结果集中没有元素或有多于一个元素会抛出异常。
one_or_none()方法同one()一样,不同是结果集为空则返回None,为多个抛出异常。

查询数量:

from sqlalchemy import func
session.query(func.count(Student.id)).scalar() # SELECT count("STUDENT"."STUID") AS count_1 FROM "STUDENT"

分组:

session.query(func.count(Student.id), Student.name).group_by(Student.name).all()

嵌套SQL语句:

from sqlalchemy import text
query = session.query(Student.id, Student.name).filter(text('stuid>2'))
query = session.query('stuid', 'stuname', 'stuage').from_statement(\
text("select * from student where stuname=:stuname")).params(stuname='hey').all()  #[(4, 'hey', 24)]

希望本文所述对大家Python程序设计有所帮助。

Python 相关文章推荐
python使用正则搜索字符串或文件中的浮点数代码实例
Jul 11 Python
python魔法方法-自定义序列详解
Jul 21 Python
python学生信息管理系统
Mar 13 Python
浅述python中深浅拷贝原理
Sep 18 Python
python中ImageTk.PhotoImage()不显示图片却不报错问题解决
Dec 06 Python
Python函数参数匹配模型通用规则keyword-only参数详解
Jun 10 Python
VPS CENTOS 上配置python,mysql,nginx,uwsgi,django的方法详解
Jul 01 Python
GDAL 矢量属性数据修改方式(python)
Mar 10 Python
浅谈python 类方法/静态方法
Sep 18 Python
Python新建项目自动添加介绍和utf-8编码的方法
Dec 26 Python
详解matplotlib绘图样式(style)初探
Feb 03 Python
如何Python使用re模块实现okenizer
Apr 30 Python
python ---lambda匿名函数介绍
Mar 13 #Python
Python实现的列表排序、反转操作示例
Mar 13 #Python
Python实现的调用C语言函数功能简单实例
Mar 13 #Python
Python3调用百度AI识别图片中的文字功能示例【测试可用】
Mar 13 #Python
浅谈python标准库--functools.partial
Mar 13 #Python
Python3实现的简单三级菜单功能示例
Mar 12 #Python
Python3实现的简单工资管理系统示例
Mar 12 #Python
You might like
《被神捡到的男人》动画化计划进行中!
2020/03/06 日漫
通过PHP CLI实现简单的数据库实时监控调度
2009/07/01 PHP
使用WordPress发送电子邮件的相关PHP函数用法解析
2015/12/15 PHP
Yii2中SqlDataProvider用法示例
2016/09/22 PHP
jQuery :nth-child前有无空格的区别分析
2011/07/11 Javascript
JS字符串累加Array不一定比字符串累加快(根据电脑配置)
2012/05/14 Javascript
jquery对象和DOM对象的区别介绍
2013/08/09 Javascript
jQuery实现右侧显示可向左滑动展示的深色QQ客服效果代码
2015/10/23 Javascript
浅谈javascript 函数表达式和函数声明的区别
2016/01/05 Javascript
js输出数据精确到小数点后n位代码
2016/07/02 Javascript
Javascript实现基本运算器
2017/07/15 Javascript
jQuery图片缩放插件smartZoom使用实例详解
2017/08/25 jQuery
JS实现的简单下拉框联动功能示例
2018/05/11 Javascript
说说如何在Vue.js中实现数字输入组件的方法
2019/01/08 Javascript
vue-cli3+typescript初体验小结
2019/02/28 Javascript
微信小程序传值以及获取值方法的详解
2019/04/29 Javascript
在Angular中实现一个级联效果的下拉框的示例代码
2020/05/20 Javascript
如何解决jQuery 和其他JS库的冲突
2020/06/22 jQuery
Python函数中的函数(闭包)用法实例
2016/03/15 Python
快速了解Python中的装饰器
2018/01/11 Python
在python里面运用多继承方法详解
2019/07/01 Python
Python编写打字训练小程序
2019/09/26 Python
Django对接支付宝实现支付宝充值金币功能示例
2019/12/17 Python
在keras下实现多个模型的融合方式
2020/05/23 Python
传统HTML页面实现模块化加载的方法
2018/10/15 HTML / CSS
KIKO美国官网:意大利的平价彩妆品牌
2017/05/16 全球购物
全球最大的户外用品零售商之一:The House
2018/06/12 全球购物
如何编写优秀的食品项目创业计划书
2014/01/23 职场文书
幼儿园教师个人反思
2014/01/30 职场文书
会计专业求职信范文
2014/03/16 职场文书
美术专业自荐信
2014/07/07 职场文书
工作作风建设心得体会
2014/10/22 职场文书
2014年纪检部工作总结
2014/11/12 职场文书
建立共青团委员会的请示
2019/04/02 职场文书
2019最新激励员工口号大全!
2019/06/28 职场文书
导游词之台湾安平古堡
2019/12/25 职场文书