论坛首页 编程语言技术论坛

web.py数据库入门

浏览 16770 次
精华帖 (0) :: 良好帖 (1) :: 新手帖 (0) :: 隐藏帖 (0)
作者 正文
   发表时间:2011-02-11  

web.py是一个非常精巧的web框架,不过其自带的db模块也是非常精简而高效。和Java里面复杂的JDBC和繁琐的Hibernat配置相比,使用web.db真是既简单又明了。

 

创建数据库对象:

 

db = web.database(dbn='mysql', user='user', pw='pass', db='dbname')

 

dbn指定数据库类型

 

查询:

 

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

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

 

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

 

查询得到的是迭代对象,直接循环

 

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

 

插入:

 

db.insert('user', name='Michael', age=29, passwd='passwd', email='abc@xyz.com')

 

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

 

修改:

 

db.update('user', where='id=$id', vars={'id':100}, name='Michael', age=29)

 

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

 

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

 

删除:

 

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

 

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

 

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

 

试想,如果用Java的Map来传入参数,你不得不编写:

 

Map where_vars = new HashMap();

where_vars.put("id", 100);

Map update_vars = new HashMap();

update_vars.put("name", "Michael");

update_vars.put("age", 29);

db.update("user", "where id=$id", where_vars, update_vars);

 

不烦死才怪。

 

在使用Java进行web开发的时候,我们总是习惯分成web,logic,dao层,然而,当极少的代码量即可完成所有工作时,真的看不出分层的意义。我使用web.py仅需600行代码就写完了网站所有的逻辑,因此,整个网站只有一个app.py文件,根本无需拆分web, db。

 

动态语言是一种趋势,尤其在web应用中。

   发表时间:2011-02-11  
確實比原生jdbc簡單,但是不能和hibernate相比。最簡單一個例子,假如我修改了數據庫的一個字段名,估計用web.py的db模塊要改很多東西。所以這個db模塊最多達到ibatis的效果,而不是hibernate。
0 请登录后投票
   发表时间:2011-02-14  
你忽略了“契约优于配置”的原则,最好的配置就是没有配置,为什么要改字段名?
1 请登录后投票
   发表时间:2011-02-15  
我记得web.py数据库连接池只针对pgsql,请问mysql怎么使用连接池?
0 请登录后投票
   发表时间:2011-02-16  
又一个WEB框架,又一个没不了解的WEB框架,做WEB的人们,你们压力大吗?

觉得一点都不好玩,学习成本啊,时间啊……

不敢用,呵呵
0 请登录后投票
   发表时间:2011-02-16  
确实不敢用,做些小东西来玩玩还可以,哥们,你用这个做一个企业级的CMS出来试试?
先不说能不能做出来,就算能做出功能那也得累死你更不说维护了!!!
0 请登录后投票
   发表时间:2011-02-16  
楼主有理,技术人员将精力集中在技术上,有几个技术人员将时间花在业务上,抛开业务谈技术一切都是浮云。开口就是hibernate,hibernate真有那么好吗?hibernate是万金油吗?淘宝做的好吧,用了hibernate吗?电信的业务大吧,都用了hibernate吗?
0 请登录后投票
   发表时间:2011-02-17  
moss 写道
楼主有理,技术人员将精力集中在技术上,有几个技术人员将时间花在业务上,抛开业务谈技术一切都是浮云。开口就是hibernate,hibernate真有那么好吗?hibernate是万金油吗?淘宝做的好吧,用了hibernate吗?电信的业务大吧,都用了hibernate吗?

事实上Hibernate在这些项目中简直就是拖累...
0 请登录后投票
   发表时间:2011-02-18  
萝卜青菜,各有所爱吧。好的web框架,也只是在特定的或者绝大数情况下更吸引人
0 请登录后投票
   发表时间:2011-02-20   最后修改:2011-02-20
"整个网站只有一个app.py文件"??
不知道维护起来怎么样,
暂时只用过django, 想试试其他框架,
有时不能太简洁, 分层还是有分层的好处.
0 请登录后投票
论坛首页 编程语言技术版

跳转论坛:
Global site tag (gtag.js) - Google Analytics