zoukankan      html  css  js  c++  java
  • web.py 数据库操作指南

    web.py 数据库操作指南 - 品牌控

    web.py 数据库操作指南

    By kenneth at 15 hours ago, 7 次点击
    官网地址:http://webpy.org/
    web.py是一个小巧灵活的框架,最新稳定版是0.33。这里不介绍web开发部分,介绍下关于数据库的相关操作。
    很多Pyer一开始都喜欢自己封装数据库操作类,本人亦如此。不过后来通过观摩web.py的源码,发现其数据库操作部分相当紧凑实用。推荐懒人可以尝试一下。
    废话不多,先来安装,有两种方式:
    1. easy_install方式,如果木有此工具,可以参考:http://chenxiaoyu.org/blog/archives/23
    easy_install web.py
    2. 下载源码编译。地址: http://webpy.org/static/web.py-0.33.tar.gz ,解压后执行:
    python setup.py install
    web.py安装算到此结束,如果想使用其中的db功能,还得借助与相应数据库操作模块,比如MySQLdb、psycopg2。如果需要尝试连接池(database pool)功能,还得装下DBUtils。这几个模块都可以通过easy_install来安装。
    下面开始使用吧!
    1. 导入模块,定义数据库连接db。
    import web
    db = web.database(dbn='postgres', db='mydata', user='dbuser', pw='')
    2. select 查询
    # 查询表
    entries = db.select('mytable')
    # where 条件
    myvar = dict(name="Bob")
    results = db.select('mytable', myvar, where="name = $name")
    results = db.select('mytable', where="id>100")
    # 查询具体列
    results = db.select('mytable', what="id,name")
    # order by
    results = db.select('mytable', order="post_date DESC")
    # group
    results = db.select('mytable', group="color")
    # limit
    results = db.select('mytable', limit=10)
    # offset
    results = db.select('mytable', offset=10)
    3. 更新
    db.update('mytable', where="id = 10", value1 = "foo")
    4. 删除
    db.delete('mytable', where="id=10")
    5. 复杂查询
    # count
    results = db.query("SELECT COUNT(*) AS total_users FROM users")
    print results[0].total_users
    # join
    results = db.query("SELECT * FROM entries JOIN users WHERE entries.author_id = users.id")
    # 防止SQL注入可以这么干
    results = db.query("SELECT * FROM users WHERE id=$id", vars={'id':10})
    6 多数据库操作 (web.py大于0.3)
    db1 = web.database(dbn='mysql', db='dbname1', user='foo')
    db2 = web.database(dbn='mysql', db='dbname2', user='foo')
    print db1.select('foo', where='id=1')
    print db2.select('bar', where='id=5')
    7. 事务
    t = db.transaction()
    try:
    db.insert('person', name='foo')
    db.insert('person', name='bar')
    except:
    t.rollback()
    raise
    else:
    t.commit()
    # Python 2.5+ 可以用with
    from __future__ import with_statement
    with db.transaction():
    db.insert('person', name='foo')
    db.insert('person', name='bar')
  • 相关阅读:
    [原][osg]osg程序窗口化、显示网格、状态信息
    [转][qt]QSignalMapper 的用法,识别QPushButton的传入参数
    [转]office2013密钥和office2013永久激活码
    [原][工具][C++]调用adobe reader打开pdf,通过命令行启动pdf
    [转]C/C++实现回调机制的几种方式(回调、槽、代理)
    [转][c++]关于构造函数不能有返回类型的错误
    [转]全国性的地理空间数据库管理平台
    [转]JsonCpp遍历json
    阿里开源分布式事务解决方案 Fescar
    MySQL 中基于 XA 实现的分布式事务
  • 原文地址:https://www.cnblogs.com/lexus/p/2839301.html
Copyright © 2011-2022 走看看