这篇文章给大家分享的是有关python如何实现一个ORM的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。
python常用的库:1.requesuts;2.scrapy;3.pillow;4.twisted;5.numpy;6.matplotlib;7.pygama;8.ipyhton等。
1、定义Field类,它负责保存数据库表的字段名和字段的类型:
class Field(object):
def __init__(self, name, column_type):
self.name = name
self.column_type = column_type
2、在Field的基础上,进一步定义各种具体类型的Field,比如StringField,IntegerField等等:
class StringField(Field):
def __init__(self, name, max_length):
super(StringField, self).__init__(name, 'varchar(%d)' % max_length)
class IntegerField(Field):
def __init__(self, name):
super(IntegerField, self).__init__(name, 'int')
3、下一步,就是编写最复杂的ModelMetaclass了:
class ModelMetaclass(type):
def __new__(cls, name, bases, attrs):
if name == 'Model':
return type.__new__(cls, name, bases, attrs)
print('Found model: %s' % name)
mappings = dict()
for k, v in attrs.items():
if isinstance(v, Field):
mappings[k] = v
for k in mappings.keys():
attrs.pop(k)
attrs['__mappings__'] = mappings
attrs['__table__'] = name
return type.__new__(cls, name, bases, attrs)
4、创建User类,并调用save方法,保存:
class User(Model):
id = IntegerField('id')
name = StringField('username', max_length=48)
email = StringField('email', max_length=128)
password = StringField('password', max_length=24)
# 创建一个实例:
u = User(id=12345, name='xiaoming', email='xiaoming@xiaomi.com', password='test')
# 保存到数据库:
u.save()
感谢各位的阅读!关于“python如何实现一个ORM”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。
原文链接:https://www.py.cn/jishu/jichu/27226.html