SPI_modifytuple

Название

SPI_modifytuple -- создать строку, заменяя отдельные поля в данной

Синтаксис

HeapTuple SPI_modifytuple(Relation rel, HeapTuple row, int ncols,
                          int * colnum, Datum * values, const char * nulls)

Описание

SPI_modifytuple создаёт новую строку, подставляя новые значения для указанных колонок и копируя исходное содержимое остальных колонок. Исходная строка не изменяется.

Аргументы

Relation rel

Используется только в качестве дескриптора строки. (Передача отношения вместо собственно дескриптора строки — нехорошая особенность.)

HeapTuple row

строка, подлежащая изменению

int ncols

число изменяемых колонок

int * colnum

массив длины ncols, содержащий номера изменяемых колонок (начиная с 1)

Datum * values

массив длины ncols, содержащий новые значения указанных колонок

const char * nulls

массив длины ncols, описывающий, в каких колонках передаётся NULL

Если в nulls передаётся NULL, SPI_modifytuple считает, что ни один из параметров не равен NULL. В противном случае элемент массива nulls должен содержать ' ', если значение соответствующего параметра не NULL, либо 'n', если это значение — NULL. (В последнем случае значение, переданное в соответствующем элементе values, не учитывается.) Заметьте, что nulls — это не текстовая строка, а просто массив: ноль '\0' в конце не нужен.

Возвращаемое значение

новая строка с изменениями, размещённая в верхнем контексте исполнителя; NULL, только если rowNULL

В случае ошибки в SPI_result устанавливается:

SPI_ERROR_ARGUMENT

если relNULL, либо rowNULL, либо ncols меньше или равно 0, либо colnumNULL, либо valuesNULL

SPI_ERROR_NOATTRIBUTE

если colnum содержит недопустимый номер колонки (меньше или равен 0, либо больше числа колонок в строке row)

pFad - Phonifier reborn

Pfad - The Proxy pFad of © 2024 Garber Painting. All rights reserved.

Note: This service is not intended for secure transactions such as banking, social media, email, or purchasing. Use at your own risk. We assume no liability whatsoever for broken pages.


Alternative Proxies:

Alternative Proxy

pFad Proxy

pFad v3 Proxy

pFad v4 Proxy