2. GraphQL의 기본 타입들
- 지난 실습 그대로 진행 또는 3-2-types 열기
스칼라 타입
- GraphQL 내장 자료형
type EquipmentAdv {
id: ID!
used_by: String!
count: Int!
use_rate: Float
is_new: Boolean!
}
타입 | 설명 |
---|---|
ID | 기본적으로는 String이나, 고유 식별자 역할임을 나타냄 |
String | UTF-8 문자열 |
Int | 부호가 있는 32비트 정수 |
Float | 부호가 있는 부동소수점 값 |
Boolean | 참/거짓 |
⭐ ! : Non Null
- null을 반환할 수 없음
equipments.js
const resolvers = {
Query: {
// ...
equipmentAdvs: (parent, args) => dbWorks.getEquipments(args)
.map((equipment) => {
if (equipment.used_by === 'developer') {
equipment.use_rate = Math.random().toFixed(2)
}
equipment.is_new = equipment.new_or_used === 'new'
return equipment
}),
},
// ...
}
_queries.js
type Query {
...
equipmentAdvs: [EquipmentAdv]
...
}
query {
equipmentAdvs {
id
used_by
count
use_rate
is_new
}
}
열거 타입
- 미리 지정된 값들 중에서만 반환
_enums.js
const { gql } = require('apollo-server')
const typeDefs = gql`
enum Role {
developer
designer
planner
}
enum NewOrUsed {
new
used
}
`
module.exports = typeDefs
index.js
// ...
const enums = require('./typedefs-resolvers/_enums')
// ...
const typeDefs = [
// ...
enums,
// ...
]
equipments.js
const typeDefs = gql`
type Equipment {
id: ID!
used_by: Role!
count: Int!
new_or_used: NewOrUsed!
}
type EquipmentAdv {
id: ID!
used_by: Role!
count: Int!
use_rate: Float
is_new: Boolean!
}
`
query {
equipments {
id
used_by
count
new_or_used
}
equipmentAdvs {
id
used_by
count
use_rate
is_new
}
}
리스트 타입
- 특정 타입의 배열을 반환
equipments.js
const typeDefs = gql`
// ...
type EquipmentAdv {
id: ID!
used_by: Role!
count: Int!
use_rate: Float
is_new: Boolean!,
users: [String!]
}
`
// ...
const resolvers = {
Query: {
// ...
equipmentAdvs: (parent, args) => dbWorks.getEquipments(args)
.map((equipment) => {
if (equipment.used_by === 'developer') {
equipment.use_rate = Math.random().toFixed(2)
}
equipment.is_new = equipment.new_or_used === 'new'
if (Math.random() > 0.5) {
equipment.users = []
dbWorks.getPeople(args).forEach((person) => {
if (person.role === equipment.used_by && Math.random() < 0.2) {
equipment.users.push(person.last_name)
}
})
}
return equipment
}),
},
// ...
}
query {
equipmentAdvs {
id
used_by
count
use_rate
is_new
users
}
}
선언부 | users: null | users: [ ] | users: [..., null] |
---|---|---|---|
[String] | ✔ | ✔ | ✔ |
[String!] | ✔ | ✔ | ❌ |
[String]! | ❌ | ✔ | ✔ |
[String!]! | ❌ | ✔ | ❌ |
객체 타입
- 사용자에 의해 정의된 타입들