python下SQLAlchemy的使用
SQLAlchemy是python中orm常用的框架。支持各种主流的数据库,如SQLite、MySQL、Postgres、Oracle、MS-SQL、SQLServer 和 Firebird。
在安装好SQLAlchemy之后导入相关的模块,如下是一些常用的模块,也可以根据项目的实际需要在添加。
from sqlalchemy import Column, String, create_engine #导入包
from sqlalchemy.orm import sessionmaker
from sqlalchemy.ext.declarative import declarative_base
定义数据模型,通常创建SqlTable.py(文件名称自定义就好)
- # coding: utf-8
- from sqlalchemy import Column, Integer, String, Float, BigInteger, Unicode, Text
- from sqlalchemy.ext.declarative import declarative_base
- from sqlalchemy import ForeignKey, Sequence
- from sqlalchemy.orm import relationship
- from sqlalchemy import create_engine
- from sqlalchemy.orm import sessionmaker
- Base = declarative_base()
- class UserInfo(Base):#所有类继承自Base
- __tablename__ = 'UserInfo'#表的名字
#表的字段定义
primaryId = Column(Integer,Sequence('user'),primary_key=True)- username = Column(Unicode(50))
- password = Column(Unicode(50))
- #以下为非必须方法,允许通过字典,对数据模型进行实例化
- def __init__(self, user_dict):
- for key in user_dict:
- setattr(self, key, user_dict[key])
- def update(self, info_dict):
- for key in info_dict:
- setattr(self, key, info_dict[key])
定义数据模型,数据模型中可以定义Id自增序列,在引用模块时添加Sequence,并且指定序列名称,如果多个数据模型共用一个序列,会导致非连续自增。
创建文件SqlManager.py,作用类似于C#中常见的SqlHellper,将SQLAlchemy的常用功能进行封装。
- # coding: utf-8
- from sqlalchemy import create_engine
- from sqlalchemy.orm import sessionmaker
- import SqlTable
- from SqlTable import Base
- import utils #自定义模块
- from sqlalchemy import and_
- from sqlalchemy import desc
- from sqlalchemy import func
- config = utils.load_config() #自定义加载配置文件方法
- engine = None
- Session = None
- class GetSession(object):
- def __init__(self):
- self.session = Session()
- def __enter__(self):
- return self.session
- def __exit__(self, exception_type, exception_value, exc_traceback):
- if exception_type is not None:
- self.session.rollback()
- log.error("session error:{}".format(traceback.format_tb(exc_traceback)))
- self.session.close()
- class SqlManager(objecet):
- def __init__(self):
- self._rlock = threading.RLock()
- global Session
- global engine
- engine = create_engine( "mysql+pymysql://{user}:{pwd}@127.0.0.1:3306/{dbname}?charset=utf8".format(
user=config["db_user"], pwd=config["db_password"], dbname=config["dbname"]))- Base.metadata.create_all(engine)
- Session = sessionmaker(bind=engine)
- #以下为非必须举例,根据项目需求写增删改查,也可以通过泛型的思想编写一些
- def add_user(self,username,pwd):
- with self._rlock:
- with GetSession() as session:
- user= User( name=username,password=pwd)
- session.add(user)
- session.commit()
- def add(self,tabname,dictlist):#注意:如果参数为字典列表,数据模型中要有相应的通过字典初始化的方法
- with self._rlock:
- table = getattr(SqlTable,tabname)
- engine.execute(table.__table__.insert(),dictlist)
- def update(self,tabname,dict):
- with self._rlock:
- with GetSession as session:
- table = getattr(SqlTable,tabname)
- result=session.query(table),filter(table.id=dict["id"])
- if len(result)==0:
- new_info=table(dict)
- session.add(new_info)
- else:
- update_info=result[0]
- update_info.update(dict)#数据模型中需要有update方法
- session.commit()
初始化数据连接 ,数据连接的基本格式为:数据库类型+数据库驱动名称://用户名:口令@机器地址:端口号/数据库名
如果提示引擎创建出错,可以尝试去掉数据库驱动名称,试运行等系统提示需要哪个模块,下载安装即可。
数据连接可以根据采用的数据库类型去拼接,有些数据库的驱动需要另外安装。创建方法如下:
engine = create_engine('mysql+pymysql://root:password@localhost:3306/test?charset=utf8')
engine = create_engine('sqlite:///' + unicode(config["db_path"], "utf-8")) #sqlite数据库可以直接指向地址,相对路径或绝对路径。
初始化数据库连接且数据模型创建完之后,需要在数据库中创建对应的表(有些类型的数据库需要手动创建),这一步可以交给SQLAlchemy来,代码如下:Base.metadata.create_all(engine) 。这行代码如果放在定义数据模型的最下边,会在import时运行,不建议放在sqltable.py中。上边代码放在了SqlManager类初始化的时候执行,避免import时加载的不受控制,具体原因会在正文后详述。
创建数据库会话类,这个类的实例可以当成数据库连接,同时还记录了一些的查询的数据并且决定什么时候才会执行数据操作。
Session = sessionmaker(bind=engine) #创建数据库会话类
数据库会话类的使用:
# 创建session对象:
session = Session()
# 创建新User对象:
new_user = User(id='5', name='Bob')
# 添加到session:
session.add(new_user)
# 提交即保存到数据库:
session.commit()
# 关闭session:
session.close()
或者使用with增加代码的健壮性:
new_user = User(id='5', name='Bob')
with GetSession() as session:
session.add(new_user)
session.commit()
基本操作到此可以应付日常工作,其他的进阶技能可以参考:http://blog.csdn.net/zd0303/article/details/50261347
关于with的使用:GetSession(),如上方法使用中的session是一个类对象,而且类中必须实现__enter__() 和__exit__()方法。
python下SQLAlchemy的使用的更多相关文章
- python下的orm基本操作(1)--Mysql下的CRUD简单操作(含源码DEMO)
最近逐渐打算将工作的环境转移到ubuntu下,突然发现对于我来说,这ubuntu对于我这种上上网,收收邮件,写写博客,写写程序的时实在是太合适了,除了刚接触的时候会不怎么完全适应命令行及各种权限管理, ...
- python之SQLAlchemy ORM 上
前言: SQLAlchmey是暑假学的,当时学完后也没及时写博客整理下.这篇博客主要介绍下SQLAlchemy及基本操作,写完后有空做个堡垒机小项目.下篇博客整理写篇关于Web框架和django基础~ ...
- 基于Python的SQLAlchemy的操作
安装 在Python使用SQLAlchemy的首要前提是安装相应的模块,当然作为python的优势,可以到python安装目录下的scripts下,同时按住shift+加上鼠标左键,从而在菜单中打开命 ...
- python之SQLAlchemy ORM
前言: 这篇博客主要介绍下SQLAlchemy及基本操作,写完后有空做个堡垒机小项目.有兴趣可看下python之数据库(mysql)操作.下篇博客整理写篇关于Web框架和django基础~~ 一.OR ...
- python使用sqlalchemy连接pymysql数据库
python使用sqlalchemy连接mysql数据库 字数833 阅读461 评论0 喜欢1 sqlalchemy是python当中比较出名的orm程序. 什么是orm? orm英文全称objec ...
- python 使用sqlalchemy进行数据库操作
sqlalchemy是python下一个著名的数据库orm库,可以方便地进行数据表创建.数据增删改查等操作 最详细的教程,见官方:https://docs.sqlalchemy.org 这里列举一些常 ...
- python下ssh的简单实现
python下的ssh都需要借助第三方模块paramiko来实现,在使用前需要手动安装. 一.python实现ssh (1) linux下的ssh登录 root@ubuntu:~# ssh morra ...
- python下编译py成pyc和pyo
python下编译py成pyc和pyo 其实很简单, 用 python -m py_compile file.py python -m py_compile /root/src/{file1,f ...
- Python下划线与命名规范
Python下划线与命名规范 先看结论,节省只想知道答案你的宝贵时间: _xxx 不能用于from module import * 以单下划线开头的表示的是protected类型的变量.即保护类型只能 ...
随机推荐
- PAT 1061 - 1064 题解
这四道题来自 13 年 08 月 30 的 PAT 测试. 代码量不大,思路也比较直接.不过第一题的处理逻辑不太清晰,需要好好把握.稍有不慎就掉进坑里了(很多人被这道 20'的题坑了一个多小时心慌意乱 ...
- Memory device control for self-refresh mode
To ensure that a memory device operates in self-refresh mode, the memory controller includes (1) a n ...
- linux awk(good)
一个用awk处理字符串的例子: #!/bin/bash source="nokia201703148855" preffixStr=$(echo $source |awk '{pr ...
- c语言学习笔记(6)——for和while循环
for和while等价替换 -------------------------- int i = 1; for (i; i<=100; i++){ sum = sum + 1; } ------ ...
- springCloud跨域访问
转自:http://blog.csdn.net/wangkang80/article/details/72829390 什么是跨域? 假设你在http://xxx.com/test/下有一个js文件, ...
- Linux下编译,要下载tar.xz,而不要下载zip,因为换行的编码不一样,对.h.cpp没有影响,但是对脚本有影响 good
原因是 在win下编辑的时候,换行结尾是\n\r , 而在linux下 是\n,所以才会有 多出来的\r但是这个我是直接下载的官网文件解压的,没有动过啊. 破案了. linux下编译要下 .tar.x ...
- Blend_Effect
原文:Blend_Effect 版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/u010265681/article/details/76651796 ...
- spring boot 配置swagger UI
springboot集成swaggerUI 有这样的需求 1.在每个接口上都增加一个字段: 2.接口文档只展示满足一定条件URL的接口 配置文件 详细看代码 import org.springfram ...
- Lexer的设计--上(3)
lexer的构造函数 有了上一节Token做铺垫, 可以开始设计lexer, 首先应该想到的是, 源代码是以文件流的格式传到编译器中的, 所以作为编译器的前段的第一个阶段, lexer必须负责处理输入 ...
- win10 uwp 萤火虫效果
原文:win10 uwp 萤火虫效果 本文在Nukepayload2指导下,使用他的思想用C#写出来. 本文告诉大家,如何使用 win2d 做出萤火虫效果. 安装 win2d 安装win2d的方法请使 ...