编写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 urllib模块urlopen()与urlretrieve()详解
Nov 01 Python
python通过scapy获取局域网所有主机mac地址示例
May 04 Python
Python新手在作用域方面经常容易碰到的问题
Apr 03 Python
Python中动态获取对象的属性和方法的教程
Apr 09 Python
Python卸载模块的方法汇总
Jun 07 Python
python将控制台输出保存至文件的方法
Jan 07 Python
python字符串替换re.sub()方法解析
Sep 18 Python
大家都说好用的Python命令行库click的使用
Nov 07 Python
pytorch中的卷积和池化计算方式详解
Jan 03 Python
对python中各个response的使用说明
Mar 28 Python
200行python代码实现贪吃蛇游戏
Apr 24 Python
Python基础之进程详解
May 21 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
支持oicq头像的留言簿(二)
2006/10/09 PHP
PHP strstr 函数判断字符串是否否存在的实例代码
2013/09/28 PHP
Zend Framework页面缓存实例
2014/06/25 PHP
PHP+jquery+ajax实现即时聊天功能实例
2014/12/23 PHP
PHP获取当前日期和时间及格式化方法参数
2015/05/11 PHP
php版微信公众平台接口开发之智能回复开发教程
2016/09/22 PHP
php使用Jpgraph创建3D饼形图效果示例
2017/02/15 PHP
JavaScript 语法集锦 脚本之家基础推荐
2009/11/15 Javascript
JavaScript OOP类与继承
2009/11/15 Javascript
iframe子父页面调用js函数示例
2013/11/07 Javascript
js创建一个input数组并绑定click事件的方法
2014/06/12 Javascript
原生JavaScript生成GUID的实现示例
2014/09/05 Javascript
js实现仿爱微网两级导航菜单效果代码
2015/08/31 Javascript
简单实现js选项卡切换效果
2016/02/03 Javascript
jQuery表单对象属性过滤选择器实例详解
2016/09/13 Javascript
jQuery向父辈遍历的简单方法
2016/09/18 Javascript
javascript中递归的两种写法
2017/01/17 Javascript
基于jQuery实现简单人工智能聊天室
2017/02/10 Javascript
react native仿微信PopupWindow效果的实例代码
2017/08/07 Javascript
前端必备插件之纯原生JS的瀑布流插件Macy.js
2017/11/22 Javascript
使用vue打包时vendor文件过大或者是app.js文件很大的问题
2018/06/29 Javascript
AngularJs中$cookies简单用法分析
2019/05/30 Javascript
js实现可爱的气泡特效
2020/09/05 Javascript
在Python的Django框架上部署ORM库的教程
2015/04/20 Python
python压缩文件夹内所有文件为zip文件的方法
2015/06/20 Python
mac系统安装Python3初体验
2018/01/02 Python
TensorFlow 合并/连接数组的方法
2018/07/27 Python
使用python实现mqtt的发布和订阅
2019/05/05 Python
Mac安装python3的方法步骤
2019/08/09 Python
python利用Excel读取和存储测试数据完成接口自动化教程
2020/04/30 Python
建筑专业自荐信范文
2014/01/05 职场文书
20岁生日感言
2014/01/13 职场文书
少儿节目主持串词
2014/04/02 职场文书
小学生暑假家长评语
2014/04/17 职场文书
施工质量承诺书范文
2014/05/30 职场文书
python实现大文本文件分割成多个小文件
2021/04/20 Python