七月小说网 Python + GraphQL (三)
概述
后台数据库几个基本表基本搭建完毕,看了下Github Develop的V4 Api抛弃了RESTful,采用GraphQL,感觉很有意思,一看文档,竟然有Python的开源实现 Graphene ,这就很舒服了。
反正也是学习,搞起来。
Flask + Graphene + SQLAlchamy + MariaDB
花了点小时间的,搞出了我的第一个GraphQL接口。还是有点意思的。
findBookTypes{
  edges{
        node{
            typeId
            typeName
            parentTypeId
            summary
        }
   }
}
上边就是个GraphQL的query语句。
Flask CORS
之前我是手动设置,每个路由都要设置一下Access-Control-Allow-Origin,结果调用了一个Flask GraphQL的库,response被它封装起来了,皮的很。我又不想去手动改他的库,故而找到这个 Flask CORS库还是很给力的,一键配置跨域。
现在的开源,是真的给力哦,果断star
app = Flask(__name__)
CORS(app, supports_credentials=True)
SQLAlchamy 语法
跟传统sql语句还是有点区别的,得花点时间研究研究怎么把传统sql语句弄成符合这款ORM框架的语法。先弄点常用的用用。
跟表关联 ORM
"""作品相关"""
class BookType(Base):
    """作品类别"""
    __tablename__ = 'BOOK_TYPE'
    type_id = Column(Integer, primary_key=True)
    type_name = Column(String(255))
    summary = Column(String(255))
    parent_type_id = Column(Integer)
    state = Column(Integer)
    createtime = Column(DateTime)
查询
query.filter(BookTypeModel.parent_type_id==args.get('parentTypeId'))
Books.get_query(info).filter(BookModel.book_id==input.get('book_id')).first()
Graphene 规则
这个库还是要跟着文档走,里面语法不能错,否则很容易出错。
还有就是github上有些代码是基于老版本的,照着写也会出错,所以要注意版本升级。给个例子吧:
class Query(graphene.ObjectType):
        node = relay.Node.Field()
        findBookTypes = SQLAlchemyConnectionField(BookTypes,
            typeId=graphene.Int(), parentTypeId=graphene.Int(),
            description="通过typeId或者parentTypeId查询书类")
        def resolve_findBookTypes(self, info, **args):
            query = BookTypes.get_query(info)
            if args.get('typeId') is not None:
                return query.filter(BookTypeModel.type_id==args.get('typeId'))
            elif args.get('parentTypeId') is not None:
                return query.filter(BookTypeModel.parent_type_id==args.get('parentTypeId'))
            else:
                return query
        findRanks = SQLAlchemyConnectionField(BookTypes,
            rankTypeId=graphene.Int(required=True),
            description="通过rankTypeId查询排行榜")
        def resolve_findRanks(self, info, rankTypeId):
            query = Ranks.get_query(info)
            return query.filter(RankModel.rank_type_id==rankTypeId)
好了好了,该睡觉了。
七月小说网 Python + GraphQL (三)的更多相关文章
- React + Python 七月小说网  启程(一)
		
一.为啥要做这个网站 很久没有写技术相关的博客了,最近几个月忙飞,各种工作,技术根本学不完,很难受. 趁着春节期间,终于有空闲时间做自己爱做的事情了,美滋滋. 热爱技术,热爱小说,于是诞生了个这么玩意 ...
 - React + Python 七月小说网  功能设计(二)
		
概述 在通过对世面上的各种小说网站简单了解之后(PS:好多盗版网站真的好丑哦.),去除花里胡哨的功能,保留实用功能. 初步制定了以下几个功能需求,当然,所有需求功能都是我自己设计.自己评审,大不了到时 ...
 - Redis 七月小说网的爬虫缓存设计
		
一.爬虫策略 1.主服务器先根据spider.all set排重,再 lpush request_url 到spider.wait List中,并且 sadd request_url 到 set中: ...
 - Python的scrapy之爬取顶点小说网的所有小说
		
闲来无事用Python的scrapy框架练练手,爬取顶点小说网的所有小说的详细信息. 看一下网页的构造: tr标签里面的 td 使我们所要爬取的信息 下面是我们要爬取的二级页面 小说的简介信息: 下面 ...
 - 使用Python爬虫整理小说网资源-自学
		
