编写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中的字典详细介绍
Sep 18 Python
Python实现的一个简单LRU cache
Sep 26 Python
关于python的list相关知识(推荐)
Aug 30 Python
Python中list查询及所需时间计算操作示例
Jun 21 Python
pyqt5 禁止窗口最大化和禁止窗口拉伸的方法
Jun 18 Python
Tensorflow训练MNIST手写数字识别模型
Feb 13 Python
使用python3 实现插入数据到mysql
Mar 02 Python
Python PyQt5整理介绍
Apr 01 Python
Ubuntu16安装Python3.9的实现步骤
Dec 15 Python
Python实现Appium端口检测与释放的实现
Dec 31 Python
Python爬虫基础初探selenium
May 31 Python
numpy array找出符合条件的数并赋值的示例代码
Jun 01 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
php获取某个目录大小的代码
2008/09/10 PHP
PHP使用JSON和将json还原成数组
2015/02/12 PHP
php计算函数执行时间的方法
2015/03/20 PHP
PHP中Session可能会引起并发问题
2015/06/26 PHP
Zend Framework框架实现类似Google搜索分页效果
2016/11/25 PHP
PHP中的函数声明与使用详解
2017/05/27 PHP
JavaScript中this关键字使用方法详解
2007/03/08 Javascript
js仿百度有啊通栏展示效果实现代码
2013/05/28 Javascript
jsonp原理及使用
2013/10/28 Javascript
解决Jquery鼠标经过不停滑动的问题
2014/03/03 Javascript
jQuery实现自定义下拉列表
2015/01/05 Javascript
详解堆的javascript实现方法
2016/11/29 Javascript
JavaScript中三个等号和两个等号你了解多少
2017/07/04 Javascript
JavaScript捕捉事件和阻止冒泡事件实例分析
2018/08/03 Javascript
浅谈Angular 观察者模式理解
2018/11/01 Javascript
[00:33]2016完美“圣”典风云人物:BurNIng宣传片
2016/12/10 DOTA
Python松散正则表达式用法分析
2016/04/29 Python
[原创]教女朋友学Python(一)运行环境搭建
2017/11/29 Python
Python2/3中urllib库的一些常见用法
2017/12/19 Python
python 计算数组中每个数字出现多少次--“Bucket”桶的思想
2017/12/19 Python
python实现录音小程序
2020/10/26 Python
Python Numpy库安装与基本操作示例
2019/01/08 Python
pandas DataFrame 删除重复的行的实现方法
2019/01/29 Python
Python 内置函数globals()和locals()对比详解
2019/12/23 Python
Django后台管理系统的图文使用教学
2020/01/20 Python
Django如何实现防止XSS攻击
2020/10/13 Python
python 实现弹球游戏的示例代码
2020/11/17 Python
html5 canvas 简单画板实现代码
2012/01/05 HTML / CSS
Html5让容器充满屏幕高度或自适应剩余高度的布局实现
2020/05/14 HTML / CSS
缅甸网上购物:Shop.com.mm
2017/12/05 全球购物
NBA欧洲商店(英国):NBA Europe Store UK
2018/07/27 全球购物
杭州信雅达系统.NET工程师面试试题
2015/02/08 面试题
前厅收银主管岗位职责
2014/02/04 职场文书
工作态度检讨书
2014/02/11 职场文书
挂牌仪式主持词
2014/03/20 职场文书
道德大讲堂实施方案
2014/05/14 职场文书