sqlalchemy简单示例

1、初始化数据库database.py

#!/usr/bin/env python
# -*- coding: utf-8 -*-
# Created by miaoshuijian on 2017/3/13

from sqlalchemy import create_engine, MetaData
from sqlalchemy.orm import scoped_session, sessionmaker
# print MOIRAI_DB_CONNECT_STRING
engine = create_engine('mysql+pymysql://root:@127.0.0.1:3306/secdev?charset=utf8')
metadata = MetaData()
db_session = scoped_session(sessionmaker(autocommit=False,
                                         autoflush=False,
                                         bind=engine))
def init_db():
    metadata.create_all(bind=engine)

def shutdown_session(exception=None):
    db_session.remove()

2、

#!/usr/bin/env python
# -*- coding: utf-8 -*-
# Created by miaoshuijian on 2017/3/13

from sqlalchemy import Table, Column, Integer, String
from sqlalchemy.orm import mapper
from database import metadata, db_session


class User(object):
    query = db_session.query_property()
    def __init__(self, name=None, email=None):
        self.name = name
        self.email = email
    def __repr__(self):
        return '<User %r>' % (self.name)

users = Table('users', metadata,
    Column('id', Integer, primary_key=True),
    Column('name', String(50), unique=False),
    Column('email', String(120), unique=False)
)
mapper(User, users)

3、操作:

#!/usr/bin/env python
# -*- coding: utf-8 -*-
# Created by miaoshuijian on 2017/3/13

from database import init_db, db_session, shutdown_session
from models import User



if __name__=='__main__':
    init_db()
    u = User('admin', 'admin@localhost')
    db_session.add(u)
    db_session.commit()
    print User.query.all()
    print User.query.filter(User.name == 'admin').first()
    shutdown_session()

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值