WordPress verilerini sorgula
WordPress verilerini sorgulaMeta Değerleri

Meta Değerleri

Daha fazla bilgi için Meta Değerleriyle Çalışmak rehberine bakın.

Bunlar meta verileri çekmek ve sonuçları meta'ya göre filtrelemek için queries örnekleridir.

Meta sorgulama

Postlardan tek meta değeri _thumbnail_id çekme:

{
  posts {
    id
    title
    metaValue(key: "_thumbnail_id")
  }
}

Yorumlardan dizi meta değeri upvotes çekme:

{
  comments {
    id
    content
    upvotes: metaValues(key: "upvotes")
  }
}

Meta'ya göre filtreleme

_thumbnail_id meta anahtarının mevcut olduğu postları filtreleme:

{
  posts(filter: {
    metaQuery: {
      key: "_thumbnail_id",
      compareBy:{
        key: {
          operator: EXISTS
        }
      }
    }
  }) {
    id
    title
    metaValue(key: "_thumbnail_id")
  }
}

nickname meta girişinin belirli bir değere sahip olduğu kullanıcıları filtreleme:

{
  users(filter: {
    metaQuery: {
      key: "nickname",
      compareBy:{
        stringValue: {
          value: "leo"
          operator: EQUALS
        }
      }
    }
  }) {
    id
    name
    metaValue(key: "nickname")
  }
}

upvotes meta girişinin (tamsayı dizisi) 4 veya 5 değerlerinden birine sahip olduğu yorumları filtreleme:

{
  comments(filter: {
    metaQuery: [
      {
        relation: OR
        key: "upvotes",
        compareBy: {
          arrayValue: {
            value: 4
            operator: IN
          }
        }
      },
      {
        key: "upvotes",
        compareBy: {
          arrayValue: {
            value: 5
            operator: IN
          }
        }
      }
  ]}) {
    id
    content
    upvotes: metaValues(key: "upvotes")
  }
}

Meta ekleme

Custom postlara, taglara, kategorilere, yorumlara ve kullanıcılara meta girişleri ekleyebilirsiniz.

Bu query, ID'si 4 olan posta bir meta girişi ekler:

mutation {
  addCustomPostMeta(input: {
    id: 4
    key: "some_key"
    value: "Some value"
  }) {
    status
    errors {
      __typename
      ...on ErrorPayload {
        message
      }
    }
    customPost {
      id
      metaValue(key: "some_key") 
    }
  }
}

Bu query, aynı meta anahtarını farklı değerlerle farklı postlara toplu olarak ekler:

mutation {
  addCustomPostMetas(inputs: [
    {
      id: 4
      key: "some_key"
      value: "Some value"
    },
    {
      id: 5
      key: "some_key"
      value: "Some other value"
    },
    {
      id: 6
      key: "some_key"
      value: "Yet another value"
    }
  ]) {
    status
    errors {
      __typename
      ...on ErrorPayload {
        message
      }
    }
    customPost {
      id
      metaValue(key: "some_key") 
    }
  }
}

Meta güncelleme

Bir kategori meta girişini güncelleme:

mutation {
  updateCategoryMeta(input: {
    id: 20
    key: "_source"
    value: "Updated source value"
  }) {
    status
    errors {
      __typename
      ...on ErrorPayload {
        message
      }
    }
    category {
      __typename
      id
      metaValue(key: "_source") 
    }
  }
}

Bu query, bir posttaki meta değerini güncellemek için iç içe mutation kullanır:

mutation {
  post(by: {id: 1}) {
    updateMeta(input: {
      key: "some_key"
      value: "Updated description"
    }) {
      status
      errors {
        __typename
        ...on ErrorPayload {
          message
        }
      }
      post {
        id
        metaValue(key: "single_meta_key") 
      }
    }
  }
}

Meta silme

Bir posttaki meta girişini silme:

mutation {
  deletePostMeta(input: {
    id: 5
    key: "some_key"
  }) {
    status
    errors {
      __typename
      ...on ErrorPayload {
        message
      }
    }
    post {
      id
      metaValue(key: "some_key") 
    }
  }
}

Aynı meta girişini birden fazla postten silme:

mutation {
  deletePostMetas(inputs: [
    {
      id: 5
      key: "some_key"
    },
    {
      id: 6
      key: "some_key"
    }
  ]) {
    status
    errors {
      __typename
      ...on ErrorPayload {
        message
      }
    }
    post {
      id
      metaValue(key: "some_key") 
    }
  }
}

Birden fazla meta girişini aynı anda ayarlama

Farklı set{Entity}Meta mutation'larına JSON geçirerek birden fazla meta girişini aynı anda ayarlayabilirsiniz:

mutation {
  setCustomPostMeta(input: {
    id: 4
    entries: {
      single_meta_key: [
        "This is a single entry",
      ],
      object_meta_key: [
        {
          key: "This is a key",
          value: "This is a value",
        },
      ],
      array_meta_key: [
        "This is a string",
        "This is another string",
      ],
      object_array_meta_key: [
        [
          {
            key: "This is a key 1",
            value: "This is a value 1",
          },
          {
            key: "This is a key 2",
            value: "This is a value 2",
          },
        ]
      ],
    }
  }) {
    status
    errors {
      __typename
      ...on ErrorPayload {
        message
      }
    }
    customPost {
      id
      meta(keys: ["single_meta_key", "object_meta_key", "array_meta_key", "object_array_meta_key"])
    }
  }
}

Bir varlık oluşturulurken/güncellenirken meta girişleri ayarlama

meta parametresi aracılığıyla bir custom post, tag, kategori veya yorum oluşturulurken ya da güncellenirken meta girişlerini doğrudan tanımlayabilirsiniz.

Bu query, bir yorum eklenirken meta ayarlar:

mutation {
  addCommentToCustomPost(input: {
    customPostID: 1130
    commentAs: { html: "New comment" }
    meta: {
      some_meta_key: [
        "This is a single entry",
      ],
      another_meta_key: [
        "This is an array entry 1",
        "This is an array entry 2",
      ],
    }
  }) {
    status
    errors {
      __typename
      ...on ErrorPayload {
        message
      }
    }
    comment {
      id
      meta(keys: ["some_meta_key", "another_meta_key"]) 
    }
  }
}

Bu query, meta'yı iç içe Post.update mutation'ına enjekte eder:

mutation {
  post(by: {id: 1}) {
    update(input: {
      meta: {
        single_meta_key: [
          "This is an updated value",
        ]
      }
    }) {
      status
      errors {
        __typename
        ...on ErrorPayload {
          message
        }
      }
      post {
        id
        metaValue(key: "single_meta_key") 
      }
    }
  }
}