`
asklxf
  • 浏览: 36826 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

web.py数据库入门

阅读更多

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应用中。

分享到:
评论
13 楼 wmjie 2011-03-24  
duan1823a 写道
确实不敢用,做些小东西来玩玩还可以,哥们,你用这个做一个企业级的CMS出来试试?
先不说能不能做出来,就算能做出功能那也得累死你更不说维护了!!!


sohu 的闪电邮就用的 webpy
http://mailteam.blog.sohu.com/136961251.html

12 楼 greatghoul 2011-03-23  
linvar 写道
"整个网站只有一个app.py文件"??
不知道维护起来怎么样,
暂时只用过django, 想试试其他框架,
有时不能太简洁, 分层还是有分层的好处.


这个只是对对于一些极其简单的系统而言的,如果东西比较复杂,当然也有相对的配置方案。
11 楼 greatghoul 2011-03-23  
感觉没有什么可比性,Hibernate有它的优越之处,py好,但只单纯的拿py和其它语言比来比去,有点无语。
抬高这个,贬低那个,并不能显示你多么牛X.
10 楼 an_six 2011-03-02  
框架的作用是规范开发,方便二次开发,和性能一点关系都没有.所以分层是为了业务更清楚,自己和别人更能理解.小的,项目是看不出来,稍大一点的项目,只要有2次开发,框架的优势就显现了.
9 楼 linvar 2011-02-20  
"整个网站只有一个app.py文件"??
不知道维护起来怎么样,
暂时只用过django, 想试试其他框架,
有时不能太简洁, 分层还是有分层的好处.
8 楼 qiukm321 2011-02-18  
萝卜青菜,各有所爱吧。好的web框架,也只是在特定的或者绝大数情况下更吸引人
7 楼 GIL_CHEN 2011-02-17  
moss 写道
楼主有理,技术人员将精力集中在技术上,有几个技术人员将时间花在业务上,抛开业务谈技术一切都是浮云。开口就是hibernate,hibernate真有那么好吗?hibernate是万金油吗?淘宝做的好吧,用了hibernate吗?电信的业务大吧,都用了hibernate吗?

事实上Hibernate在这些项目中简直就是拖累...
6 楼 moss 2011-02-16  
楼主有理,技术人员将精力集中在技术上,有几个技术人员将时间花在业务上,抛开业务谈技术一切都是浮云。开口就是hibernate,hibernate真有那么好吗?hibernate是万金油吗?淘宝做的好吧,用了hibernate吗?电信的业务大吧,都用了hibernate吗?
5 楼 duan1823a 2011-02-16  
确实不敢用,做些小东西来玩玩还可以,哥们,你用这个做一个企业级的CMS出来试试?
先不说能不能做出来,就算能做出功能那也得累死你更不说维护了!!!
4 楼 分离的北极熊 2011-02-16  
又一个WEB框架,又一个没不了解的WEB框架,做WEB的人们,你们压力大吗?

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

不敢用,呵呵
3 楼 lovetysx 2011-02-15  
我记得web.py数据库连接池只针对pgsql,请问mysql怎么使用连接池?
2 楼 asklxf 2011-02-14  
你忽略了“契约优于配置”的原则,最好的配置就是没有配置,为什么要改字段名?
1 楼 xnnyygn 2011-02-11  
確實比原生jdbc簡單,但是不能和hibernate相比。最簡單一個例子,假如我修改了數據庫的一個字段名,估計用web.py的db模塊要改很多東西。所以這個db模塊最多達到ibatis的效果,而不是hibernate。

相关推荐

    python web py入门配套源代码

    【Python Web 开发基础】 Python 是一种高级编程语言,以其简洁、优雅的...通过学习和实践这个入门项目,你不仅可以掌握Python Web开发的基本流程,还能了解到前后端协作的方式,为今后的Web开发之路打下坚实的基础。

    python web 轻量级框架

    如果你还没有安装,可以通过`pip install webpy`命令进行安装。 接着,创建一个Python文件,例如`app.py`,并在其中定义URL映射、处理函数和模板。以下是一个简单的示例: ```python import web urls = ( '/', '...

    webpy演示例子1

    WebPy 是一个轻量级的Python Web框架,它允许开发者以简洁、直观的方式构建Web应用。这个"webpy演示例子1"是针对...继续深入研究WebPy文档和这个示例,你将掌握更多关于路由、数据库交互、表单处理等Web开发关键概念。

    python for web2py

    - **学习曲线**: Web2Py的入门门槛相对较低,适合Python初学者快速上手。 - **轻量级**: 相较于Django,Web2Py的体积更小,更适合小型项目和快速原型开发。 - **灵活性**: Web2Py的MVC架构允许开发者更自由地定制和...

    web2py_win_py37.zip

    9. **学习资源**:Web2Py官方网站提供了详尽的文档和教程,包括快速入门指南、API参考以及社区论坛,对于初学者和有经验的开发者来说都是很好的学习资源。 10. **国际化的支持**:Web2Py支持多语言,允许你创建面向...

    资源包web2py

    10. **社区与文档**:Web2py有一个活跃的开发者社区,提供了丰富的文档和教程,方便新手入门和高级开发者深入研究。 压缩包中的"web2py"可能包含了Web2py框架的源代码、库文件、示例应用、文档等资源。开发者可以...

    Flask-1.0.2-py2.py3-none-any.whl

    **Flask 1.0.2 知识点详解** ...对于初学者,理解这些概念和实践操作将有助于快速入门 Flask Web 开发。在实际项目中,不断探索和学习更多的 Flask 扩展和最佳实践,能够帮助你构建出强大而灵活的 Web 应用。

    Python库 | pcpp-1.30-py2.py3-none-any.whl

    它支持面向对象、命令式、函数式和过程式编程范式,适合初学者入门,也适用于专业开发。Python广泛应用于Web开发、数据科学、人工智能、自动化脚本、网络编程等多个领域。 **后端开发** 后端开发是指构建服务器端...

    APScheduler-3.2.0-py2.py3-none-any.whl.zip

    在提供的压缩包中,`使用说明.txt` 文件很可能是 APScheduler 的使用指南或快速入门文档,它会介绍如何配置和启动调度器,以及如何定义和调度任务。用户应该首先阅读这份文档,以了解如何在项目中正确集成 ...

    Python库 | permon-2.0.1-py2.py3-none-any.whl

    这些库可以处理数据库连接(如SQLAlchemy)、实现Web框架(如Django或Flask)、提供API接口(如Flask-RESTful)等。通过合理利用Python库,开发者可以大大提高工作效率,同时确保代码的质量和可维护性。 总结来说,...

    爬取笑话标题内容.py等4个文件.zip

    本压缩包包含的四个Python脚本是针对初学者设计的入门实例,旨在帮助新手快速掌握Python编程基础,特别是爬虫技术的应用。 1. **有道翻译.py**: 这个脚本可能是利用Python的`requests`库进行网络请求,获取有道...

    Django入门笔记.doc

    Django入门笔记主要涵盖以下几个关键知识点: 1. **创建项目**:Django是Python的一款Web框架,用于快速开发高效、可维护的网站。创建项目是使用Django的第一步,通过命令行工具`django-admin startproject project...

    Python库 | jbxapi-2.10.1-py2.py3-none-any.whl

    由于其易学性,Python已经成为初学者入门编程的首选语言,同时也被广泛应用于科学计算、Web开发、数据分析、人工智能等领域。 **后端开发** 后端开发是构建应用程序的“幕后”部分,处理数据存储、业务逻辑和...

    web2py manual

    官方文档覆盖了从入门到进阶的所有内容,是学习web2py的最佳起点。 ### 结论 总的来说,web2py是一个功能强大且易于上手的Web应用框架,它不仅适用于初学者,也深受经验丰富的开发者的喜爱。无论是用于教学还是实际...

    本博客的数据库与模型非Django自动生成,采用Python的web开发框架(Django)和Mysql数据库.rar

    本篇使用Python Web框架Django连接和操作MySQL数据库学生信息管理系统(SMS),主要包含对学生信息增删改查功能,旨在快速入门Python Web,少走弯路。效果演示在项目实战最后一节,文章结尾有整个项目的源码地址。 ...

    Python学习资料

    通过阅读,你可以了解到如何使用Django创建数据库驱动的Web应用,以及如何实现用户认证和管理、表单处理等功能。 接下来是"web.py-doc.chm",web.py是一个轻量级的Python Web框架,它强调简洁和清晰。web.py提供了...

    Django实战入门项目.rar

    【Django实战入门项目】是针对初学者设计的一套教程,旨在帮助他们快速掌握Django框架,从而能够构建实际的Web应用。Django是Python语言中最受欢迎的Web开发框架之一,以其“ batteries included ”的理念,提供了...

Global site tag (gtag.js) - Google Analytics