Scalar Utility Functions
The functions below are difficult to categorize into specific function types and are broadly useful.
| Name | Description | 
|---|---|
| alias(column) | Return the name of the column. | 
| can_cast_implicitly(source_value, target_value) | Whether or not we can implicitly cast from the types of the source value to the target value. | 
| checkpoint(database) | Synchronize WAL with file for (optional) database without interrupting transactions. | 
| coalesce(expr, ...) | Return the first expression that evaluates to a non- NULLvalue. Accepts 1 or more parameters. Each expression can be a column, literal value, function result, or many others. | 
| constant_or_null(arg1, arg2) | If arg2isNULL, returnNULL. Otherwise, returnarg1. | 
| count_if(x) | Aggregate function; rows contribute 1 if xistrueor a non-zero number, else 0. | 
| create_sort_key(parameters...) | Constructs a binary-comparable sort key based on a set of input parameters and sort qualifiers. | 
| current_catalog() | Return the name of the currently active catalog. Default is memory. | 
| current_database() | Return the name of the currently active database. | 
| current_query() | Return the current query as a string. | 
| current_schema() | Return the name of the currently active schema. Default is main. | 
| current_schemas(boolean) | Return list of schemas. Pass a parameter of trueto include implicit schemas. | 
| current_setting('setting_name') | Return the current value of the configuration setting. | 
| currval('sequence_name') | Return the current value of the sequence. Note that nextvalmust be called at least once prior to callingcurrval. | 
| error(message) | Throws the given error message. | 
| equi_width_bins(min, max, bincount, nice := false) | Returns the upper boundaries of a partition of the interval [min, max]intobin_countequal-sized subintervals (for use with, e.g.,histogram). Ifnice = true, thenmin,max, andbincountmay be adjusted to produce more aesthetically pleasing results. | 
| force_checkpoint(database) | Synchronize WAL with file for (optional) database interrupting transactions. | 
| gen_random_uuid() | Return a random UUID similar to this: eeccb8c5-9943-b2bb-bb5e-222f4e14b687. | 
| getenv(var) | Returns the value of the environment variable var. Only available in the command line client. | 
| hash(value) | Returns a UBIGINTwith a hash ofvalue. The used hash function may change across DuckDB versions. | 
| icu_sort_key(string, collator) | Surrogate sort key used to sort special characters according to the specific locale. Collator parameter is optional. Only available when the ICU extension is installed. | 
| if(a, b, c) | Ternary conditional operator. | 
| ifnull(expr, other) | A two-argument version of coalesce. | 
| is_histogram_other_bin(arg) | Returns truewhenargis the "catch-all element" of its datatype for the purpose of thehistogram_exactfunction, which is equal to the "right-most boundary" of its datatype for the purpose of thehistogramfunction. | 
| md5(string) | Returns the MD5 hash of the stringas aVARCHAR. | 
| md5_number(string) | Returns the MD5 hash of the stringas aUHUGEINT. | 
| md5_number_lower(string) | Returns the lower 64-bit segment of the MD5 hash of the stringas aUBIGINT. | 
| md5_number_upper(string) | Returns the upper 64-bit segment of the MD5 hash of the stringas aUBIGINT. | 
| nextval('sequence_name') | Return the following value of the sequence. | 
| nullif(a, b) | Return NULLifa = b, else returna. Equivalent toCASE WHEN a = b THEN NULL ELSE a END. | 
| pg_typeof(expression) | Returns the lower case name of the data type of the result of the expression. For PostgreSQL compatibility. | 
| query(query_string) | Table function that parses and executes the query defined in query_string. Only constant strings are allowed. Warning: this function allows invoking arbitrary queries, potentially altering the database state. | 
| query_table(tbl_name) | Table function that returns the table given in tbl_name. | 
| query_table(tbl_names, [by_name]) | Table function that returns the union of tables given in tbl_names. If the optionalby_nameparameter is set totrue, it usesUNION ALL BY NAMEsemantics. | 
| read_blob(source) | Returns the content from source(a filename, a list of filenames, or a glob pattern) as aBLOB. See theread_blobguide for more details. | 
| read_text(source) | Returns the content from source(a filename, a list of filenames, or a glob pattern) as aVARCHAR. The file content is first validated to be valid UTF-8. Ifread_textattempts to read a file with invalid UTF-8 an error is thrown suggesting to useread_blobinstead. See theread_textguide for more details. | 
| sha1(string) | Returns a VARCHARwith the SHA-1 hash of thestring. | 
| sha256(string) | Returns a VARCHARwith the SHA-256 hash of thestring. | 
| stats(expression) | Returns a string with statistics about the expression. Expression can be a column, constant, or SQL expression. | 
| txid_current() | Returns the current transaction's identifier, a BIGINTvalue. It will assign a new one if the current transaction does not have one already. | 
| typeof(expression) | Returns the name of the data type of the result of the expression. | 
| uuid() | Return a random UUID (UUIDv4) similar to this: eeccb8c5-9943-b2bb-bb5e-222f4e14b687. | 
| uuidv4() | Return a random UUID (UUIDv4) similar to this: eeccb8c5-9943-b2bb-bb5e-222f4e14b687. | 
| uuidv7() | Return a random UUIDv7 similar to this: 81964ebe-00b1-7e1d-b0f9-43c29b6fb8f5. | 
| uuid_extract_timestamp(uuidv7) | Extracts TIMESTAMP WITH TIME ZONEfrom a UUIDv7 value. | 
| uuid_extract_version(uuid) | Extracts UUID version ( 4or7). | 
| version() | Return the currently active version of DuckDB in this format. | 
        
        alias(column)
        
      
    
