Lists all users in the system.
SHOW [ TERSE ] USERS [ LIKE '<pattern>' ] [ STARTS WITH '<name_string>' ] [ LIMIT <rows> ] [ FROM '<name_string>' ]
Optionally returns only a subset of the output columns:
| name | created_on | display_name | first_name | last_name | email | org_identity | comment | has_password | has_rsa_public_key |
Default: No value (all columns are included in the output).
Filters the command output by object name. The filter uses case-insensitive pattern matching, with support for SQL wildcard characters (
For example, the following patterns return the same results:
... LIKE '%testing%' ...
... LIKE '%TESTING%' ...
STARTS WITH 'name_string'
Optionally filters the command output based on the characters that appear at the beginning of the object name. The string must be enclosed in single quotes and is case-sensitive.
For example, the following clauses return different results:
... STARTS WITH 'B' ...
... STARTS WITH 'b' ...
Default: No value (no filtering is applied to the output).
LIMIT rows [ FROM 'name_string' ]
Optionally limits the maximum number of rows returned, while also enabling “pagination” of the results. Note that the actual number of rows returned might be less than the specified limit (e.g. the number of existing objects is less than the specified limit).
FROM 'name_string'subclause effectively serves as a “cursor” for the results. This enables fetching the specified number of rows following the first row whose object name matches the specified string:
The string must be enclosed in single quotes and is case-sensitive.
The string does not have to include the full object name; partial names are supported.
Default: No value (no limit is applied to the output)
STARTS WITH 'name_string'can be combined in the same statement; however, both conditions must be met or they cancel out each other and no results are returned.
In addition, objects are returned in lexicographic order by name, so
FROM 'name_string'only returns rows with a higher lexicographic value than the rows returned by
STARTS WITH 'name_string'.
... STARTS WITH 'A' LIMIT ... FROM 'B'would return no results.
... STARTS WITH 'B' LIMIT ... FROM 'A'would return no results.
... STARTS WITH 'A' LIMIT ... FROM 'AB'would return results (if any rows match the input strings).
The command can only be executed by users with a role that has the MANAGE GRANTS global privilege. This privilege is usually only granted to the ACCOUNTADMIN and SECURITYADMIN roles.
If the account has more than 10,000 users, you can use either of the following options:
SHOW USERS LIMIT 10000 FROM 'JOE';
Returns users after 10,000. In this example,
JOEis the username of the last row from the command.
The command does not require a running warehouse to execute.
To post-process the output of this command, you can use the RESULT_SCAN function, which treats the output as a table that can be queried.