python简单实现了一个ORM
python简单实现了一个ORM
(推荐操作系统:windows7系统、Python3.9.1、DELLG3电脑。)
1、定义Field类,它负责保存数据库表的字段名和字段的类型:
classField(object):
def__init__(self,name,column_type):
self.name=name
self.column_type=column_type
2、在Field的基础上,进一步定义各种具体类型的Field,比如StringField,IntegerField等等:
classStringField(Field):
def__init__(self,name,max_length):
super(StringField,self).__init__(name,'varchar(%d)'%max_length)
classIntegerField(Field):
def__init__(self,name):
super(IntegerField,self).__init__(name,'int')
3、下一步,就是编写最复杂的ModelMetaclass了:
classModelMetaclass(type):
def__new__(cls,name,bases,attrs):
ifname=='Model':
returntype.__new__(cls,name,bases,attrs)
print('Foundmodel:%s'%name)
mappings=dict()
fork,vinattrs.items():
ifisinstance(v,Field):
mappings[k]=v
forkinmappings.keys():
attrs.pop(k)
attrs['__mappings__']=mappings
attrs['__table__']=name
returntype.__new__(cls,name,bases,attrs)
4、创建User类,并调用save方法,保存:
classUser(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,希望能对大家有所帮助。更多Python学习教程请关注IT培训机构:千锋教育。
猜你喜欢LIKE
相关推荐HOT
更多>>如何使用python中的add函数?
如何使用python中的add函数?本文教程操作环境:windows7系统、Python3.9.1,DELLG3电脑。add函数使用方法1、numpy中加法运算使用实例importnump...详情>>
2023-11-14 14:11:16python如何将九九乘法表写入到Excel?
python如何将九九乘法表写入到Excel?现在使用python去输出九九乘法表,已经不再稀奇,我们经常输出的环境是文本,但是今天教大家更为复杂一点的...详情>>
2023-11-14 12:11:28python中altair可视化库怎么用?
python中altair可视化库怎么用?作为六大python可视化库,基本上学会都是可以通吃任何领域的存在,本章要给大家介绍的Altair就是其中之一的可视...详情>>
2023-11-14 09:40:29python中最小二乘法如何理解?
python中最小二乘法如何理解?python中在实现一元线性回归时会使用最小二乘法,那你知道最小二乘法是什么吗。其实最小二乘法为分类回归算法的基...详情>>
2023-11-14 06:58:12热门推荐
如何使用python中的add函数?
沸python中dir函数如何使用?
热python中merge函数如何使用?
热python中str内置函数总结归纳
新python如何将九九乘法表写入到Excel?
Python的scikit-image模块是什么?
python timedelta函数是什么?
python中如何使用np.concatenate()拼接numpy数组
Python jieba库分词模式怎么用?
python中altair可视化库怎么用?
TCP在python中如何连接服务器?
python中使用__slots__定义类属性
python中的unittest框架是什么?
python字典获取对应键的方法