特定のフィールドを返す

必要なフィールドを正確に返してパフォーマンスを向上させるには、メソッド呼び出しで fields システム パラメータを使用します。

fields パラメータは、レスポンスのフィルタリングに FieldMask を使用します。フィールド マスクは、リクエストで返されるフィールドのサブセットを指定するために使用されます。フィールド マスクを使用することは、不要なデータをリクエストしないようにするための優れた設計手法です。これにより、不要な処理時間を回避できます。

デフォルトでは、サーバーはクエリ対象のリソースに固有のフィールドのセットを返します。たとえば、files リソースの get() メソッドは、idnamemimeType のみを返す場合があります。permissions リソースの get() メソッドは、異なるデフォルト フィールドのセットを返します。

サーバーは、fields パラメータを含む有効なリクエストを処理した後、HTTP 200 OK ステータス コードとリクエストされたデータを返します。fields パラメータにエラーがある場合、またはパラメータが無効な場合、サーバーは HTTP 400 Bad Request ステータス コードと、フィールド選択の問題箇所を示すエラー メッセージを返します。たとえば、files.list(fields='files(id,capabilities,canAddChildren)') は「無効なフィールド選択 canAddChildren」というエラーになります。この例の正しい fields パラメータは files.list(fields='files(id,capabilities/canAddChildren)') です。

fields パラメータを使用して返すことができるフィールドを確認するには、クエリを実行するリソースのドキュメント ページをご覧ください。たとえば、ファイルに対して返すことができるフィールドを確認するには、files リソースのドキュメントをご覧ください。

フィールド パラメータの形式ルール

fields リクエスト パラメータの形式は、XPath の構文に基づいています。fields パラメータの形式設定ルールは次のとおりです。これらのルールはすべて、files.get() メソッドに関連する例を使用しています。

  • 複数のフィールドを選択する場合は、カンマ区切りのリストを使用します(例: 'name, mimeType')。

  • a/b を使用して、フィールド a 内にネストされているフィールド b を選択します('capabilities/canDownload' など)。詳細については、ネストされたリソースのフィールドを取得するをご覧ください。

  • サブセレクタを使用して配列またはオブジェクトの特定のサブフィールドのセットをリクエストするには、式をかっこ「()」で囲みます。たとえば、'permissions(id)' は、permissions 配列内の各要素の権限 ID のみを返します。

  • オブジェクト内のすべてのフィールドを返すには、フィールド選択でアスタリスク(*)をワイルドカードとして使用します。たとえば、'permissions/permissionDetails/*' は、権限ごとに使用可能な権限の詳細フィールドをすべて選択します。なお、ワイルドカードを使用すると、リクエストのパフォーマンスに悪影響を及ぼす可能性があります。

例を表示

リクエスト

この例では、ファイル ID パス パラメータと複数のフィールドをリクエストのクエリ パラメータとして指定します。レスポンスには、ファイル ID のフィールド値が返されます。

GET https://www.googleapis.com/drive/v3/files/FILE_ID?fields=name,starred,shared

レスポンス

{
  "name": "File1",
  "starred": false,
  "shared": true
  }
}

ネストされたリソースのフィールドを取得する

フィールドが別のリソースを参照している場合は、ネストされたリソースのどのフィールドをフェッチするかを指定できます。

たとえば、permissions リソースの role フィールド(ネストされたリソース)を取得するには、次のいずれかのオプションを使用します。

  • permissions.get(): fields=role
  • permissions.get()fields=* に置き換えて、すべての permissions フィールドを表示します。
  • files.get()fields=permissions(role) または fields=permissions/role に置き換えます。
  • files.get()fields=permissions に置き換えて、すべての permissions フィールドを表示します。
  • changes.list(): fields=changes(file(permissions(role)))

複数のフィールドを取得するには、カンマ区切りのリストを使用します。たとえば、files.list()fields=files(id,name,createdTime,modifiedTime,size) に置き換えます。

例を表示

リクエスト

この例では、ファイル ID パス パラメータと、ネストされた権限リソースの一部のフィールドを含む複数のフィールドを、リクエストのクエリ パラメータとして指定します。レスポンスには、ファイル ID のフィールド値が返されます。

GET https://www.googleapis.com/drive/v3/files/FILE_ID?fields=name,starred,shared,permissions(kind,type,role)

レスポンス

{
  "name": "File1",
  "starred": false,
  "shared": true,
  "permissions": [
    {
      "kind": "drive#permission",
      "type": "user",
      "role": "owner"
    }
  ]
}