apollo/server express,mongoose,resolver chains

2024-04-30 18:44

本文主要是介绍apollo/server express,mongoose,resolver chains,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

apollo/server Get started with Apollo Server - Apollo GraphQL Docs

mongoose Mongoose 5.0 中文文档

index2.ts

import { ApolloServer } from '@apollo/server';
import { expressMiddleware } from '@apollo/server/express4';
import { ApolloServerPluginDrainHttpServer } from '@apollo/server/plugin/drainHttpServer';
import express from 'express';
import http from 'http';
import cors from 'cors';
import { typeDefs, resolvers } from './index2-schema';
import { users } from "./index2-mongoose";const app = express();const httpServer = http.createServer(app);const server = new ApolloServer<{ token?: String }>({typeDefs,resolvers,plugins: [ApolloServerPluginDrainHttpServer({ httpServer })],
});server.start().then(() => {app.use('/graphql',cors<cors.CorsRequest>(),express.json(),expressMiddleware(server, {context: async ({ req }) => ({token: req.headers.token,msg: "会传递到所有的resolver context参数中",dataSources: { users }}),}),);httpServer.listen(4000, () => {console.log(`🚀 Server ready at http://localhost:4000/graphql`);});
});

index2-schema.ts

import { users } from "./index2-mongoose";export let typeDefs = `#graphql#1type Event {name: String!date: String!location: Location}type Location {name: String!weather: WeatherInfo}type WeatherInfo {temperature: Floatdescription: String}#2type Library {branch: String!books: [Book]}type Book {title: Stringauthor: Author}type Author {name: String!}#3type User{_id: ID!name: String!age: Int!sex: String!}type Query {books: [Book]users: [User]user(id: ID!): UserupcomingEvents: [Event!]!libraries: [Library]Library: Library}
`;export const resolvers = {Query: {books() {return [{ id: '1', title: "t1", },{ id: '2', title: "t2", },]},async users(parent: any, args: any, context: { dataSources: { users: { find: () => any; }; }; }) {let value = await users.find();console.log(await context.dataSources.users.find());return value;},async user(parent: any, { id }: any, context: { dataSources: { users: { findById: (arg0: any) => any; }; }; }) {console.log(await context.dataSources.users.findById(id));const user = await users.findById(id)return user;},upcomingEvents() {return [{name: "01",date: "2024-1-1",location: {name: "sunday",weather: {temperature: 18.5,description: 'cold'}}}];},libraries() {return [{ id: "1", branch: 'downtown' },{ id: "2", branch: 'riverside' },];}},Library: {books(parent: any) {// parent上一步libraries解析的结果console.log('books parent =', parent);let books = [{ id: '1', belongto: "1", title: "t1", },{ id: '2', belongto: "1", title: "t2", },{ id: '3', belongto: "1", title: "t2", },{ id: '4', belongto: "2", title: "t2", },{ id: '5', belongto: "2", title: "t2", },]return books.filter(item => item.belongto === parent.id);}},Book: {author(parent: any, args: any, context: any, info: any) {// 上一步books的解析结果console.log(parent);console.log(context);let authors = [{ id: '1', bid: '1', name: "Tom" },{ id: '2', bid: '2', name: "Sam" },{ id: '3', bid: '3', name: "Jack" },{ id: '4', bid: '4', name: "Lucy" },{ id: '5', bid: '5', name: "David" },]return authors.find(item => item.bid === parent.id);}}
};/*
// 查询案例
query ExampleQuery {books {titleauthor{name}}user(id: "63ca47df3dd42947e4cc021b") {_idnameage}upcomingEvents{name}libraries {branchbooks{titleauthor {name}}}
}
*/

index2-mongoose.ts 

import mongoose, { Mongoose } from 'mongoose';mongoose.set("strictQuery", true);mongoose.connect('mongodb://localhost:27017/test');export var db = mongoose.connection;db.on('error', console.error.bind(console, 'connection error:'));db.once('open', function () {console.log('mongodb connection success!');
});function UserModel(mongoose: Mongoose) {let user = new mongoose.Schema({name: { type: String, required: true },password: { type: String, required: true },age: { type: Number, require: true },sex: { type: String, require: true },phone: { type: String, require: true },email: { type: String, required: true },image: { type: String, default: null },myChannel: { type: String, default: null },describle: { type: String, default: null },subscribeCount: { type: Number, default: 0 },});return mongoose.model("User", user);
}export const users = UserModel(mongoose);

这篇关于apollo/server express,mongoose,resolver chains的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/949636

相关文章

python连接本地SQL server详细图文教程

《python连接本地SQLserver详细图文教程》在数据分析领域,经常需要从数据库中获取数据进行分析和处理,下面:本文主要介绍python连接本地SQLserver的相关资料,文中通过代码... 目录一.设置本地账号1.新建用户2.开启双重验证3,开启TCP/IP本地服务二js.python连接实例1.

mysql出现ERROR 2003 (HY000): Can‘t connect to MySQL server on ‘localhost‘ (10061)的解决方法

《mysql出现ERROR2003(HY000):Can‘tconnecttoMySQLserveron‘localhost‘(10061)的解决方法》本文主要介绍了mysql出现... 目录前言:第一步:第二步:第三步:总结:前言:当你想通过命令窗口想打开mysql时候发现提http://www.cpp

SQL Server清除日志文件ERRORLOG和删除tempdb.mdf

《SQLServer清除日志文件ERRORLOG和删除tempdb.mdf》数据库再使用一段时间后,日志文件会增大,特别是在磁盘容量不足的情况下,更是需要缩减,以下为缩减方法:如果可以停止SQLSe... 目录缩减 ERRORLOG 文件(停止服务后)停止 SQL Server 服务:找到错误日志文件:删除

Windows Server服务器上配置FileZilla后,FTP连接不上?

《WindowsServer服务器上配置FileZilla后,FTP连接不上?》WindowsServer服务器上配置FileZilla后,FTP连接错误和操作超时的问题,应该如何解决?首先,通过... 目录在Windohttp://www.chinasem.cnws防火墙开启的情况下,遇到的错误如下:无法与

一文详解SQL Server如何跟踪自动统计信息更新

《一文详解SQLServer如何跟踪自动统计信息更新》SQLServer数据库中,我们都清楚统计信息对于优化器来说非常重要,所以本文就来和大家简单聊一聊SQLServer如何跟踪自动统计信息更新吧... SQL Server数据库中,我们都清楚统计信息对于优化器来说非常重要。一般情况下,我们会开启"自动更新

JAVA虚拟机中 -D, -X, -XX ,-server参数使用

《JAVA虚拟机中-D,-X,-XX,-server参数使用》本文主要介绍了JAVA虚拟机中-D,-X,-XX,-server参数使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有... 目录一、-D参数二、-X参数三、-XX参数总结:在Java开发过程中,对Java虚拟机(JVM)的启动参数进

Windows server服务器使用blat命令行发送邮件

《Windowsserver服务器使用blat命令行发送邮件》在linux平台的命令行下可以使用mail命令来发送邮件,windows平台没有内置的命令,但可以使用开源的blat,其官方主页为ht... 目录下载blatBAT命令行示例备注总结在linux平台的命令行下可以使用mail命令来发送邮件,Win

MySQL 中的服务器配置和状态详解(MySQL Server Configuration and Status)

《MySQL中的服务器配置和状态详解(MySQLServerConfigurationandStatus)》MySQL服务器配置和状态设置包括服务器选项、系统变量和状态变量三个方面,可以通过... 目录mysql 之服务器配置和状态1 MySQL 架构和性能优化1.1 服务器配置和状态1.1.1 服务器选项

查询SQL Server数据库服务器IP地址的多种有效方法

《查询SQLServer数据库服务器IP地址的多种有效方法》作为数据库管理员或开发人员,了解如何查询SQLServer数据库服务器的IP地址是一项重要技能,本文将介绍几种简单而有效的方法,帮助你轻松... 目录使用T-SQL查询方法1:使用系统函数方法2:使用系统视图使用SQL Server Configu

SQL Server数据库迁移到MySQL的完整指南

《SQLServer数据库迁移到MySQL的完整指南》在企业应用开发中,数据库迁移是一个常见的需求,随着业务的发展,企业可能会从SQLServer转向MySQL,原因可能是成本、性能、跨平台兼容性等... 目录一、迁移前的准备工作1.1 确定迁移范围1.2 评估兼容性1.3 备份数据二、迁移工具的选择2.1