GraphQL - Mutasi
Pada bab ini, kita akan mempelajari kueri mutasi di GraphQL.
Kueri mutasi mengubah data di penyimpanan data dan mengembalikan nilai. Ini dapat digunakan untuk memasukkan, memperbarui, atau menghapus data. Mutasi didefinisikan sebagai bagian dari skema.
Sintaks kueri mutasi diberikan di bawah ini -
mutation{
someEditOperation(dataField:"valueOfField"):returnType
}
Ilustrasi
Mari kita memahami cara menambahkan catatan siswa baru ke dalam datastore menggunakan kueri mutasi.
Langkah 1 - Unduh dan Instal Dependensi yang Diperlukan untuk Proyek
Buat folder proyek dengan nama mutation-app. Ubah direktori Anda menjadi aplikasi mutasi dari terminal. Ikuti langkah 3 hingga 5 yang dijelaskan di bab Pengaturan Lingkungan.
Langkah 2 - Buat File schema.graphql
Menambahkan schema.graphql file dalam aplikasi mutasi folder proyek dan tambahkan kode berikut -
type Query {
greeting:String
}
type Mutation {
createStudent(collegeId:ID,firstName:String,lastName:String):String
}
Perhatikan bahwa fungsi createStudent mengembalikan tipe String. Ini adalah pengenal unik (ID) yang dihasilkan setelah membuat siswa.
Langkah 3 - Buat File resolver.js
Buat file resolvers.js di folder proyek dan tambahkan kode berikut -
const db = require('./db')
const Mutation = {
createStudent:(root,args,context,info) => {
return db.students.create({collegeId:args.collegeId,
firstName:args.firstName,
lastName:args.lastName})
}
}
const Query = {
greeting:() => "hello"
}
module.exports = {Query,Mutation}
Fungsi mutasi menunjuk ke koleksi siswa di datastore. Untuk menambahkan siswa baru , panggil metode buat di koleksi siswa. The args objek akan berisi parameter yang dilewatkan dalam query. Metode buat koleksi siswa akan mengembalikan id dari objek siswa yang baru dibuat.
Langkah 4 - Jalankan Aplikasi
Membuat server.jsmengajukan. Lihat langkah 8 di Bab Pengaturan Lingkungan. Jalankan perintah npm start di terminal. Server akan aktif dan berjalan pada 9000 port. Di sini, kami menggunakan GraphiQL sebagai klien untuk menguji aplikasi.
Langkah selanjutnya adalah membuka browser dan mengetik URL http://localhost:9000/graphiql. Ketik kueri berikut di editor -
//college Id should be matched with data from colleges.json for easy retrieval
mutation {
createStudent(collegeId:"col-2",firstName:"Tim",lastName:"George")
}
Kueri di atas akan membuat objek siswa di file student.json. Kueri akan mengembalikan pengenal unik. Respon dari query tersebut seperti yang ditunjukkan di bawah ini -
{
"data": {
"createStudent": "SkQtxYBUm"
}
}
Untuk memverifikasi jika objek siswa dibuat, kita dapat menggunakan kueri studentById. Anda juga dapat membuka file students.json dari folder data untuk memverifikasi id.
Untuk menggunakan kueri studentById, edit schema.graphql seperti yang diberikan di bawah ini -
type Query {
studentById(id:ID!):Student
}
type Student {
id:ID!
firstName:String
lastName:String
collegeId:String
}
Edit resolver.js file seperti yang diberikan di bawah ini -
const db = require('./db')
const Query = {
studentById:(root,args,context,info) => {
return db.students.get(args.id);
}
}
const Mutation = {
createStudent:(root,args,context,info) => {
return db.students.create({collegeId:args.collegeId,
firstName:args.firstName,
lastName:args.lastName})
}
}
module.exports = {Query,Mutation}
Diberikan di bawah ini adalah kueri untuk mendapatkan siswa dengan id unik yang dikembalikan dari kueri mutasi -
{
studentById(id:"SkQtxYBUm") {
id
firstName
lastName
}
}
Tanggapan dari server adalah sebagai berikut -
{
"data": {
"studentById": {
"id": "SkQtxYBUm",
"firstName": "Tim",
"lastName":"George"
}
}
}
Mengembalikan Objek dalam Mutasi
Merupakan praktik terbaik untuk mengembalikan objek dalam mutasi. Misalnya, aplikasi klien ingin mengambil detail siswa dan perguruan tinggi. Dalam kasus ini, daripada membuat dua permintaan berbeda, kita bisa membuat kueri yang mengembalikan objek yang berisi siswa dan detail perguruan tinggi mereka.
Langkah 1 - Edit File Skema
Tambahkan metode baru bernama addStudent yang mengembalikan objek dalam tipe mutasi schema.graphql.
Mari kita pelajari cara mengakses detail perguruan tinggi melalui detail siswa. Tambahkan jenis perguruan tinggi di file skema.
type Mutation {
addStudent_returns_object(collegeId:ID,firstName:String,lastName:String):Student
createStudent(collegeId:ID,firstName:String,lastName:String):String
}
type College {
id:ID!
name:String
location:String
rating:Float
}
type Student {
id:ID!
firstName:String
lastName:String
college:College
}
Langkah 2 - Perbarui File resolvers.js
Perbarui file resolvers.js di folder proyek dan tambahkan kode berikut -
const Mutation = {
createStudent:(root,args,context,info) => {
return db.students.create({
collegeId:args.collegeId,
firstName:args.firstName,
lastName:args.lastName
})
},
// new resolver function
addStudent_returns_object:(root,args,context,info) => {
const id = db.students.create({
collegeId:args.collegeId,
firstName:args.firstName,
lastName:args.lastName
})
return db.students.get(id)
}
}
//for each single student object returned,resolver is invoked
const Student = {
college:(root) => {
return db.colleges.get(root.collegeId);
}
}
module.exports = {Query,Student,Mutation}
Langkah 3 - Mulai Server dan Ketik Permintaan Permintaan di GraphiQL
Selanjutnya, kita akan memulai server dan meminta query di GraphiQL dengan kode berikut -
mutation {
addStudent_returns_object(collegeId:"col-101",firstName:"Susan",lastName:"George") {
id
firstName
college{
id
name
}
}
}
Kueri di atas menambahkan siswa baru dan mengambil objek siswa bersama dengan objek perguruan tinggi. Ini menghemat perjalanan bolak-balik ke server.
Tanggapannya seperti yang diberikan di bawah ini -
{
"data": {
"addStudent_returns_object": {
"id": "rklUl08IX",
"firstName": "Susan",
"college": {
"id": "col-101",
"name": "AMU"
}
}
}
}