SQLAlchemy是一个强大的Python SQL工具箱, 提供了包括ORM在内的各种支持.

首先使用pip安装;

pip install SQLAlchemy

SQL Expression Language 是SQLAlchemy Core的组成部分, 提供了与SQL类似的API而避免了直接书写SQL语句.

连接数据库

使用下列语句连接数据库:

from sqlalchemy import create_engine
engine = create_engine("mysql://root:passwd@localhost:3306/webpy?charset=utf8", echo=True)

create_engine的第一个参数的格式为:

数据库类型://用户名:密码@数据库主机地址/数据库名?编码

没有密码则为空,不填; echo=True则在终端进行回显, 默认为False.

engine可以直接执行sql语句:

engine.execute("SELECT * FROM user")

如果需要事务性操作则需要使用connect:

conn = engine.connect()
result = conn.execute("SELECT * FROM user")

Create Table

使用metadata和Table类来定义表:

from sqlalchemy import create_engine, Table, Column, Integer, String, MetaData, ForeignKey
import MySQLdb engine = create_engine("mysql://root:password@localhost:3306/test?charset=utf8", encoding="utf-8", echo=True) metadata = MetaData() # define
user = Table('user', metadata,
Column('user_id', Integer, primary_key=True),
Column('name', String(20)),
) # do create and commit
metadata.create_all(engine)

回显信息:

...
INFO sqlalchemy.engine.base.Engine
CREATE TABLE user (
user_id INTEGER NOT NULL AUTO_INCREMENT,
name VARCHAR(20),
PRIMARY KEY (user_id)
)
....
INFO sqlalchemy.engine.base.Engine COMMIT

Insert

使用engine.connect()来执行:

from sqlalchemy import create_engine, Table, Column, Integer, String, MetaData, ForeignKey
import MySQLdb engine = create_engine("mysql://root:password@localhost:3306/test?charset=utf8", encoding="utf-8", echo=True) metadata = MetaData() user = Table('user', metadata,
Column('user_id', Integer, primary_key=True),
Column('name', String(20)),
Column('fullname', String(40)),
) conn = engine.connect()
i = user.insert()
u = {'name': 'yichya'}
result = conn.execute(i, **u)

select

仍然使用conn对象, 先做一个select * from user

conn = engine.connect()
s = user.select()
result = conn.execute(s)
print (result.fetchall() )

回显:

INFO sqlalchemy.engine.base.Engine SELECT user.user_id, user.name, user.fullname  FROM user
INFO sqlalchemy.engine.base.Engine ()
[(1L, u'yichya', None)]

可以使用for-each遍历结果集:

>>>for raw in result:
... print(raw)
INFO sqlalchemy.engine.base.Engine ()
(1L, u'yichya', None)
(2L, u'finley', None)
(3L, u'yy', None)
(4L, u'godess', None)

使用user的column对象可以自定义查询的字段

>>>print(user.c)
['user.user_id', 'user.name', 'user.fullname']

注意select不是从user对象中获得的:

from sqlalchemy.sql import select
conn = engine.connect()
s = select([user.c.user_id, user.c.name])
result = conn.execute(s)
print (result.fetchall() )

可以在终端看到:

INFO sqlalchemy.engine.base.Engine SELECT user.user_id, user.name
FROM user
INFO sqlalchemy.engine.base.Engine ()
[(1L, u'yichya'), (2L, u'finley'), (3L, u'yy'), (4L, u'godess')]

使用where()筛选记录:

from sqlalchemy.sql import select
conn = engine.connect()
s = select([user.c.name]).where(user.c.name == 'yy')
result = conn.execute(s)
print(result.fetchall() )

可以看到回显:

INFO sqlalchemy.engine.base.Engine SELECT user.name
FROM user
WHERE user.name = %s
INFO sqlalchemy.engine.base.Engine ('yy',)
[(u'yy',)]

实际上user.c重载了各种运算符:

>>>print(user.c.name == None)
"user".name IS NULL

where支持的运算符包括: > < <= >= ==!= , 逻辑符and,or, not需要用下述方法:

>>>from sqlalchemy.sql import and_
>>>print(and_(user.c.user_id == address.c.user_id, address.c.city == 'New York') )
"user".user_id = address.user_id AND address.city = :city_1

顺便展示了多表连接查询, 也可以使用join进行查询:

>>>s = select([user.c.name, address.c.email]).select_from(user.join(address, user.c.user_id==address.c.user_id))
>>>print s
SELECT "user".name, address.email
FROM "user" JOIN address ON "user".user_id = address.user_id

更多的查询请参见,文末的参考链接.

Update

仍然使用connect执行:

conn = engine.connect()
u = user.update().where(user.name == 'yichya').values(name='aa')
result = conn.execute(u)

Delete

delete也很简单:

>>>d = user.delete().where(user.c.name == 'yichya')
>>>conn.execute(d)
INFO sqlalchemy.engine.base.Engine DELETE FROM user WHERE user.name = %s
INFO sqlalchemy.engine.base.Engine ('yichya',)
INFO sqlalchemy.engine.base.Engine COMMIT

