db.select 查询
问题:
怎样执行数据库查询?
解决方案:
如果是0.3版本, 连接部分大致如下:
db = web.database(dbn='postgres', db='mydata', user='dbuser', pw='')
当获取数据库连接后, 可以这样执行查询数据库:
# Select all entries from table 'mytable'
entries = db.select('mytable')
select方法有下面几个参数:
- vars
- what
- where
- order
- group
- limit
- offset
- _test
vars
vars变量用来填充查询条件. 如:
myvar = dict(name="Bob")
results = db.select('mytable', myvar, where="name = $name")
what
what是标明需要查询的列名, 默认是*, 但是你可以标明需要查询哪些列.
results = db.select('mytable', what="id,name")
where
where查询条件, 如:
results = db.select('mytable', where="id>100")
order
排序方式:
results = db.select('mytable', order="post_date DESC")
group
按group组排列.
results = db.select('mytable', group="color")
limit
从多行中返回limit查询.
results = db.select('mytable', limit=10)
offset
偏移量, 从第几行开始.
results = db.select('mytable', offset=10)
_test
查看运行时执行的SQL语句:
results = db.select('mytable', offset=10, _test=True)
<sql: 'SELECT * FROM mytable OFFSET 10'>