编写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 相关文章推荐
使用Python编写Linux系统守护进程实例
Feb 03 Python
Python中的Numeric包和Numarray包使用教程
Apr 13 Python
详解python使用Nginx和uWSGI来运行Python应用
Jan 09 Python
Python使用matplotlib绘制多个图形单独显示的方法示例
Mar 14 Python
python 获取list特定元素下标的实例讲解
Apr 09 Python
Python Grid使用和布局详解
Jun 30 Python
Python 调用PIL库失败的解决方法
Jan 08 Python
numpy np.newaxis 的实用分享
Nov 30 Python
Python xlrd excel文件操作代码实例
Mar 10 Python
Python基础之元类详解
Apr 29 Python
pandas时间序列之pd.to_datetime()的实现
Jun 16 Python
python数字图像处理:图像简单滤波
Jun 28 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
人族 Terran 魔法与科技
2020/03/14 星际争霸
PHP分页显示制作详细讲解
2006/10/09 PHP
dedecms 制作模板中使用的全局标记图文教程
2007/03/11 PHP
php页面跳转session cookie丢失导致不能登录等问题的解决方法
2016/12/12 PHP
jQuery 源码分析笔记(4) Ready函数
2011/06/02 Javascript
jquery 卷帘效果实现代码(不同方向)
2013/02/05 Javascript
Javascript对象属性方法汇总
2013/11/21 Javascript
jquery.cookie() 方法的使用(读取、写入、删除)
2013/12/05 Javascript
JS对话框_JS模态对话框showModalDialog用法总结
2014/01/11 Javascript
自己封装的javascript事件队列函数版
2014/06/12 Javascript
基于JavaScript创建动态Dom
2015/12/08 Javascript
JavaScript动态创建form表单并提交的实现方法
2015/12/10 Javascript
jQuery时间日期三级联动(推荐)
2016/11/27 Javascript
最实用的JS数组函数整理
2017/12/05 Javascript
JavaScript递归函数定义与用法实例分析
2019/01/24 Javascript
Vuex实现数据共享的方法
2019/12/20 Javascript
[48:37]EG vs OG 2018国际邀请赛小组赛BO2 第一场 8.17
2018/08/18 DOTA
Python命名空间详解
2014/08/18 Python
python基础教程之自定义函数介绍
2014/08/29 Python
python logging 日志轮转文件不删除问题的解决方法
2016/08/02 Python
详解Python进程间通信之命名管道
2017/08/28 Python
python for循环输入一个矩阵的实例
2018/11/14 Python
python基础 range的用法解析
2019/08/23 Python
python 实现多线程下载m3u8格式视频并使用fmmpeg合并
2019/11/15 Python
pytorch 批次遍历数据集打印数据的例子
2019/12/30 Python
Python+OpenCV实现旋转文本校正方式
2020/01/09 Python
通过python实现windows桌面截图代码实例
2020/01/17 Python
基于python的docx模块处理word和WPS的docx格式文件方式
2020/02/13 Python
利用CSS3的transition属性实现滑动效果
2015/08/05 HTML / CSS
花园仓库建筑:Garden Buildings Direct
2018/02/16 全球购物
Boom手表官网:瑞典手表品牌,设计你的手表
2019/03/11 全球购物
学校志愿者活动总结
2014/06/27 职场文书
护士医德医风心得体会
2016/01/25 职场文书
如何书写邀请函?
2019/06/24 职场文书
使用canvas仿Echarts实现金字塔图的实例代码
2021/11/11 HTML / CSS
vue中this.$http.post()跨域和请求参数丢失的解决
2022/04/08 Vue.js