Show / Hide Table of Contents

Class Routine

A user-defined function or a stored procedure.

Inheritance
object
Routine
Implements
IDirectResponseSchema
Inherited Members
object.Equals(object)
object.Equals(object, object)
object.GetHashCode()
object.GetType()
object.MemberwiseClone()
object.ReferenceEquals(object, object)
object.ToString()
Namespace: Google.Apis.Bigquery.v2.Data
Assembly: Google.Apis.Bigquery.v2.dll
Syntax
public class Routine : IDirectResponseSchema

Properties

Arguments

Optional.

Declaration
[JsonProperty("arguments")]
public virtual IList<Argument> Arguments { get; set; }
Property Value
Type Description
IList<Argument>

CreationTime

Output only. The time when this routine was created, in milliseconds since the epoch.

Declaration
[JsonProperty("creationTime")]
public virtual long? CreationTime { get; set; }
Property Value
Type Description
long?

DataGovernanceType

Optional. If set to DATA_MASKING, the function is validated and made available as a masking function. For more information, see Create custom masking routines.

Declaration
[JsonProperty("dataGovernanceType")]
public virtual string DataGovernanceType { get; set; }
Property Value
Type Description
string

DefinitionBody

Required. The body of the routine. For functions, this is the expression in the AS clause. If language=SQL, it is the substring inside (but excluding) the parentheses. For example, for the function created with the following statement: CREATE FUNCTION JoinLines(x string, y string) as (concat(x, "\n", y)) The definition_body is concat(x, "\n", y) (\n is not replaced with linebreak). If language=JAVASCRIPT, it is the evaluated string in the AS clause. For example, for the function created with the following statement: CREATE FUNCTION f() RETURNS STRING LANGUAGE js AS 'return "\n";\n' The definition_body is return "\n";\n Note that both \n are replaced with linebreaks.

Declaration
[JsonProperty("definitionBody")]
public virtual string DefinitionBody { get; set; }
Property Value
Type Description
string

Description

Optional. The description of the routine, if defined.

Declaration
[JsonProperty("description")]
public virtual string Description { get; set; }
Property Value
Type Description
string

DeterminismLevel

Optional. The determinism level of the JavaScript UDF, if defined.

Declaration
[JsonProperty("determinismLevel")]
public virtual string DeterminismLevel { get; set; }
Property Value
Type Description
string

ETag

Output only. A hash of this resource.

Declaration
[JsonProperty("etag")]
public virtual string ETag { get; set; }
Property Value
Type Description
string

ImportedLibraries

Optional. If language = "JAVASCRIPT", this field stores the path of the imported JAVASCRIPT libraries.

Declaration
[JsonProperty("importedLibraries")]
public virtual IList<string> ImportedLibraries { get; set; }
Property Value
Type Description
IList<string>

Language

Optional. Defaults to "SQL" if remote_function_options field is absent, not set otherwise.

Declaration
[JsonProperty("language")]
public virtual string Language { get; set; }
Property Value
Type Description
string

LastModifiedTime

Output only. The time when this routine was last modified, in milliseconds since the epoch.

Declaration
[JsonProperty("lastModifiedTime")]
public virtual long? LastModifiedTime { get; set; }
Property Value
Type Description
long?

RemoteFunctionOptions

Optional. Remote function specific options.

Declaration
[JsonProperty("remoteFunctionOptions")]
public virtual RemoteFunctionOptions RemoteFunctionOptions { get; set; }
Property Value
Type Description
RemoteFunctionOptions

ReturnTableType

Optional. Can be set only if routine_type = "TABLE_VALUED_FUNCTION". If absent, the return table type is inferred from definition_body at query time in each query that references this routine. If present, then the columns in the evaluated table result will be cast to match the column types specified in return table type, at query time.

Declaration
[JsonProperty("returnTableType")]
public virtual StandardSqlTableType ReturnTableType { get; set; }
Property Value
Type Description
StandardSqlTableType

ReturnType

Optional if language = "SQL"; required otherwise. Cannot be set if routine_type = "TABLE_VALUED_FUNCTION". If absent, the return type is inferred from definition_body at query time in each query that references this routine. If present, then the evaluated result will be cast to the specified returned type at query time. For example, for the functions created with the following statements: * CREATE FUNCTION Add(x FLOAT64, y FLOAT64) RETURNS FLOAT64 AS (x + y); * CREATE FUNCTION Increment(x FLOAT64) AS (Add(x, 1)); * CREATE FUNCTION Decrement(x FLOAT64) RETURNS FLOAT64 AS (Add(x, -1)); The return_type is {type_kind: "FLOAT64"} for Add and Decrement, and is absent for Increment (inferred as FLOAT64 at query time). Suppose the function Add is replaced by CREATE OR REPLACE FUNCTION Add(x INT64, y INT64) AS (x + y); Then the inferred return type of Increment is automatically changed to INT64 at query time, while the return type of Decrement remains FLOAT64.

Declaration
[JsonProperty("returnType")]
public virtual StandardSqlDataType ReturnType { get; set; }
Property Value
Type Description
StandardSqlDataType

RoutineReference

Required. Reference describing the ID of this routine.

Declaration
[JsonProperty("routineReference")]
public virtual RoutineReference RoutineReference { get; set; }
Property Value
Type Description
RoutineReference

RoutineType

Required. The type of routine.

Declaration
[JsonProperty("routineType")]
public virtual string RoutineType { get; set; }
Property Value
Type Description
string

SecurityMode

Optional. The security mode of the routine, if defined. If not defined, the security mode is automatically determined from the routine's configuration.

Declaration
[JsonProperty("securityMode")]
public virtual string SecurityMode { get; set; }
Property Value
Type Description
string

SparkOptions

Optional. Spark specific options.

Declaration
[JsonProperty("sparkOptions")]
public virtual SparkOptions SparkOptions { get; set; }
Property Value
Type Description
SparkOptions

StrictMode

Optional. Use this option to catch many common errors. Error checking is not exhaustive, and successfully creating a procedure doesn't guarantee that the procedure will successfully execute at runtime. If strictMode is set to TRUE, the procedure body is further checked for errors such as non-existent tables or columns. The CREATE PROCEDURE statement fails if the body fails any of these checks. If strictMode is set to FALSE, the procedure body is checked only for syntax. For procedures that invoke themselves recursively, specify strictMode=FALSE to avoid non-existent procedure errors during validation. Default value is TRUE.

Declaration
[JsonProperty("strictMode")]
public virtual bool? StrictMode { get; set; }
Property Value
Type Description
bool?

Implements

IDirectResponseSchema
In this article
Back to top Generated by DocFX
OSZAR »