参考资料:

sqlalchemy docs latest

SQLAlchemy 简单笔记

使用SQLAlchemy-廖雪峰

SQLAlchemy之SQL Expression的更多相关文章

  1. SQL Expression Language Tutorial 学习笔记二

    11. Using Textual SQL 直接使用 SQL 如果实在玩不转, 还是可以通过 test() 直接写 SQL. In [51]: s = text( ...: "SELECT ...

  2. SQL Expression Language Tutorial 学习笔记一

    http://docs.sqlalchemy.org/en/latest/core/tutorial.html Google 翻译了一下 SQLAlchemy Expression Language, ...

  3. sqlalchemy防sql注入

    银行对安全性要求高,其中包括基本的mysql防注入,因此,记录下相关使用方法: 注意:sqlalchemy自带sql防注入,但是在 execute执行 手写sql时 需要考虑此安全问题 对于 wher ...

  4. sqlalchemy 执行sql

    关键需要使用text from sqlalchemy import create_engine, text sql = 'SELECT * FROM my_table WHERE account_id ...

  5. sqlalchemy执行sql语句

    #删除user表中的所有数据,表中的自增字段又从默认值开始 session.execute("truncate table user")

  6. SqlAlchemy个人学习笔记完整汇总-转载

    使用 sqlalchemy 有3种方式: 方式1, 使用raw sql; 方式2, 使用SqlAlchemy的sql expression; 方式3, 使用ORM.   前两种方式可以统称为 core ...

  7. python面试题解析(前端、框架和其他)

    答: HTTP是一个属于应用层的面向对象的协议,由于其简捷.快速的方式,适用于分布式超媒体信息系统.它于1990年提出,经过几年的使用与发展,得到不断地完善和扩展.目前在WWW中使用的是HTTP/1. ...

  8. Python3 连接各类数据库

    Python 标准数据库接口为 Python DB-API,Python DB-API为开发人员提供了数据库应用编程接口.它定义了一系列必须的对象和数据库存取方式, 以便为各种各样的底层数据库系统和多 ...

  9. SQL学习笔记八之ORM框架SQLAlchemy

    阅读目录 一 介绍 二 创建表 三 增删改查 四 其他查询相关 五 正查.反查 一 介绍 SQLAlchemy是Python编程语言下的一款ORM框架,该框架建立在数据库API之上,使用关系对象映射进 ...

随机推荐

  1. ES6 学习笔记之四 对象的扩展

    ES6 为对象字面量添加了几个实用的功能,虽然这几个新功能基本上都是语法糖,但确实方便. 一.属性的简洁表示法 当定义一个对象时,允许直接写入一个变量,作为对象的属性,变量名就是属性名. 例1: , ...

  2. Android实现带下划线的EditText(BUG修正)

    之前写了一个关于实现EditText显示下划线的例子,发现仍然存在一些问题,在此继续探索,原文链接:http://www.cnblogs.com/ayqy/p/3599414.html (零)另一个b ...

  3. Ajax 访问 或 获取 IIS 虚拟目录

    使用场景 最近用 .net core mvc 写了一个工具类的项目,作为我们项目的后台管理网站使用.第一次被老大拿去部署的时候被告知不可用,同样的代码在我电脑和我的iis上都可以使用的啊. 后来才知道 ...

  4. (zxing.net)解码

    //图片路径 string imgPath = @"D:\barcode.png"; //解码通用类 IBarcodeReader reader = new BarcodeRead ...

  5. 遍历 SortedList<string, string> 中的值(可用于datatable转json)

    SortedList<string, string> STK = new SortedList<string, string>();STK.Add("1", ...

  6. Android学习之ViewPager

     1.定义 ViewPager是android扩展包v4包中的类,这个类可以让用户左右切换当前的view.其中,android.support.v4是谷歌公司为了解决当前版本碎片化的问题,从而提供的一 ...

  7. Flask基础-配置,路由

    一,配置文件 flask中的配置文件是一个flask.config.Config对象(继承字典),默认配置为: { 'DEBUG': get_debug_flag(default=False), 是否 ...

  8. AndroidStudio的一些快捷键的使用

    1.返回上一次浏览快捷键的设置   https://blog.csdn.net/yingtian648/article/details/73277388 2.格式化代码的快捷键的设置      htt ...

  9. Java基础学习篇---------多态

    一.多态性的理解 1.向上转型:子类为父类对象实例化,调用的一定是子类覆写的方法,他们之间找的是共性 2.向下转型:子类扩充了父类的某些功能,而父类中没有该功能,他们之间找的是特性 案例: Numbe ...

  10. BS4爬取物价局房产备案价以及dataframe的操作来获取房价的信息分析

    因为最近要买房子,然后对房市做了一些调研,发现套路极多.卖房子的顾问目前基本都是一派胡言能忽悠就忽悠,所以基本他们的话是不能信的.一个楼盘一次开盘基本上都是200-300套房子,数据量虽然不大,但是其 ...