编写Python的web框架中的Model的教程


Posted in Python onApril 29, 2015

有了ORM,我们就可以把Web App需要的3个表用Model表示出来:

import time, uuid

from transwarp.db import next_id
from transwarp.orm import Model, StringField, BooleanField, FloatField, TextField

class User(Model):
  __table__ = 'users'

  id = StringField(primary_key=True, default=next_id, ddl='varchar(50)')
  email = StringField(updatable=False, ddl='varchar(50)')
  password = StringField(ddl='varchar(50)')
  admin = BooleanField()
  name = StringField(ddl='varchar(50)')
  image = StringField(ddl='varchar(500)')
  created_at = FloatField(updatable=False, default=time.time)

class Blog(Model):
  __table__ = 'blogs'

  id = StringField(primary_key=True, default=next_id, ddl='varchar(50)')
  user_id = StringField(updatable=False, ddl='varchar(50)')
  user_name = StringField(ddl='varchar(50)')
  user_image = StringField(ddl='varchar(500)')
  name = StringField(ddl='varchar(50)')
  summary = StringField(ddl='varchar(200)')
  content = TextField()
  created_at = FloatField(updatable=False, default=time.time)

class Comment(Model):
  __table__ = 'comments'

  id = StringField(primary_key=True, default=next_id, ddl='varchar(50)')
  blog_id = StringField(updatable=False, ddl='varchar(50)')
  user_id = StringField(updatable=False, ddl='varchar(50)')
  user_name = StringField(ddl='varchar(50)')
  user_image = StringField(ddl='varchar(500)')
  content = TextField()
  created_at = FloatField(updatable=False, default=time.time)

在编写ORM时,给一个Field增加一个default参数可以让ORM自己填入缺省值,非常方便。并且,缺省值可以作为函数对象传入,在调用insert()时自动计算。

例如,主键id的缺省值是函数next_id,创建时间created_at的缺省值是函数time.time,可以自动设置当前日期和时间。

日期和时间用float类型存储在数据库中,而不是datetime类型,这么做的好处是不必关心数据库的时区以及时区转换问题,排序非常简单,显示的时候,只需要做一个float到str的转换,也非常容易。
初始化数据库表

如果表的数量很少,可以手写创建表的SQL脚本:

-- schema.sql

drop database if exists awesome;

create database awesome;

use awesome;

grant select, insert, update, delete on awesome.* to 'www-data'@'localhost' identified by 'www-data';

create table users (
  `id` varchar(50) not null,
  `email` varchar(50) not null,
  `password` varchar(50) not null,
  `admin` bool not null,
  `name` varchar(50) not null,
  `image` varchar(500) not null,
  `created_at` real not null,
  unique key `idx_email` (`email`),
  key `idx_created_at` (`created_at`),
  primary key (`id`)
) engine=innodb default charset=utf8;

create table blogs (
  `id` varchar(50) not null,
  `user_id` varchar(50) not null,
  `user_name` varchar(50) not null,
  `user_image` varchar(500) not null,
  `name` varchar(50) not null,
  `summary` varchar(200) not null,
  `content` mediumtext not null,
  `created_at` real not null,
  key `idx_created_at` (`created_at`),
  primary key (`id`)
) engine=innodb default charset=utf8;

create table comments (
  `id` varchar(50) not null,
  `blog_id` varchar(50) not null,
  `user_id` varchar(50) not null,
  `user_name` varchar(50) not null,
  `user_image` varchar(500) not null,
  `content` mediumtext not null,
  `created_at` real not null,
  key `idx_created_at` (`created_at`),
  primary key (`id`)
) engine=innodb default charset=utf8;

如果表的数量很多,可以从Model对象直接通过脚本自动生成SQL脚本,使用更简单。

把SQL脚本放到MySQL命令行里执行:

$ mysql -u root -p < schema.sql

我们就完成了数据库表的初始化。
编写数据访问代码

接下来,就可以真正开始编写代码操作对象了。比如,对于User对象,我们就可以做如下操作:

# test_db.py

from models import User, Blog, Comment

from transwarp import db

db.create_engine(user='www-data', password='www-data', database='awesome')

u = User(name='Test', email='test@example.com', password='1234567890', image='about:blank')

u.insert()

print 'new user id:', u.id

u1 = User.find_first('where email=?', 'test@example.com')
print 'find user\'s name:', u1.name

u1.delete()

u2 = User.find_first('where email=?', 'test@example.com')
print 'find user:', u2

