werkzeug實現簡單Python web框架(4):添加orm支持

完整代碼:
https://github.com/yangzhezjgs/Light/tree/master/webapp

orm代碼:
參考前文 Python實現簡單orm
將代碼複製粘貼到orm.py文件即可。

下面我們用一個例子來說明這個簡單orm的使用。
(1)新建 scheme.sql

drop database if exists my_user;

create database my_user;

use my_user;

create table users (
    `id` varchar(50) not null,
    `passwd` varchar(50) not null,
    `name` varchar(50) not null,
    primary key (`id`)
) engine=innodb default charset=utf8;

(2)執行mysql -uroot -p <scheme.sql 並輸入密碼。

(3)使用orm插入數據
新建demo.py

from webapp import WebApp,View,render_template
from orm import Model,StringField

class User(Model):
    __table__ = 'users'
    __database__='my_user'
    id = StringField(primary_key=True, ddl='varchar(50)')
    passwd = StringField(ddl='varchar(50)')
    name = StringField(ddl='varchar(50)')


class Index(View):
    def GET(self,request):
        user1 = User.filter()[0]
        name = user1.get('name')
        return render_template("index.html",name=name)

class Test(View):
    def GET(self,request,my_id):
        return "test",my_id

urls = [
{
    'url':'/',
    'view':Index
},
{
   'url':'/test/<my_id>',
   'view':Test
}
] 
if __name__ == '__main__':

    app = WebApp()

    app.add_url_rule(urls)

    app.run()

插入數據

master@ubuntu:~/webapp$ python3
Python 3.6.0 |Anaconda 4.3.1 (64-bit)| (default, Dec 23 2016, 12:22:00) 
[GCC 4.4.7 20120313 (Red Hat 4.4.7-1)] on linux
Type "help", "copyright", "credits" or "license" for more information.
>>> from demo import User
>>> u = User(id=0,passwd='123456',name='xiaoming')
>>> u.save()
insert into `users` (`passwd`, `name`, `id`) values (?, ?, ?) ['123456', 'xiaoming', 0]
insert into `users` (`passwd`, `name`, `id`) values ('123456', 'xiaoming', '0')
()

(4)運行代碼並驗證
這裏寫圖片描述

這裏寫圖片描述

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章