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).
Any user can execute the SHOW USERS command. Snowflake filters the output based upon the privileges granted to the active role that the user uses to run the command. The user that runs the command can always see the username in the results, which is recorded in the
namecolumn. To see the full output, the active role must have either:
The OWNERSHIP privilege on the user object.
The CREATE USER privilege on the account.
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.