| Description | Return the name of the column. | 
| Example | alias(column1) | 
| Result | column1 | 
        
        can_cast_implicitly(source_value, target_value)
        
      
    
| Description | Whether or not we can implicitly cast from the types of the source value to the target value. | 
| Example | can_cast_implicitly(1::BIGINT, 1::SMALLINT) | 
| Result | false | 
        
        checkpoint(database)
        
      
    
| Description | Synchronize WAL with file for (optional) database without interrupting transactions. | 
| Example | checkpoint(my_db) | 
| Result | success Boolean | 
        
        coalesce(expr, ...)
        
      
    
| Description | Return the first expression that evaluates to a non- NULLvalue. Accepts 1 or more parameters. Each expression can be a column, literal value, function result, or many others. | 
| Example | coalesce(NULL, NULL, 'default_string') | 
| Result | default_string | 
        
        constant_or_null(arg1, arg2)
        
      
    
| Description | If arg2isNULL, returnNULL. Otherwise, returnarg1. | 
| Example | constant_or_null(42, NULL) | 
| Result | NULL | 
        
        count_if(x)
        
      
    
| Description | Aggregate function; rows contribute 1 if xistrueor a non-zero number, else 0. | 
| Example | count_if(42) | 
| Result | 1 | 
        
        create_sort_key(parameters...)
        
      
    
| Description | Constructs a binary-comparable sort key based on a set of input parameters and sort qualifiers. | 
| Example | create_sort_key('abc', 'ASC NULLS FIRST'); | 
| Result | \x02bcd\x00 | 
        
        current_catalog()
        
      
    
| Description | Return the name of the currently active catalog. Default is memory. | 
| Example | current_catalog() | 
| Result | memory | 
        
        current_database()
        
      
    
| Description | Return the name of the currently active database. | 
| Example | current_database() | 
| Result | memory | 
        
        current_query()
        
      
    
| Description | Return the current query as a string. | 
| Example | current_query() | 
| Result | SELECT current_query(); | 
        
        current_schema()
        
      
    
| Description | Return the name of the currently active schema. Default is main. | 
| Example | current_schema() | 
| Result | main | 
        
        current_schemas(boolean)
        
      
    
| Description | Return list of schemas. Pass a parameter of trueto include implicit schemas. | 
| Example | current_schemas(true) | 
| Result | ['temp', 'main', 'pg_catalog'] | 
        
        current_setting('setting_name')
        
      
    
| Description | Return the current value of the configuration setting. | 
| Example | current_setting('access_mode') | 
| Result | automatic | 
        
        currval('sequence_name')
        
      
    
| Description | Return the current value of the sequence. Note that nextvalmust be called at least once prior to callingcurrval. | 
| Example | currval('my_sequence_name') | 
| Result | 1 | 
        
        error(message)
        
      
    
| Description | Throws the given error message. | 
| Example | error('access_mode') | 
        
        equi_width_bins(min, max, bincount, nice := false)
        
      
    
