> ## Documentation Index
> Fetch the complete documentation index at: https://developers.hubspot.es/docs/llms.txt
> Use this file to discover all available pages before exploring further.

# Get rows from draft table

> Devuelve filas de la versión en borrador de la tabla especificada. Los resultados de las filas se pueden filtrar y ordenar. Las opciones para filtrar y ordenar se enviarán como parámetros de consulta a la solicitud de la API. Por ejemplo, al agregar los parámetros de consulta "column1__gt=5&sort=-column1", la API devuelve las filas con valores de la columna "column1" mayores que 5 y en el orden descendente de los valores de "column1". Consulta la [sección de resumen](https://developers.hubspot.com/docs/api/cms/hubdb#filtering-and-sorting-table-rows) para obtener información detallada acerca de las opciones para filtrar y ordenar.

export const ScopesList = ({scopes = [], description = "Esta API requiere uno de los siguientes ámbitos:"}) => {
  if (!scopes || scopes.length === 0) {
    return null;
  }
  const sortedScopes = scopes.sort((a, b) => a.localeCompare(b));
  return <div>
      <div className="text-sm mb-2">{description}</div>
      <div>
        {sortedScopes.map((scope, index) => <div key={index}>
            <code>
              <span className="text-xs">{scope}</span>
            </code>
          </div>)}
      </div>
    </div>;
};

export const SupportedProducts = ({marketing, sales, service, cms, marketingLevel, salesLevel, serviceLevel, cmsLevel}) => {
  const translations = {
    header: "Productos compatibles",
    description: "Se requiere uno de los siguientes productos o productos de ediciones superiores.",
    productNames: {
      marketing: "Marketing Hub",
      sales: "Sales Hub",
      service: "Service Hub",
      cms: "Content Hub"
    },
    tiers: {
      free: "Gratuito",
      starter: "Starter",
      professional: "Pro",
      enterprise: "Enterprise"
    }
  };
  const translateTier = tier => {
    if (!tier) return '';
    const lowerTier = tier.toLowerCase();
    return translations.tiers[lowerTier] || tier;
  };
  const products = [{
    name: marketing ? translations.productNames.marketing : '',
    level: translateTier(marketingLevel),
    icon: "https://mintlify-assets.b-cdn.net/Icons/marketing-bolt.svg",
    alt: "Marketing Hub"
  }, {
    name: sales ? translations.productNames.sales : '',
    level: translateTier(salesLevel),
    icon: "https://mintlify-assets.b-cdn.net/Icons/sales-star.svg",
    alt: "Sales Hub"
  }, {
    name: service ? translations.productNames.service : '',
    level: translateTier(serviceLevel),
    icon: "https://mintlify-assets.b-cdn.net/Icons/service-heart.svg",
    alt: "Service Hub"
  }, {
    name: cms ? translations.productNames.cms : '',
    level: translateTier(cmsLevel),
    icon: "https://mintlify-assets.b-cdn.net/Icons/content-play.svg",
    alt: "Content Hub"
  }].filter(product => product.name && product.level);
  if (products.length === 0) return null;
  return <div>
      <div className="text-sm mb-2">{translations.description}</div>
      <div className={`grid ${products.length === 1 ? 'grid-cols-1' : 'grid-cols-2'} gap-1.5`}>
        {products.map((product, index) => <div key={index} style={{
    display: 'flex',
    alignItems: 'center'
  }}>
            <img src={product.icon} alt={product.alt} className="w-3.5 h-3.5 mr-1.5 mt-2.5 mb-2.5 flex-shrink-0 align-middle" />
            <span className="font-medium mr-1 text-sm">{product.name} -</span>
            <span className="text-sm">{product.level}</span>
          </div>)}
      </div>
    </div>;
};

<AccordionGroup>
  <Accordion title="Supported products" defaultOpen="true" icon="cubes">
    <SupportedProducts marketing={true} sales={true} service={true} cms={true} marketingLevel="PROFESSIONAL" salesLevel="FREE" serviceLevel="FREE" cmsLevel="PROFESSIONAL" />
  </Accordion>

  <Accordion title="Required Scopes" icon="key">
    <ScopesList
      scopes={[
  'hubdb'
]}
    />
  </Accordion>
</AccordionGroup>


## OpenAPI

````yaml specs/2026-03/cms-hubdb-v2026-03.json GET /cms/hubdb/2026-03/tables/{tableIdOrName}/rows/draft
openapi: 3.0.1
info:
  title: Hubdb
  description: Basepom for all HubSpot Projects
  version: 2026-03
  x-hubspot-product-tier-requirements:
    marketing: PROFESSIONAL
    sales: FREE
    service: FREE
    cms: PROFESSIONAL
    commerce: FREE
    crmHub: FREE
    dataHub: FREE
servers:
  - url: https://api.hubapi.com
security: []
tags:
  - name: Filas
  - name: Rows
  - name: Tablas
  - name: Tables
paths:
  /cms/hubdb/2026-03/tables/{tableIdOrName}/rows/draft:
    get:
      tags:
        - Tablas
        - Tables
      summary: Obtener filas de tabla de borrador
      description: >-
        Devuelve filas de la versión en borrador de la tabla especificada. Los
        resultados de las filas se pueden filtrar y ordenar. Las opciones para
        filtrar y ordenar se enviarán como parámetros de consulta a la solicitud
        de la API. Por ejemplo, al agregar los parámetros de consulta
        "column1__gt=5&sort=-column1", la API devuelve las filas con valores de
        la columna "column1" mayores que 5 y en el orden descendente de los
        valores de "column1". Consulta la [sección de
        resumen](https://developers.hubspot.com/docs/api/cms/hubdb#filtering-and-sorting-table-rows)
        para obtener información detallada acerca de las opciones para filtrar y
        ordenar.
      operationId: >-
        get-/cms/hubdb/2026-03/tables/{tableIdOrName}/rows/draft_readDraftTableRows
      parameters:
        - name: tableIdOrName
          in: path
          description: El ID o nombre de la tabla que se consultará.
          required: true
          style: simple
          explode: false
          schema:
            type: string
        - name: after
          in: query
          description: >-
            El token del cursor de paginación del último recurso leído con éxito
            se devolverá como la propiedad JSON `paging.next.after` de una
            respuesta paginada que contenga más resultados.
          required: false
          style: form
          explode: true
          schema:
            type: string
        - name: archived
          in: query
          description: >-
            Especifica si se deben devolver las filas archivadas. De forma
            predeterminada es `false`.
          required: false
          style: form
          explode: true
          schema:
            type: boolean
        - name: limit
          in: query
          description: >-
            El número máximo de resultados que se devolverán. La opción
            predeterminada es `1000`.
          required: false
          style: form
          explode: true
          schema:
            type: integer
            format: int32
        - name: offset
          in: query
          description: >-
            El número de filas que hay que saltarse para empezar a obtener
            resultados.
          required: false
          style: form
          explode: true
          schema:
            type: integer
            format: int32
        - name: properties
          in: query
          description: >-
            Especifica los nombres de las columnas para obtener resultados que
            contengan solo las columnas requeridas en lugar de todos los
            detalles de las columnas. Si quieres incluir múltiples columnas en
            el resultado, utiliza este parámetro de consulta tantas veces como
            desees.
          required: false
          style: form
          explode: true
          schema:
            type: array
            items:
              type: string
        - name: sort
          in: query
          description: >-
            Especifica los nombres de las columnas por los cuales ordenar los
            resultados.
          required: false
          style: form
          explode: true
          schema:
            type: array
            items:
              type: string
      responses:
        '200':
          description: successful operation
          content:
            application/json:
              schema:
                $ref: >-
                  #/components/schemas/UnifiedCollectionResponseWithTotalBaseHubDbTableRowV3
        default:
          $ref: '#/components/responses/Error'
          description: ''
      security:
        - oauth2:
            - hubdb
        - oauth2:
            - hubdb.rows.read
components:
  schemas:
    UnifiedCollectionResponseWithTotalBaseHubDbTableRowV3:
      properties: {}
      oneOf:
        - $ref: >-
            #/components/schemas/RandomAccessCollectionResponseWithTotalHubDbTableRowV3
        - $ref: >-
            #/components/schemas/StreamingCollectionResponseWithTotalHubDbTableRowV3
    RandomAccessCollectionResponseWithTotalHubDbTableRowV3:
      required:
        - results
        - total
        - type
      type: object
      properties:
        paging:
          $ref: '#/components/schemas/BoundedPaging'
        results:
          type: array
          items: 8c71ccf5-806b-46ab-a7e4-80713e787384
        total:
          type: integer
          description: El número total de filas disponibles en la colección.
          format: int32
        type:
          type: string
          description: >-
            Indica el tipo de respuesta, que de forma predeterminada es
            'RANDOM_ACCESS'.
          default: RANDOM_ACCESS
          enum:
            - RANDOM_ACCESS
      x-hubspot-sub-type-impl: true
    StreamingCollectionResponseWithTotalHubDbTableRowV3:
      required:
        - results
        - total
        - type
      type: object
      properties:
        paging:
          $ref: '#/components/schemas/Paging'
        results:
          type: array
          items: 8c71ccf5-806b-46ab-a7e4-80713e787384
        total:
          type: integer
          description: El número total de filas disponibles en la colección.
          format: int32
        type:
          type: string
          description: >-
            Indica el tipo de respuesta, que de forma predeterminada es
            "STREAMING".
          default: STREAMING
          enum:
            - STREAMING
      x-hubspot-sub-type-impl: true
    Error:
      required:
        - category
        - correlationId
        - message
      type: object
      properties:
        category:
          type: string
          description: La categoría del error
        context:
          type: object
          additionalProperties:
            type: array
            items:
              type: string
          description: Contexto de la condición de error
          example: >-
            {invalidPropertyName=[propertyValue], missingScopes=[scope1,
            scope2]}
        correlationId:
          type: string
          description: >-
            Un identificador único para la solicitud. Incluye este valor con
            cualquier informe de error o ticket de asistencia.
          format: uuid
          example: aeb5f871-7f07-4993-9211-075dc63e7cbf
        errors:
          type: array
          description: información adicional acerca del error
          items:
            $ref: '#/components/schemas/ErrorDetail'
        links:
          type: object
          additionalProperties:
            type: string
          description: >-
            Un mapa de nombres de enlaces a las URI asociadas que contienen
            documentación sobre el error o los pasos recomendados para
            solucionarlo
        message:
          type: string
          description: >-
            Un mensaje legible en el que se describa el error y los pasos para
            solucionarlo, si procede
          example: An error occurred
        subCategory:
          type: string
          description: >-
            Una categoría específica que contiene detalles más concretos acerca
            del error
      example:
        message: Invalid input (details will vary based on the error)
        correlationId: aeb5f871-7f07-4993-9211-075dc63e7cbf
        category: VALIDATION_ERROR
        links:
          knowledge-base: https://www.hubspot.com/products/service/knowledge-base
    BoundedPaging:
      type: object
      properties:
        next:
          $ref: '#/components/schemas/BoundedNextPage'
    Paging:
      type: object
      properties:
        next:
          $ref: '#/components/schemas/NextPage'
        prev:
          $ref: '#/components/schemas/PreviousPage'
    ErrorDetail:
      required:
        - message
      type: object
      properties:
        code:
          type: string
          description: El código de estado asociado al detalle del error
        context:
          type: object
          additionalProperties:
            type: array
            items:
              type: string
          description: Contexto de la condición de error
          example: >-
            {invalidPropertyName=[propertyValue], missingScopes=[scope1,
            scope2]}
        in:
          type: string
          description: El nombre del campo o parámetro en el que se encontró el error.
        message:
          type: string
          description: >-
            Un mensaje legible en el que se describa el error y los pasos para
            solucionarlo, si procede
        subCategory:
          type: string
          description: >-
            Una categoría específica que contiene detalles más concretos acerca
            del error
    BoundedNextPage:
      required:
        - offset
      type: object
      properties:
        link:
          type: string
          description: >-
            Una URL que puede utilizarse para obtener el siguiente conjunto de
            resultados.
        offset:
          type: integer
          description: >-
            El valor de desplazamiento que indica el punto de partida de la
            siguiente serie de resultados.
          format: int32
    NextPage:
      required:
        - after
      type: object
      properties:
        after:
          type: string
          description: >-
            Un token del cursor de paginación para recuperar páginas
            posteriores.
        link:
          type: string
          description: >-
            Una URL que se puede utilizar para recuperar los resultados de la
            página siguiente.
      description: >-
        Specifies the paging information needed to retrieve the next set of
        results in a paginated API response
    PreviousPage:
      required:
        - before
      type: object
      properties:
        before:
          type: string
          description: Un token del cursor de paginación para recuperar páginas anteriores.
        link:
          type: string
          description: >-
            Una URL que se puede utilizar para recuperar los resultados de las
            páginas anteriores.
      description: >-
        specifies the paging information needed to retrieve the previous set of
        results in a paginated API response
  responses:
    Error:
      description: An error occurred.
      content:
        '*/*':
          schema:
            $ref: '#/components/schemas/Error'
  securitySchemes:
    oauth2:
      type: oauth2
      flows:
        authorizationCode:
          authorizationUrl: https://app.hubspot.com/oauth/authorize
          tokenUrl: https://api.hubapi.com/oauth/v1/token
          scopes:
            hubdb: ''

````