免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 5017 | 回复: 4
打印 上一主题 下一主题

大家用过什么python的ORM模块么? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2015-05-21 14:02 |只看该作者 |倒序浏览
大家用过么,刚刚在写python里访问数据库的功能,一直用的都是MySQLdb模块,直接用sql语句。突然觉得写sql语句好麻烦,感觉好low啊,好长一串,用好多+号连接变量和sql语句。

大家用过什么python的ORM模块么?会不会比sql语句方便好用些?

论坛徽章:
14
15-16赛季CBA联赛之辽宁
日期:2019-06-16 15:47:3515-16赛季CBA联赛之广夏
日期:2016-08-13 21:24:352015亚冠之武里南联
日期:2015-07-07 17:37:372015亚冠之萨济拖拉机
日期:2015-07-06 17:07:482015亚冠之全北现代
日期:2015-06-04 13:54:272015亚冠之城南
日期:2015-05-21 15:43:212015年亚洲杯之伊朗
日期:2015-04-25 18:20:362015年亚洲杯之伊朗
日期:2015-04-20 16:06:052015年亚洲杯之科威特
日期:2015-03-07 12:51:26丑牛
日期:2014-12-30 10:26:38申猴
日期:2014-09-28 22:40:18金牛座
日期:2014-09-13 21:12:22
2 [报告]
发表于 2015-05-21 15:43 |只看该作者
贴代码看看~~~

论坛徽章:
0
3 [报告]
发表于 2015-05-21 16:27 |只看该作者
做web开发的话一般都自带ORM,不如django什么的。或者你可以自己封装.
比如我简单封装了update
  1. def update(self, tablename, update_dict, condition_dict = {}, dry=False):
  2.                 sql = "UPDATE `%s` SET " % tablename
  3.                 for key in update_dict.iterkeys():
  4.                         sql += "`" + key + "` = %(" + key + ")s,"
  5.                        
  6.                 sql = sql[:-1]
  7.                        
  8.                 if len(condition_dict) > 0:
  9.                         sql += " WHERE "
  10.                         for key in condition_dict.iterkeys():
  11.                                 sql += "`" + key  + "` = %(" + key + ")s AND "
  12.                                 if not update_dict.has_key(key):
  13.                                         update_dict[key] = condition_dict[key]
  14.                                
  15.                         sql = sql[:-4]
  16.                
  17.                 if dry:
  18.                         return sql, update_dict
  19.                 else:
  20.                         return self.operation(sql, update_dict)
复制代码

论坛徽章:
14
15-16赛季CBA联赛之辽宁
日期:2019-06-16 15:47:3515-16赛季CBA联赛之广夏
日期:2016-08-13 21:24:352015亚冠之武里南联
日期:2015-07-07 17:37:372015亚冠之萨济拖拉机
日期:2015-07-06 17:07:482015亚冠之全北现代
日期:2015-06-04 13:54:272015亚冠之城南
日期:2015-05-21 15:43:212015年亚洲杯之伊朗
日期:2015-04-25 18:20:362015年亚洲杯之伊朗
日期:2015-04-20 16:06:052015年亚洲杯之科威特
日期:2015-03-07 12:51:26丑牛
日期:2014-12-30 10:26:38申猴
日期:2014-09-28 22:40:18金牛座
日期:2014-09-13 21:12:22
4 [报告]
发表于 2015-05-21 17:09 |只看该作者
回复 3# huangxiaohen


    大师牛逼~  

论坛徽章:
1
数据库技术版块每日发帖之星
日期:2016-03-08 06:20:00
5 [报告]
发表于 2015-05-24 23:07 |只看该作者
SQLAlchemy 和 django的ORM
用过ORM后,就不再写sql语句了。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP