完整代碼:
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)運行代碼並驗證