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.