sqlalchemy orm使用指南

本教程只讲述sqlalchemyORM使用方式,手写sql的使用基本上和python-mysqldb没区别。

使用环境:部署了openstack的虚拟机。否则请自行安装sqlalchemy所需的各种包。

以下开始使用sqlalchemy来读取我们的nova数据库里面的数据。


fromsqlalchemy import *

fromsqlalchemy.orm import sessionmaker

DB_CONNECT_STRING

='mysql://root:dfe16cf8429dbb9dd2e4@localhost/nova?charset=utf8'

engine= create_engine(DB_CONNECT_STRING, echo=False)

DB_Session= sessionmaker(bind=engine)

session= DB_Session()

这里的DB_CONNECT_STRING就是连接数据库的路径,从nova.conf里面取得。“mysql”指定了连接方式,“root”和“dfe16cf8429dbb9dd2e4分别是用户名和密码,“localhost”是数据库的域名,“ooxx”是使用的数据库名(可省略),“charset”指定了连接时使用的字符集(可省略)。

create_engine()会返回一个数据库引擎,echo参数为True时,会显示每条执行的SQL语句,生产环境下可关闭。
sessionmaker()
会生成一个数据库会话类。这个类的实例可以当成一个数据库连接,它同时还记录了一些查询的数据,并决定什么时候执行SQL语句。

定义一个表:

使用nova数据库的service表:

fromsqlalchemy import Column

fromsqlalchemy.types import CHAR, Integer, String

fromsqlalchemy.ext.declarative import declarative_base

BaseModel= declarative_base()

definit_db():

BaseModel.metadata.create_all(engine)

defdrop_db():

BaseModel.metadata.drop_all(engine)

classService(BaseModel):

"""Representsa running service on a host."""

__tablename__= 'services'

id= Column(Integer, primary_key=True)

host= Column(String(255)) # , ForeignKey('hosts.id'))

host_ip= Column(String(255))

binary= Column(String(255))

topic= Column(String(255))

report_count= Column(Integer, nullable=False, default=0)

disabled= Column(Boolean, default=False)

availability_zone= Column(String(255), default='nova')

init_db()


declarative_base()创建了一个BaseModel类,这个类的子类可以自动与一个表关联。

接着就开始使用这个表吧:

fromsqlalchemy import func, or_, not_

service= Service(host='xww',host_ip='22.22.22.22')

session.add(service)

session.commit()

query= session.query(Service)

#printquery

forserveice in query:

printservice.host, service.host_ip


可以看到输出的结果就是我们想要的。如果service表之前有内容,也会一并输出。


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

大熊1997

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值