ODBC Driver for Couchbase

Build 24.0.9060

Vertical Flattening

Example Document


/* Primary key "1" */
{
  "address" : {
    "building" : "1007",
    "coord" : [-73.856077, 40.848447],
    "street" : "Morris Park Ave",
    "zipcode" : "10462"
  },
  "borough" : "Bronx",
  "cuisine" : "Bakery",
  "grades" : [{
      "date" : "2014-03-03T00:00:00Z",
      "grade" : "A",
      "score" : 2
    }, {
      "date" : "2013-09-11T00:00:00Z",
      "grade" : "A",
      "score" : 6
    }, {
      "date" : "2013-01-24T00:00:00Z",
      "grade" : "A",
      "score" : 10
    }, {
      "date" : "2011-11-23T00:00:00Z",
      "grade" : "A",
      "score" : 9
    }, {
      "date" : "2011-03-10T00:00:00Z",
      "grade" : "B",
      "score" : 14
    }],
  "name" : "Morris Park Bake Shop",
  "restaurant_id" : "30075445"
}

Selecting Values In Objects

If the FlattenObjects property is configured to allow object flattening, then the driver will traverse objects and map the fields inside them as columns. For example, this query:
SELECT [address.building], [address.street] FROM restaurants
Would return this resultset:

address.building addres.street
1007 Morris Park Ave

Selecting Values In Arrays

If the FlattenArrays property is configured to allow array flattening, then the driver will traverse arrays and map their individual values as columns. For example, if Flatten Arrays were set to "2", then this query:
SELECT [address.coord.0], [address.coord.1] FROM restaurants
Would return this resultset:

address.coord.0 address.coord.1
-73.856077 40.838447

Note that array flattening should only be used in cases where you know the number of array items in advance, such as with "address.coord" which will always contain two items. For arrays like "grades" which can contain arbitrary numbers of items, consider using the child tables described in Automatic Schema Discovery instead, since they will allow you to read all of the values within the array.

Copyright (c) 2024 CData Software, Inc. - All rights reserved.
Build 24.0.9060