编写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实现2014火车票查询代码分享
Jan 10 Python
Python批量按比例缩小图片脚本分享
May 21 Python
简单介绍使用Python解析并修改XML文档的方法
Oct 15 Python
Python爬虫包 BeautifulSoup  递归抓取实例详解
Jan 28 Python
浅谈Python2、Python3相对路径、绝对路径导入方法
Jun 22 Python
python3判断url链接是否为404的方法
Aug 10 Python
python将处理好的图像保存到指定目录下的方法
Jan 10 Python
django rest framework vue 实现用户登录详解
Jul 29 Python
python实现两个文件夹的同步
Aug 29 Python
python 实现音频叠加的示例
Oct 29 Python
完美处理python与anaconda环境变量的冲突问题
Apr 07 Python
Pytest中skip skipif跳过用例详解
Jun 30 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邮件类
2007/01/03 PHP
PHP n个不重复的随机数生成代码
2009/06/23 PHP
理解PHP中的Session及对Session有效期的控制
2016/01/08 PHP
PHP全局变量与超级全局变量区别分析
2016/04/01 PHP
PHP中call_user_func_array回调函数的用法示例
2016/11/26 PHP
php微信高级接口调用方法(自定义菜单接口、客服接口、二维码)
2016/11/28 PHP
jQuery 点击图片跳转上一张或下一张功能的实现代码
2010/03/12 Javascript
js setTimeout()函数介绍及应用以倒计时为例
2013/12/12 Javascript
js使用DOM设置单选按钮、复选框及下拉菜单的方法
2015/01/20 Javascript
深入学习JavaScript对象
2015/10/13 Javascript
js实现新年倒计时效果
2015/12/10 Javascript
JS控制HTML元素的显示和隐藏的两种方法
2016/09/27 Javascript
jQuery控制控件文本的长度的操作方法
2016/12/05 Javascript
Javascript自定义事件详解
2017/01/13 Javascript
利用canvas实现的加载动画效果实例代码
2017/07/05 Javascript
在react中使用vuex的示例代码
2018/07/30 Javascript
Vue.js实现备忘录功能
2019/06/26 Javascript
javascript中this的用法实践分析
2019/07/29 Javascript
微信分享invalid signature签名错误踩过的坑
2020/04/11 Javascript
ant-design-vue中的select选择器,对输入值的进行筛选操作
2020/10/24 Javascript
[03:08]Ti4观战指南上
2014/07/07 DOTA
python实现在IDLE中输入多行的方法
2018/04/19 Python
使用Puppeteer爬取微信文章的实现
2020/02/11 Python
Charles&Keith美国官方网站:新加坡快时尚鞋类和配饰零售商
2019/11/27 全球购物
请用用Java代码写一个堆栈
2012/01/26 面试题
教师研修随笔感言
2014/01/23 职场文书
怀念母亲教学反思
2014/04/28 职场文书
纪检监察建议书
2014/05/19 职场文书
师范类求职信
2014/06/21 职场文书
付款委托书范本
2014/10/05 职场文书
自我查摆剖析材料
2014/10/11 职场文书
学雷锋倡议书
2015/01/19 职场文书
晚会开场白和结束语
2015/05/29 职场文书
数据库连接池
2021/04/06 MySQL
SQL实现LeetCode(177.第N高薪水)
2021/08/04 MySQL
JS前端可扩展的低代码UI框架Sunmao使用详解
2022/07/23 Javascript