
SqlAlchemy
stonefisher
这个作者很懒,什么都没留下…
展开
-
SQLAlchemy中设置Column的默认值
在使用SQLAlchemy时,如果主健使用uuid时import uuidid = db.Column(db.String(32), default=uuid.uuid4().hex, primary_key=True)上述写法,如果在进行批量增加时,会出现“主关健字重复”的错误正确的做法应该是def gen_id(): return uuid.原创 2015-09-12 23:44:17 · 10342 阅读 · 0 评论 -
开源一个基于SQLAlchemy左右值存储的树组件
TreeModel for SQLAlchemy基于SQLAlcemy ORM库,利用左右值原理来实现树状存储的库。什么是左右值树存储原理可以问度娘。SATree可以在一张数据库表中存储多棵树,并可以方便地进行树的增加、删除、移动、输出等。树的一个节点在存储为一条记录,表现为SQLALchemy一个混合了TreeMixin的Model实例。项目地址:原创 2015-11-05 11:30:21 · 3623 阅读 · 0 评论 -
理解SQLAlchemy的表继承关系(1)--Joined Table Inheritance
Joined Table Inheritance指通过外健方式进行链接实现的继承方式。举个例子理解,共三个ORM类: Employee:员工,基类,具有id,name两个共有字段Manager:经理,继承Employee Engineer:工程师,继承Employee,在本例中,SQLAlchemy将会创建三个表,Employee,Manager,Engineerclass原创 2015-12-09 11:27:12 · 6233 阅读 · 0 评论 -
理解SQLAlchemy的表继承关系(3)-Concrete Table Inheritance
Concrete Table Inheritance译成混合继承?这种继承方式会创建一个ORM基类,然后在所有继承表中会创建包含ORM基类定义的字段的独立的表。继承表与ORM基类的关系在数据库层面上没有外健关系,只是在语言层会有继承关系。class Employee(AbstractConcreteBase, Base): id =Column(Integer, pri原创 2015-12-09 11:45:43 · 4547 阅读 · 0 评论 -
创建SQLAlchemy的ORM类的基类(一)
SQLAlchemy功能非常强大,一般来说我们可以采用下面方法建立一个ORM类.from sqlalchemy import create_enginefrom sqlalchemy.ext.declarative import declarative_basefrom sqlalchemy.orm import sessionmakerengine = create_engine('原创 2015-06-19 16:09:55 · 7704 阅读 · 0 评论 -
创建SQLAlchemy的ORM类的基类(二)
要为SQLAlchemy的ORM类的基类还有一种方法,就是利用继承的方法来配置。rom sqlalchemy.ext.declarative import declared_attrfrom sqlalchemy.ext.declarative import AbstractConcreteBaseengine = create_engine(...)Base = declarat原创 2015-12-09 22:51:19 · 6212 阅读 · 0 评论 -
理解SQLAlchemy的表继承关系(4)--高级应用
我们创建ORM的基类的目的除了提供公共字段和属性外,还可以实现更高级的功能。在stackoverflow上发现一个应用案例,在此转载一下。class Entry(AbstractConcreteBase, db.Model): """Base Class of Entry.""" id = db.Column(db.Integer, primary_key转载 2015-12-09 23:04:37 · 6786 阅读 · 0 评论 -
理解SQLAlchemy的表继承关系(2)-Single Table Inheritance
Single Table Inheritance即单表继承,顾名思义,所有继承表的数据均保存在一个表。该种继承比较容易理解。class Employee(Base): __tablename__ = 'employee' id = Column(Integer, primary_key=True name = Column(String(50)) manager_d原创 2015-12-09 11:36:13 · 4809 阅读 · 0 评论