| Description | Returns the upper boundaries of a partition of the interval [min, max]intobin_countequal-sized subintervals (for use with, e.g.,histogram). Ifnice = true, thenmin,max, andbincountmay be adjusted to produce more aesthetically pleasing results. | 
| Example | equi_width_bins(0.1, 2.7, 4, true) | 
| Result | [0.5, 1.0, 1.5, 2.0, 2.5, 3.0] | 
        
        force_checkpoint(database)
        
      
    
| Description | Synchronize WAL with file for (optional) database interrupting transactions. | 
| Example | force_checkpoint(my_db) | 
| Result | success Boolean | 
        
        gen_random_uuid()
        
      
    
| Description | Return a random UUID (UUIDv4) similar to this: eeccb8c5-9943-b2bb-bb5e-222f4e14b687. | 
| Example | gen_random_uuid() | 
| Result | various | 
        
        getenv(var)
        
      
    
| Description | Returns the value of the environment variable var. Only available in the command line client. | 
| Example | getenv('HOME') | 
| Result | /path/to/user/home | 
        
        hash(value)
        
      
    
| Description | Returns a UBIGINTwith the hash of thevalue. The used hash function may change across DuckDB versions. | 
| Example | hash('🦆') | 
| Result | 2595805878642663834 | 
        
        icu_sort_key(string, collator)
        
      
    
| Description | Surrogate sort key used to sort special characters according to the specific locale. Collator parameter is optional. Only available when the ICU extension is installed. | 
| Example | icu_sort_key('ö', 'DE') | 
| Result | 460145960106 | 
        
        if(a, b, c)
        
      
    
| Description | Ternary conditional operator; returns b if a, else returns c. Equivalent to CASE WHEN a THEN b ELSE c END. | 
| Example | if(2 > 1, 3, 4) | 
| Result | 3 | 
        
        ifnull(expr, other)
        
      
    
| Description | A two-argument version of coalesce. | 
| Example | ifnull(NULL, 'default_string') | 
| Result | default_string | 
        
        is_histogram_other_bin(arg)
        
      
    
| Description | Returns truewhenargis the "catch-all element" of its datatype for the purpose of thehistogram_exactfunction, which is equal to the "right-most boundary" of its datatype for the purpose of thehistogramfunction. | 
| Example | is_histogram_other_bin('') | 
| Result | true | 
        
        md5(string)
        
      
    
| Description | Returns the MD5 hash of the stringas aVARCHAR. | 
| Example | md5('abc') | 
| Result | 900150983cd24fb0d6963f7d28e17f72 | 
        
        md5_number(string)
        
      
    
| Description | Returns the MD5 hash of the stringas aUHUGEINT. | 
| Example | md5_number('abc') | 
| Result | 152195979970564155685860391459828531600 | 
        
        md5_number_lower(string)
        
      
    
| Description | Returns the lower 8 bytes of the MD5 hash of stringas aUBIGINT. | 
| Example | md5_number_lower('abc') | 
| Result | 8250560606382298838 | 
        
        md5_number_upper(string)
        
      
    
| Description | Returns the upper 8 bytes of the MD5 hash of stringas aUBIGINT. | 
| Example | md5_number_upper('abc') | 
| Result | 12704604231530709392 | 
        
        nextval('sequence_name')
        
      
    
| Description | Return the following value of the sequence. | 
| Example | nextval('my_sequence_name') | 
| Result | 2 | 
        
        nullif(a, b)
        
      
    
| Description | Return NULLif a = b, else return a. Equivalent toCASE WHEN a = b THEN NULL ELSE a END. | 
| Example | nullif(1+1, 2) | 
| Result | NULL | 
        
        pg_typeof(expression)
        
      
    
| Description | Returns the lower case name of the data type of the result of the expression. For PostgreSQL compatibility. | 
| Example | pg_typeof('abc') | 
| Result | varchar | 
        
        query(query_string)
        
      
    
| Description | Table function that parses and executes the query defined in query_string. Only constant strings are allowed. Warning: this function allows invoking arbitrary queries, potentially altering the database state. | 
| Example | query('SELECT 42 AS x') | 
| Result | 42 | 
        
        query_table(tbl_name)
        
      
    
| Description | Table function that returns the table given in tbl_name. | 
| Example | query_table('t1') | 
| Result | (the rows of t1) | 
        
        query_table(tbl_names, [by_name])
        
      
    
