热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

GraphQL学习第五篇-GraphQl中定义schema实现增、删、改、查

constDBrequire(..modeldb.js);const{GraphQLObjectType,GraphQLString,GraphQLInt,GraphQLList,

const DB = require('../model/db.js');const {GraphQLObjectType,GraphQLString,GraphQLInt,GraphQLList,GraphQLSchema,GraphQLID,GraphQLFloat,GraphQLNonNull
} = require('graphql')// 定义导航的schema,映射要操作表的字段
var NavSchema = new GraphQLObjectType({name: 'nav',fields: {_id: { type: GraphQLString },title: {type: GraphQLString}, url: {type: GraphQLString},sort: {type: GraphQLInt},status: {type: GraphQLString},add_time: {type: GraphQLString}}
})// 定义一个根,配置查询的方法
var RootSchema = new GraphQLObjectType({name: 'root',fields: {navList: {type: GraphQLList(NavSchema),async resolve(parent, args) {var navList = await DB.find('nav', {});return navList;}},oneNavList: {type: NavSchema,args: {_id: {type: GraphQLString}},async resolve(parent, args) {var oneNavList = await DB.find('nav', { "_id": DB.getObjectId(args._id)});return oneNavList[0];}}}
})// 定义一个根,配置增加、修改、删除的方法
var MutationSchema=new GraphQLObjectType({name:"mutation",fields:{// 添加的方法addNav:{// 数据类型type:NavSchema,// 接收的参数args:{title: {type: new GraphQLNonNull(GraphQLString)},url: {type: GraphQLNonNull(GraphQLString)},sort: {type: GraphQLInt},status: {type: GraphQLString},add_time: {type: GraphQLString}},// 操作的方法async resolve(parent, args) {var result = await DB.insert('nav', {title:args.title,url:args.url,sort:args.sort,status:args.status,add_time:new Date().getTime()});return result.ops[0];}},// 编辑的方法editNav:{type:NavSchema,args:{// GraphQLNonNull代表必传字段_id:{type: new GraphQLNonNull(GraphQLString)},title: {type: new GraphQLNonNull(GraphQLString)}, url: {type: GraphQLNonNull(GraphQLString)},sort: {type: GraphQLInt},status: {type: GraphQLString},add_time: {type: GraphQLString}},async resolve(parent, args) {await DB.update('nav', {"_id":DB.getObjectId(args._id)},{title:args.title,url:args.url,sort:args.sort,status:args.status,add_time:new Date().getTime()});return {_id:args._id,title:args.title,url:args.url,sort:args.sort,status:args.status,add_time:new Date().getTime()}}},deleteNav:{type:NavSchema,args:{_id:{type: new GraphQLNonNull(GraphQLString)},},async resolve(parent, args) {var oneNavList = await DB.find('nav', { "_id": DB.getObjectId(args._id)});var deleteResult = await DB.remove('nav', {"_id":DB.getObjectId(args._id)});// 用影响的行业来判断是否成功if(deleteResult.result.n){return oneNavList[0]; }else{return {}}}} }
})// 将定义的所有的根,挂载到GraphQLSchema上
module.exports = new GraphQLSchema({query: RootSchema,mutation:MutationSchema
})


推荐阅读
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • 本文详细介绍了Spring的JdbcTemplate的使用方法,包括执行存储过程、存储函数的call()方法,执行任何SQL语句的execute()方法,单个更新和批量更新的update()和batchUpdate()方法,以及单查和列表查询的query()和queryForXXX()方法。提供了经过测试的API供使用。 ... [详细]
  • 如何自行分析定位SAP BSP错误
    The“BSPtag”Imentionedintheblogtitlemeansforexamplethetagchtmlb:configCelleratorbelowwhichi ... [详细]
  • Spring源码解密之默认标签的解析方式分析
    本文分析了Spring源码解密中默认标签的解析方式。通过对命名空间的判断,区分默认命名空间和自定义命名空间,并采用不同的解析方式。其中,bean标签的解析最为复杂和重要。 ... [详细]
  • PHP图片截取方法及应用实例
    本文介绍了使用PHP动态切割JPEG图片的方法,并提供了应用实例,包括截取视频图、提取文章内容中的图片地址、裁切图片等问题。详细介绍了相关的PHP函数和参数的使用,以及图片切割的具体步骤。同时,还提供了一些注意事项和优化建议。通过本文的学习,读者可以掌握PHP图片截取的技巧,实现自己的需求。 ... [详细]
  • 向QTextEdit拖放文件的方法及实现步骤
    本文介绍了在使用QTextEdit时如何实现拖放文件的功能,包括相关的方法和实现步骤。通过重写dragEnterEvent和dropEvent函数,并结合QMimeData和QUrl等类,可以轻松实现向QTextEdit拖放文件的功能。详细的代码实现和说明可以参考本文提供的示例代码。 ... [详细]
  • 开发笔记:加密&json&StringIO模块&BytesIO模块
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了加密&json&StringIO模块&BytesIO模块相关的知识,希望对你有一定的参考价值。一、加密加密 ... [详细]
  • Java容器中的compareto方法排序原理解析
    本文从源码解析Java容器中的compareto方法的排序原理,讲解了在使用数组存储数据时的限制以及存储效率的问题。同时提到了Redis的五大数据结构和list、set等知识点,回忆了作者大学时代的Java学习经历。文章以作者做的思维导图作为目录,展示了整个讲解过程。 ... [详细]
  • JavaSE笔试题-接口、抽象类、多态等问题解答
    本文解答了JavaSE笔试题中关于接口、抽象类、多态等问题。包括Math类的取整数方法、接口是否可继承、抽象类是否可实现接口、抽象类是否可继承具体类、抽象类中是否可以有静态main方法等问题。同时介绍了面向对象的特征,以及Java中实现多态的机制。 ... [详细]
  • MyBatis多表查询与动态SQL使用
    本文介绍了MyBatis多表查询与动态SQL的使用方法,包括一对一查询和一对多查询。同时还介绍了动态SQL的使用,包括if标签、trim标签、where标签、set标签和foreach标签的用法。文章还提供了相关的配置信息和示例代码。 ... [详细]
  • Java学习笔记之使用反射+泛型构建通用DAO
    本文介绍了使用反射和泛型构建通用DAO的方法,通过减少代码冗余度来提高开发效率。通过示例说明了如何使用反射和泛型来实现对不同表的相同操作,从而避免重复编写相似的代码。该方法可以在Java学习中起到较大的帮助作用。 ... [详细]
  • android listview OnItemClickListener失效原因
    最近在做listview时发现OnItemClickListener失效的问题,经过查找发现是因为button的原因。不仅listitem中存在button会影响OnItemClickListener事件的失效,还会导致单击后listview每个item的背景改变,使得item中的所有有关焦点的事件都失效。本文给出了一个范例来说明这种情况,并提供了解决方法。 ... [详细]
  • 本文介绍了OC学习笔记中的@property和@synthesize,包括属性的定义和合成的使用方法。通过示例代码详细讲解了@property和@synthesize的作用和用法。 ... [详细]
  • 1,关于死锁的理解死锁,我们可以简单的理解为是两个线程同时使用同一资源,两个线程又得不到相应的资源而造成永无相互等待的情况。 2,模拟死锁背景介绍:我们创建一个朋友 ... [详细]
  • 本文详细介绍了Java中vector的使用方法和相关知识,包括vector类的功能、构造方法和使用注意事项。通过使用vector类,可以方便地实现动态数组的功能,并且可以随意插入不同类型的对象,进行查找、插入和删除操作。这篇文章对于需要频繁进行查找、插入和删除操作的情况下,使用vector类是一个很好的选择。 ... [详细]
author-avatar
蜗蜗家的逆时针
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有