快速导航
sqlalchemy object序列化为json
灵感来源于 Django REST framework
多个实例
1posts = Post.query.all()
2serializer = Seralizer(posts,many=True)
3data = serializer.data
单个实例
1post = Post.query.first()
2serializer = Seralizer(post,many=False)
3data = serializer.data
排除字段
1serializer = Seralizer(post,exclude=['title'])
仅包括字段
1serializer = Seralizer(post,include=['title'])
关系查询深度
1serializer = Seralizer(post,depth=3)
-
depth 默认为2
增加一些自定义的函数
1serializer = Serializer(post,extra=['get_post_count'])
Post
1class Post(Model):
2 ......
3 def get_post_count(self):
4 return 11
可传递参数的函数
1class PostSerializer(Serializer):
2 count = Field(source = 'get_post_count',args={'name':'hello'},default=20)
3 class Meta:
4 include = []
5 depth = 2
6 include = []
7 exclude = []
8 extra = ['count']
像django orm一样使用sqlalchemy
djang orm与sqlalchemy相比,为什么很多人都认为django orm更好用,大概就是因为django orm更方便
基本查询(已实现)
-
gt
-
lt
-
lte
-
gte
-
contains
-
in
-
exact
-
iexact
-
startswith
-
istartswith
-
iendswith
-
endswith
-
isnull
-
range
-
year
-
month
-
day
示例:
1Post.query.filter_by(title__contains = 'sql').all()
2Post.query.exclude_by(title__contains = 'sql').all()
关系查询
1Post.query.filter_by(tags__name__contains = 'sql').all()
其它
1Post.query.filter_by(tags__name__contains = 'sql').or(Post.id == 1,Post.id == 2).all()
2Post.query.filter_by(tags__name__contains = 'sql').and(Post.id == 1,Post.id == 2).all()
3Post.query.filter_by(tags__name__contains = 'sql').exists()
4Post.query.load_only('title')
去掉一些sqlalchemy的重复工作
以flask-sqlalchemy为例,通过继承 models.py 中的Mixin,就可以去除部分重复工作
ModelMixin
自增ID -- id
1post = Post(·····)
2post.save() # 保存
3post.delete() # 保存
批量操作
-
bulk_insert
-
bulk_update
-
bulk_save
ModelTimeMixin
增加两字段
-
created_at 数据创建时间
-
updated_at 数据更新时间
ModelUserMixin
关联用户表,与User表现为多对一关系(即一个用户有多个post)
1class Post(ModelUserMixin, Model):
2
3 user_related_name = 'posts'
4 titile = ...
知识共享署名-非商业性使用-相同方式共享4.0国际许可协议