> ## 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.

# Replace an existing row

> Reemplaza una única fila en la versión en borrador de la tabla. Deben especificarse todos los valores de las columnas. Si una columna tiene un valor en la tabla de destino y ese valor no se define en esta solicitud, se eliminará.
Consulta el punto de terminación "Crear una fila" para obtener instrucciones sobre cómo dar formato a las definiciones de fila JSON.

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 PUT /cms/hubdb/2026-03/tables/{tableIdOrName}/rows/{rowId}/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/{rowId}/draft:
    put:
      tags:
        - Filas
        - Rows
      summary: Reemplaza una fila existente
      description: >-
        Reemplaza una única fila en la versión en borrador de la tabla. Deben
        especificarse todos los valores de las columnas. Si una columna tiene un
        valor en la tabla de destino y ese valor no se define en esta solicitud,
        se eliminará.

        Consulta el punto de terminación "Crear una fila" para obtener
        instrucciones sobre cómo dar formato a las definiciones de fila JSON.
      operationId: >-
        put-/cms/hubdb/2026-03/tables/{tableIdOrName}/rows/{rowId}/draft_replaceDraftTableRow
      parameters:
        - name: rowId
          in: path
          description: El ID de la fila
          required: true
          style: simple
          explode: false
          schema:
            pattern: \d+
            type: string
        - name: tableIdOrName
          in: path
          description: El ID o nombre de la tabla
          required: true
          style: simple
          explode: false
          schema:
            type: string
      requestBody:
        content:
          application/json:
            schema:
              $ref: '#/components/schemas/HubDbTableRowV3Request'
        required: true
      responses:
        '200':
          description: successful operation
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/HubDbTableRowV3'
        default:
          $ref: '#/components/responses/Error'
          description: ''
      security:
        - oauth2:
            - hubdb
        - oauth2:
            - hubdb.rows.write
components:
  schemas:
    HubDbTableRowV3Request:
      required:
        - childTableId
        - displayIndex
        - values
      type: object
      properties:
        childTableId:
          type: integer
          description: Especifica el valor del ID de la columna de tabla secundaria
          format: int64
        displayIndex:
          type: integer
          description: La posición del índice para mostrar la fila dentro de la tabla.
          format: int32
        name:
          type: string
          description: >-
            Especifica el valor de la columna `hs_name`, que se utilizará como
            título en las páginas dinámicas.
        path:
          type: string
          description: >-
            Especifica el valor de la columna `hs_path`, que se utilizará como
            slug en las páginas dinámicas.
        values:
          type: object
          additionalProperties:
            $ref: '#/components/schemas/Variant'
          description: Lista de pares clave-valor con el nombre y el valor de la columna
    HubDbTableRowV3:
      required:
        - childTableId
        - createdAt
        - id
        - name
        - path
        - publishedAt
        - updatedAt
        - values
      type: object
      properties:
        childTableId:
          type: string
          description: Especifica el valor del ID de la columna de tabla secundaria
        createdAt:
          type: string
          description: Marca de tiempo en la que se crea la fila
          format: date-time
        id:
          type: string
          description: El ID de la fila de la tabla
        name:
          type: string
          description: >-
            Especifica el valor de la columna `hs_name`, que se utilizará como
            título en las páginas dinámicas.
        path:
          type: string
          description: >-
            Especifica el valor de la columna `hs_path`, que se utilizará como
            slug en las páginas dinámicas.
        publishedAt:
          type: string
          description: >-
            La marca de tiempo que indica cuándo se publicó la fila por última
            vez, en formato de fecha y hora.
          format: date-time
        updatedAt:
          type: string
          description: Marca de tiempo en la que se actualizó la fila por última vez.
          format: date-time
        values:
          type: object
          additionalProperties:
            type: object
            properties: {}
          description: Lista de pares clave-valor con el nombre y el valor de la columna
    Variant:
      type: object
      properties: {}
    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
    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
  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: ''

````