| Description | Table function that returns the union of tables given in tbl_names. If the optionalby_nameparameter is set totrue, it usesUNION ALL BY NAMEsemantics. | 
| Example | query_table(['t1', 't2']) | 
| Result | (the union of the two tables) | 
        
        read_blob(source)
        
      
    
| Description | Returns the content from source(a filename, a list of filenames, or a glob pattern) as aBLOB. See theread_blobguide for more details. | 
| Example | read_blob('hello.bin') | 
| Result | hello\x0A | 
        
        read_text(source)
        
      
    
| Description | Returns the content from source(a filename, a list of filenames, or a glob pattern) as aVARCHAR. The file content is first validated to be valid UTF-8. Ifread_textattempts to read a file with invalid UTF-8 an error is thrown suggesting to useread_blobinstead. See theread_textguide for more details. | 
| Example | read_text('hello.txt') | 
| Result | hello\n | 
        
        sha1(string)
        
      
    
| Description | Returns a VARCHARwith the SHA-1 hash of thestring. | 
| Example | sha1('🦆') | 
| Result | 949bf843dc338be348fb9525d1eb535d31241d76 | 
        
        sha256(string)
        
      
    
| Description | Returns a VARCHARwith the SHA-256 hash of thestring. | 
| Example | sha256('🦆') | 
| Result | d7a5c5e0d1d94c32218539e7e47d4ba9c3c7b77d61332fb60d633dde89e473fb | 
        
        stats(expression)
        
      
    
| Description | Returns a string with statistics about the expression. Expression can be a column, constant, or SQL expression. | 
| Example | stats(5) | 
| Result | '[Min: 5, Max: 5][Has Null: false]' | 
        
        txid_current()
        
      
    
| Description | Returns the current transaction's identifier, a BIGINTvalue. It will assign a new one if the current transaction does not have one already. | 
| Example | txid_current() | 
| Result | various | 
        
        typeof(expression)
        
      
    
| Description | Returns the name of the data type of the result of the expression. | 
| Example | typeof('abc') | 
| Result | VARCHAR | 
        
        uuid()
        
      
    
| Description | Return a random UUID (UUIDv4) similar to this: eeccb8c5-9943-b2bb-bb5e-222f4e14b687. | 
| Example | uuid() | 
| Result | various | 
        
        uuidv4()
        
      
    
| Description | Return a random UUID (UUIDv4) similar to this: eeccb8c5-9943-b2bb-bb5e-222f4e14b687. | 
| Example | uuidv4() | 
| Result | various | 
        
        uuidv7()
        
      
    
| Description | Return a random UUIDv7 similar to this: 81964ebe-00b1-7e1d-b0f9-43c29b6fb8f5. | 
| Example | uuidv7() | 
| Result | various | 
        
        uuid_extract_timestamp(uuidv7)
        
      
    
| Description | Extracts TIMESTAMP WITH TIME ZONEfrom a UUIDv7 value. | 
| Example | uuid_extract_timestamp(uuidv7()) | 
| Result | 2025-04-19 15:51:20.07+00 | 
        
        uuid_extract_version(uuid)
        
      
    
| Description | Extracts UUID version ( 4or7). | 
| Example | uuid_extract_version(uuidv7()) | 
| Result | 7 | 
        
        version()
        
      
    
| Description | Return the currently active version of DuckDB in this format. | 
| Example | version() | 
| Result | various | 
Utility Table Functions
A table function is used in place of a table in a FROM clause.
| Name | Description | 
|---|---|
| glob(search_path) | Return filenames found at the location indicated by the search_path in a single column named file. The search_path may contain glob pattern matching syntax. | 
| repeat_row(varargs, num_rows) | Returns a table with num_rowsrows, each containing the fields defined invarargs. | 
        
        glob(search_path)
        
      
    
| Description | Return filenames found at the location indicated by the search_path in a single column named file. The search_path may contain glob pattern matching syntax. | 
| Example | glob('*') | 
| Result | (table of filenames) | 
        
        repeat_row(varargs, num_rows)
        
      
    
| Description | Returns a table with num_rowsrows, each containing the fields defined invarargs. | 
| Example | repeat_row(1, 2, 'foo', num_rows = 3) | 
| Result | 3 rows of 1, 2, 'foo' | 
© 2025 DuckDB Foundation, Amsterdam NL