内容简介:最近在研究SQLAlchemy源码,自己造个轮子先(当然,SQLAlchemy远比这里复杂)运行结果:
最近在研究SQLAlchemy源码,自己造个轮子先(当然,SQLAlchemy远比这里复杂)
import logging
logging.basicConfig(level=logging.DEBUG)
class Column:
def __init__(self, type, default=None):
self.col_name = None
self.col_type = type
self.col_default = default
def __eq__(self, value):
logging.debug("__eq__ of {} && {}".format(self, value))
return "{} = {}".format(self.col_name, value)
class Base(type):
def __new__(cls, *args, **kwargs):
logging.debug("creating class {}, args {}, kwargs {}".format(
cls, args, kwargs
))
if len(args) > 2:
for k, v in args[2].items():
if k.startswith("_"):
continue
v.col_name = k
return type.__new__(cls, *args, **kwargs)
class User(metaclass=Base):
__tablename__ = "user"
id = Column(int)
name = Column(str)
passwd = Column(str)
class Queryable:
def __init__(self, table):
self.table = table
def filter(self, text):
return "select * from {} where {}".format(
self.table.__tablename__,
text,
)
class Session:
def query(self, table):
logging.debug("returning Queryable({})".format(table))
return Queryable(table)
session = Session()
print(session.query(User).filter(User.id == 1))
运行结果:
jiajun@debian test: python3 orm.py
DEBUG:root:creating class <class '__main__.Base'>, args ('User', (), {'__qualname__': 'User', '__tablename__': 'user', 'id': <__main__.Column object at 0x7f8174b107b8>, 'passwd': <__main__.Column object at 0x7f8174b10940>, 'name': <__main__.Column object at 0x7f8174b10828>, '__module__': '__main__'}), kwargs {}
DEBUG:root:returning Queryable(<class '__main__.User'>)
DEBUG:root:__eq__ of <__main__.Column object at 0x7f8174b107b8> && 1
select * from user where id = 1
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Python基础教程(第2版)
Magnus Lie Hetland / 司维、曾军崴、谭颖华 / 人民邮电出版社 / 2010-7 / 69.00元
本书是经典教程的全新改版,作者根据Python 3.0版本的种种变化,全面改写了书中内容,做到既能“瞻前”也能“顾后”。本书层次鲜明、结构严谨、内容翔实,特别是在最后几章,作者将前面讲述的内容应用到了10个引人入胜的项目中,并以模板的形式介绍了项目的开发过程。本书既适合初学者夯实基础,又能帮助Python程序员提升技能,即使是 Python方面的技术专家,也能从书里找到令你耳目一新的东西。一起来看看 《Python基础教程(第2版)》 这本书的介绍吧!