GraphQL - Şema

Bir GraphQL şeması, herhangi bir GraphQL sunucu uygulamasının merkezinde yer alır. Kendisine bağlanan istemci uygulamalarının kullanabileceği işlevselliği açıklar. Bir GraphQL şeması oluşturmak ve bunun etrafında bir arayüz oluşturmak için herhangi bir programlama dilini kullanabiliriz.

GraphQL çalışma zamanı, temsil ettiği veri hizmetinin yeteneklerini yayınlamak için genel bir grafik tabanlı şema tanımlar. İstemci uygulamaları, yetenekleri dahilinde şemayı sorgulayabilir. Bu yaklaşım, istemcileri sunuculardan ayırır ve her ikisinin de bağımsız olarak gelişmesine ve ölçeklenmesine izin verir.

Bu bölümde, GraphQL sorgularını yürütmek için Apollo sunucusunu kullanıyoruz. makeExecutableSchema graphql-tools içindeki fonksiyon, şema ve çözücüleri bağlamanıza yardımcı olur.

makeExecutableSchema İşlev Sözdizimi

makeExecutableSchemaişlev, Nesne türünde tek bir bağımsız değişken {} alır. Bu işlevi kullanmak için sözdizimi aşağıda verilmiştir -

import { makeExecutableSchema } from 'graphql-tools';

const jsSchema = makeExecutableSchema({
   typeDefs,
   resolvers, // optional
   logger, // optional
   allowUndefinedInResolve = false, // optional
   resolverValidationOptions = {}, // optional
   directiveResolvers = null, // optional
   schemaDirectives = null,  // optional
   parseOptions = {},  // optional
   inheritResolversFromInterfaces = false  // optional
});

Sr.No. Parametre ve Açıklama
1

typeDefs

Bu gerekli bir argümandır. Bir GraphQL sorgusunu UTF-8 dizesi olarak temsil eder.

2

Resolvers

Bu isteğe bağlı bir argümandır (varsayılan olarak boş nesnedir). Bu, sorguyu işleyen işlevlere sahiptir.

3

logger

Bu isteğe bağlı bir argümandır ve sunucu konsoluna hataları yazdırmak için kullanılabilir.

4

parseOptions

Bu isteğe bağlı bir argümandır ve typeDefs'i bir dizge olarak belirtirken ayrıştırmanın özelleştirilmesine izin verir.

5

allowUndefinedInResolve

Bu, varsayılan olarak doğrudur. Yanlış olarak ayarlandığında, çözümleme işlevlerinizin tanımsız döndürmeleri halinde hata vermesine neden olur.

6

resolverValidationOptions

Bu isteğe bağlı bir argümandır ve Boole özelliklerine sahip bir nesneyi kabul eder.

7

inheritResolversFromInterfaces

Bu, isteğe bağlı bir argümandır ve çözümleyicilerin nesne mirasını kontrol etmek için bir Boole argümanını kabul eder.

İllüstrasyon

Bu şemayı anlamak için basit bir uygulama oluşturalım. Bu, sunucudaki öğrencilerin listesini sorgulamak için bir şema oluşturacaktır. Öğrenci verileri düz bir dosyada saklanacak ve adında bir düğüm modülü kullanacağız.notarealdb bir veritabanını taklit etmek ve düz dosyadan okumak.

Adım 1 - Proje için Gerekli Bağımlılıkları İndirin ve Yükleyin

Adlı bir klasör oluşturun schema-app. Dizininizi terminalden schema-app olarak değiştirin. Ardından, indirme ve yükleme işlemini tamamlamak için Ortam Kurulumu bölümünde açıklanan 3 ila 5 arasındaki adımları izleyin.

Adım 2 - Şema Oluşturun

Ekle schema.graphql proje klasöründeki dosya, schema-app ve aşağıdaki kodu ekleyin -

type Query {
   greeting:String
   students:[Student]
}

type Student {
   id:ID!
   firstName:String
   lastName:String
   password:String
   collegeId:String
}

Şemanın kökü Sorgu türü olacaktır. Sorgunun iki alanı vardır: tebrik ve sırasıyla Dize döndüren Öğrenciler ve öğrencilerin listesi. Öğrenci, birden çok alan içerdiği için Nesne türü olarak ilan edilir. Kimlik alanı boş değer atanamaz olarak bildirildi.

Adım 3 - Çözücü Oluşturun

Bir dosya oluştur resolvers.js proje klasörüne ve aşağıdaki kodu ekleyin -

const db = require('./db')
const Query = {
   greeting:() => {
      return "hello from  TutorialsPoint !!!"
   },
   students:() => db.students.list()
}

module.exports = {Query}

Burada selamlama ve öğrenciler, sorguyu ele alan çözümleyicilerdir. students resolver functionveri erişim katmanındaki öğrencilerin bir listesini döndürür. Modül dışındaki çözümleyici işlevlerine erişmek için, Sorgu nesnesi kullanılarak dışa aktarılmalıdır.module.exports.

Adım 4 - Uygulamayı Çalıştırın

Bir server.js dosyası oluşturun ve Ortam Kurulumu Bölümündeki 8. adıma bakın. Bir sonraki adım, terminalde npm start komutunu çalıştırmaktır. Sunucu, 9000 portunda çalışır durumda olacaktır. Burada, uygulamayı test etmek için bir istemci olarak GraphiQL kullanıyoruz. Tarayıcıyı açın ve URL'yi yazın,http://localhost:9000/graphiql.

Düzenleyiciye aşağıdaki sorguyu yazın -

{
   greeting
   students {
      id
      firstName
      lastName
   }
}

Sorgu, çıktıyı aşağıda gösterildiği gibi gösterecektir -

Note- Öğrencilerin verilerini ve hatta MySQL veya MongoDB gibi gerçek bir veritabanını almak için student.json'u RESTful API çağrısıyla değiştirebiliriz. GraphQL, performansı artırmak için orijinal uygulama katmanınızın etrafında ince bir paket haline gelir.