web.py框架之db模块操作

来源:互联网 发布:centos 7安装snmp服务 编辑:程序博客网 时间:2024/05/16 01:53

先创建数据库对象:


db = web.database(dbn='mysql', user='user', pw='pass', db='dbname')  //dbn指定数据库类型 db指定所连接的数据库名

 

查询:

 

users = db.query('select * from user where id>$id', vars={'id':10})

for user in users: print user.id, user.name

 

查询参数用$var_name表示,查询时用vars dict中的值替换

 

查询得到的是迭代对象,直接循环,至于每个对象的具体属性,和字段名一一对应。没有任何预定义的class,没有映射和配置,一切都是约定,你需要的是自己管理好数据库字段的命名。

 

插入:

 

db.insert('user', name='dava', age=19, passwd='passwd', email='abc@whaley.cn')

 

插入利用了python的**kw提供字段值,非常方便

 

修改:

 

db.update('user', where='id=$id', vars={'id':10}, name='dava', age=19)

 

update也充分利用了python的**kw参数,只有传入的**kw才被update,其他字段保持不变。

 

where和vars负责where语句的生成和绑定参数。

 

删除:

 

db.delete('user', where='id=$id', vars={'id':10})

 

和update类似,不过没有**kw,因为delete只需要where子句。

 

和Java比,web.py的db操作非常简单,这主要得益于python的**kw参数和内建的dict支持(对应Java的Map)


0 0
原创粉丝点击