第一次接触python,原本C语言的习惯使得我还不是很适应python的语法风格.希望读者能够给出建议. 相关的入门指导来自以下的网址:https://blog.csdn.net/c406495762 ...
 - Python的scrapy之爬取6毛小说网的圣墟
		
闲来无事想看个小说,打算下载到电脑上看,找了半天,没找到可以下载的网站,于是就想自己爬取一下小说内容并保存到本地 圣墟 第一章 沙漠中的彼岸花 - 辰东 - 6毛小说网 http://www.6ma ...
 - 批量下载小说网站上的小说(python爬虫)
		
随便说点什么 因为在学python,所有自然而然的就掉进了爬虫这个坑里,好吧,主要是因为我觉得爬虫比较酷,才入坑的. 想想看,你可以批量自动的采集互联网上海量的资料数据,是多么令人激动啊! 所以我就被 ...
 - Python进阶(三十五)-Fiddler命令行和HTTP断点调试
		
Python进阶(三十五)-Fiddler命令行和HTTP断点调试 一. Fiddler内置命令 上一节(使用Fiddler进行抓包分析)中,介绍到,在web session(与我们通常所说的se ...
 - 孤荷凌寒自学python第三十九天python 的线程锁Lock
		
孤荷凌寒自学python第三十九天python的线程锁Lock (完整学习过程屏幕记录视频地址在文末,手写笔记在文末) 当多个线程同时操作一个文件等需要同时操作某一对象的情况发生时,很有可能发生冲突, ...
 
随机推荐
- logback高级特性二 异步记录日志
			
问题描述: 下图中JProfiler可看出logback的日志输出占了64%的cpu消耗 优化方案: 1. 这部分写日志的代码写了一些报文数据,确实是比较大的字符串.先禁掉控制台输出,生产环境也不需要 ...
 - python开发初识函数:函数定义,返回值,参数
			
一,函数的定义 1,函数mylen叫做函数名 #函数名 #必须由字母下划线数字组成,不能是关键字,不能是数字开头 #函数名还是要有一定的意义能够简单说明函数的功能 2,def是关键字 (define) ...
 - 第五章 深入class文件结构
			
一次编译好的class文件是如何到处运行的 5.1 JVM指令集简介 5.1.1 与类相关的指令 5.1.2 方法的定义 5.1.3 属性的定义 5.1.4 其他指令集 5.2 class文件头的表示 ...
 - HTTP之报文
			
HTTP 报文 用于 HTTP 协议交互的信息被称为 HTTP 报文.请求端(客户端)的 HTTP 报文叫做请求报文,响应端(服务器端)的叫做响应报文.HTTP 报文本身是由多行(用 CR+LF 作换 ...
 - leetcode375
			
public class Solution { public int GetMoneyAmount(int n) { , n + ]; , n); } int DP(int[,] t, int s, ...
 - centos7 时间设置及ntp
			
转自:https://blog.gtwang.org/linux/howto-set-date-time-from-linux-command-prompt/ 這裡介紹各種在 Linux 中以手動來調 ...
 - C# XML文件操作
			
C# XML文件操作 运行环境:Window7 64bit,.NetFramework4.61,C# 6.0: 编者:乌龙哈里 2017-02-09 参考 LINQ to XML System.Xml ...
 - git用法小结(1)--建立远程仓库
			
最近一直在学习使用git来管理自己的程序,总是今天东学一点,明天西凑一点,到用的时候,总是有些茫然不知所措. 在博客园里看见一篇老好的文章,教我们做笔记啦,但是做完笔记还是要记得总结哦! 来吧,让我们 ...
 - 解决 Python 连不上pip库的问题(使用国内镜像地址)
			
经常在使用python的时候需要安装各种模块,而pip是很强大的模块安装工具,但是由于国外官方pypi经常被墙,导致不可用,所以我们最好是将自己使用的pip源更换一下,这样就能解决被墙导致的装不上 ...
 - JAVA基础知识总结15(集合容器)
			
集合框架:用于存储数据的容器. 1:对象封装数据,对象多了也需要存储.集合用于存储对象. 2:对象的个数确定可以使用数组,但是不确定怎么办?可以用集合.因为集合是可变长度的. 集合和数组的区别: 1: ...