可以在MySQL客户端命令行查询,看看数据是不是正常存储到MySQL里面了。

Python 相关文章推荐
Linux下编译安装MySQL-Python教程
Feb 02 Python
Python操作MySQL模拟银行转账
Mar 12 Python
Python实现字典(dict)的迭代操作示例
Jun 05 Python
python实现K近邻回归,采用等权重和不等权重的方法
Jan 23 Python
selenium+python自动化测试之使用webdriver操作浏览器的方法
Jan 23 Python
django 自定义过滤器(filter)处理较为复杂的变量方法
Aug 12 Python
解决python 读取excel时 日期变成数字并加.0的问题
Oct 08 Python
Pycharm中Python环境配置常见问题解析
Jan 16 Python
tensorflow之变量初始化(tf.Variable)使用详解
Feb 06 Python
Python使用uuid库生成唯一标识ID
Feb 12 Python
利用python画出AUC曲线的实例
Feb 28 Python
OpenCV-Python使用cv2实现傅里叶变换
Jun 09 Python
python获取本地计算机名字的方法
Apr 29 #Python
Python中编写ORM框架的入门指引
Apr 29 #Python
python获取本机mac地址和ip地址的方法
Apr 29 #Python
在Python中编写数据库模块的教程
Apr 29 #Python
Python的gevent框架的入门教程
Apr 29 #Python
在Python中使用HTML模版的教程
Apr 29 #Python
以Flask为例讲解Python的框架的使用方法
Apr 29 #Python
You might like
附件名前加网站名
2008/03/23 PHP
php调用c接口无错版介绍
2014/03/11 PHP
round robin权重轮循算法php实现代码
2016/05/28 PHP
KindEditor在php环境下上传图片功能集成的方法示例
2020/07/20 PHP
laravel数据库查询结果自动转数组修改实例
2021/02/27 PHP
JavaScript利用正则表达式去除日期中的-
2014/06/09 Javascript
fixedBox固定div漂浮代码支持ie6以上大部分主流浏览器
2014/06/26 Javascript
jquery解决客户端跨域访问问题
2015/01/06 Javascript
easyui取消表单实时验证,提交时统一验证的简单实例
2016/11/07 Javascript
jQuery实现鼠标经过显示动画边框特效
2017/03/24 jQuery
Angular.Js中过滤器filter与自定义过滤器filter实例详解
2017/05/08 Javascript
关于页面刷新vuex数据消失问题解决方案
2017/07/03 Javascript
JavaScript常用截取字符串的三种方式用法区别实例解析
2018/05/15 Javascript
Vue中插入HTML代码的方法
2018/09/21 Javascript
如何从0开始用node写一个自己的命令行程序
2018/12/29 Javascript
vue使用@scroll监听滚动事件时,@scroll无效问题的解决方法详解
2019/10/15 Javascript
Node配合WebSocket做多文件下载以及进度回传
2019/11/07 Javascript
[01:04:05]Mineski vs TNC 2019国际邀请赛小组赛 BO2 第一场 8.15
2019/08/16 DOTA
[02:16]完美世界DOTA2联赛PWL S3 集锦第三期
2020/12/21 DOTA
python发送arp欺骗攻击代码分析
2014/01/16 Python
python opencv 图像尺寸变换方法
2018/04/02 Python
python遍历文件夹,指定遍历深度与忽略目录的方法
2018/07/11 Python
pandas修改DataFrame列名的实现方法
2019/02/22 Python
Python 常用模块 re 使用方法详解
2019/06/06 Python
python elasticsearch从创建索引到写入数据的全过程
2019/08/04 Python
使用Tensorflow实现可视化中间层和卷积层
2020/01/24 Python
python sorted函数原理解析及练习
2020/02/10 Python
对Matlab中共轭、转置和共轭装置的区别说明
2020/05/11 Python
Parts Express:音频、视频和扬声器的第一来源
2017/04/25 全球购物
Kangol帽子官网:坎戈尔袋鼠
2018/09/26 全球购物
购买正版游戏和游戏激活码:Green Man Gaming
2019/11/06 全球购物
政府绩效管理实施方案
2014/05/04 职场文书
公司委托书格式范文
2014/10/09 职场文书
诚信承诺书
2015/01/19 职场文书
2016年119消防宣传日活动总结
2016/04/05 职场文书
大学生暑期实践报告之企业经营管理
2019/08/08 职场文书