The MySQL Enterprise Data Masking and De-Identification plugin library includes several functions, which may be grouped into these categories:
        As of MySQL 8.0.19, these functions support the single-byte
        latin1 character set for string arguments and
        return values. Prior to MySQL 8.0.19, the functions treat string
        arguments as binary strings (which means they do not distinguish
        lettercase), and string return values are binary strings. You
        can see the difference in return value character set as follows:
      
MySQL 8.0.19 and higher:
mysql> SELECT CHARSET(gen_rnd_email());
+--------------------------+
| CHARSET(gen_rnd_email()) |
+--------------------------+
| latin1                   |
+--------------------------+Prior to MySQL 8.0.19:
mysql> SELECT CHARSET(gen_rnd_email());
+--------------------------+
| CHARSET(gen_rnd_email()) |
+--------------------------+
| binary                   |
+--------------------------+
        For any version, if a string return value should be in a
        different character set, convert it. The following example shows
        how to convert the result of
        gen_rnd_email()
        to the utf8mb4 character set:
      
SET @email = CONVERT(gen_rnd_email() USING utf8mb4);To explicitly produce a binary string (for example, to produce a result like that for MySQL versions prior to 8.0.19), do this:
SET @email = CONVERT(gen_rnd_email() USING binary);It may also be necessary to convert string arguments, as illustrated in Using Masked Data for Customer Identification.
        If a MySQL Enterprise Data Masking and De-Identification function is invoked from within the
        mysql client, binary string results display
        using hexadecimal notation, depending on the value of the
        --binary-as-hex. For more
        information about that option, see Section 6.5.1, “mysql — The MySQL Command-Line Client”.
Each plugin function in this section performs a masking operation on its string argument and returns the masked result.
- mask_inner(- str,- margin1,- margin2[,- mask_char])- Masks the interior part of a string, leaving the ends untouched, and returns the result. An optional masking character can be specified. - Arguments: - str: The string to mask.
- margin1: A nonnegative integer that specifies the number of characters on the left end of the string to remain unmasked. If the value is 0, no left end characters remain unmasked.
- margin2: A nonnegative integer that specifies the number of characters on the right end of the string to remain unmasked. If the value is 0, no right end characters remain unmasked.
- mask_char: (Optional) The single character to use for masking. The default is- 'X'if- mask_charis not given.- The masking character must be a single-byte character. Attempts to use a multibyte character produce an error. 
 - Return value: - The masked string, or - NULLif either margin is negative.- If the sum of the margin values is larger than the argument length, no masking occurs and the argument is returned unchanged. - Example: - mysql> SELECT mask_inner('abcdef', 1, 2), mask_inner('abcdef',0, 5); +----------------------------+---------------------------+ | mask_inner('abcdef', 1, 2) | mask_inner('abcdef',0, 5) | +----------------------------+---------------------------+ | aXXXef | Xbcdef | +----------------------------+---------------------------+ mysql> SELECT mask_inner('abcdef', 1, 2, '*'), mask_inner('abcdef',0, 5, '#'); +---------------------------------+--------------------------------+ | mask_inner('abcdef', 1, 2, '*') | mask_inner('abcdef',0, 5, '#') | +---------------------------------+--------------------------------+ | a***ef | #bcdef | +---------------------------------+--------------------------------+
- mask_outer(- str,- margin1,- margin2[,- mask_char])- Masks the left and right ends of a string, leaving the interior unmasked, and returns the result. An optional masking character can be specified. - Arguments: - str: The string to mask.
- margin1: A nonnegative integer that specifies the number of characters on the left end of the string to mask. If the value is 0, no left end characters are masked.
- margin2: A nonnegative integer that specifies the number of characters on the right end of the string to mask. If the value is 0, no right end characters are masked.
- mask_char: (Optional) The single character to use for masking. The default is- 'X'if- mask_charis not given.- The masking character must be a single-byte character. Attempts to use a multibyte character produce an error. 
 - Return value: - The masked string, or - NULLif either margin is negative.- If the sum of the margin values is larger than the argument length, the entire argument is masked. - Example: - mysql> SELECT mask_outer('abcdef', 1, 2), mask_outer('abcdef',0, 5); +----------------------------+---------------------------+ | mask_outer('abcdef', 1, 2) | mask_outer('abcdef',0, 5) | +----------------------------+---------------------------+ | XbcdXX | aXXXXX | +----------------------------+---------------------------+ mysql> SELECT mask_outer('abcdef', 1, 2, '*'), mask_outer('abcdef',0, 5, '#'); +---------------------------------+--------------------------------+ | mask_outer('abcdef', 1, 2, '*') | mask_outer('abcdef',0, 5, '#') | +---------------------------------+--------------------------------+ | *bcd** | a##### | +---------------------------------+--------------------------------+
- Masks a payment card Primary Account Number and returns the number with all but the last four digits replaced by - 'X'characters.- Arguments: - str: The string to mask. The string must be a suitable length for the Primary Account Number, but is not otherwise checked.
 - Return value: - The masked payment number as a string. If the argument is shorter than required, it is returned unchanged. - Example: - mysql> SELECT mask_pan(gen_rnd_pan()); +-------------------------+ | mask_pan(gen_rnd_pan()) | +-------------------------+ | XXXXXXXXXXXX9102 | +-------------------------+ mysql> SELECT mask_pan(gen_rnd_pan(19)); +---------------------------+ | mask_pan(gen_rnd_pan(19)) | +---------------------------+ | XXXXXXXXXXXXXXX8268 | +---------------------------+ mysql> SELECT mask_pan('a*Z'); +-----------------+ | mask_pan('a*Z') | +-----------------+ | a*Z | +-----------------+
- Masks a payment card Primary Account Number and returns the number with all but the first six and last four digits replaced by - 'X'characters. The first six digits indicate the payment card issuer.- Arguments: - str: The string to mask. The string must be a suitable length for the Primary Account Number, but is not otherwise checked.
 - Return value: - The masked payment number as a string. If the argument is shorter than required, it is returned unchanged. - Example: - mysql> SELECT mask_pan_relaxed(gen_rnd_pan()); +---------------------------------+ | mask_pan_relaxed(gen_rnd_pan()) | +---------------------------------+ | 551279XXXXXX3108 | +---------------------------------+ mysql> SELECT mask_pan_relaxed(gen_rnd_pan(19)); +-----------------------------------+ | mask_pan_relaxed(gen_rnd_pan(19)) | +-----------------------------------+ | 462634XXXXXXXXX6739 | +-----------------------------------+ mysql> SELECT mask_pan_relaxed('a*Z'); +-------------------------+ | mask_pan_relaxed('a*Z') | +-------------------------+ | a*Z | +-------------------------+
- Masks a US Social Security number and returns the number with all but the last four digits replaced by - 'X'characters.- Arguments: - str: The string to mask. The string must be 11 characters long.
 - Return value: - The masked Social Security number as a string, or an error if the argument is not the correct length. - Example: - mysql> SELECT mask_ssn('909-63-6922'), mask_ssn('abcdefghijk'); +-------------------------+-------------------------+ | mask_ssn('909-63-6922') | mask_ssn('abcdefghijk') | +-------------------------+-------------------------+ | XXX-XX-6922 | XXX-XX-hijk | +-------------------------+-------------------------+ mysql> SELECT mask_ssn('909'); ERROR 1123 (HY000): Can't initialize function 'mask_ssn'; MASK_SSN: Error: String argument width too small mysql> SELECT mask_ssn('123456789123456789'); ERROR 1123 (HY000): Can't initialize function 'mask_ssn'; MASK_SSN: Error: String argument width too large
          The plugin functions in this section generate random values
          for different types of data. When possible, generated values
          have characteristics reserved for demonstration or test
          values, to avoid having them mistaken for legitimate data. For
          example,
          gen_rnd_us_phone()
          returns a US phone number that uses the 555 area code, which
          is not assigned to phone numbers in actual use. Individual
          function descriptions describe any exceptions to this
          principle.
- Generates a random number chosen from a specified range. - Arguments: - lower: An integer that specifies the lower boundary of the range.
- upper: An integer that specifies the upper boundary of the range, which must not be less than the lower boundary.
 - Return value: - A random integer in the range from - lowerto- upper, inclusive, or- NULLif the- upperargument is less than- lower.- Example: - mysql> SELECT gen_range(100, 200), gen_range(-1000, -800); +---------------------+------------------------+ | gen_range(100, 200) | gen_range(-1000, -800) | +---------------------+------------------------+ | 177 | -917 | +---------------------+------------------------+ mysql> SELECT gen_range(1, 0); +-----------------+ | gen_range(1, 0) | +-----------------+ | NULL | +-----------------+
- Generates a random email address in the - example.comdomain.- Arguments: - None. - Return value: - A random email address as a string. - Example: - mysql> SELECT gen_rnd_email(); +---------------------------+ | gen_rnd_email() | +---------------------------+ | ijocv.mwvhhuf@example.com | +---------------------------+
- Generates a random payment card Primary Account Number. The number passes the Luhn check (an algorithm that performs a checksum verification against a check digit). Warning- Values returned from - gen_rnd_pan()should be used only for test purposes, and are not suitable for publication. There is no way to guarantee that a given return value is not assigned to a legitimate payment account. Should it be necessary to publish a- gen_rnd_pan()result, consider masking it with- mask_pan()or- mask_pan_relaxed().- Arguments: - size: (Optional) An integer that specifies the size of the result. The default is 16 if- sizeis not given. If given,- sizemust be an integer in the range from 12 to 19.
 - Return value: - A random payment number as a string, or - NULLif a- sizeargument outside the permitted range is given.- Example: - mysql> SELECT mask_pan(gen_rnd_pan()); +-------------------------+ | mask_pan(gen_rnd_pan()) | +-------------------------+ | XXXXXXXXXXXX5805 | +-------------------------+ mysql> SELECT mask_pan(gen_rnd_pan(19)); +---------------------------+ | mask_pan(gen_rnd_pan(19)) | +---------------------------+ | XXXXXXXXXXXXXXX5067 | +---------------------------+ mysql> SELECT mask_pan_relaxed(gen_rnd_pan()); +---------------------------------+ | mask_pan_relaxed(gen_rnd_pan()) | +---------------------------------+ | 398403XXXXXX9547 | +---------------------------------+ mysql> SELECT mask_pan_relaxed(gen_rnd_pan(19)); +-----------------------------------+ | mask_pan_relaxed(gen_rnd_pan(19)) | +-----------------------------------+ | 578416XXXXXXXXX6509 | +-----------------------------------+ mysql> SELECT gen_rnd_pan(11), gen_rnd_pan(20); +-----------------+-----------------+ | gen_rnd_pan(11) | gen_rnd_pan(20) | +-----------------+-----------------+ | NULL | NULL | +-----------------+-----------------+
- Generates a random US Social Security number in - AAA-- BB-- CCCC- AAApart is greater than 900 and the- BBpart is less than 70, which are characteristics not used for legitimate Social Security numbers.- Arguments: - None. - Return value: - A random Social Security number as a string. - Example: - mysql> SELECT gen_rnd_ssn(); +---------------+ | gen_rnd_ssn() | +---------------+ | 951-26-0058 | +---------------+
- Generates a random US phone number in - 1-555-format. The 555 area code is not used for legitimate phone numbers.- AAA-- BBBB- Arguments: - None. - Return value: - A random US phone number as a string. - Example: - mysql> SELECT gen_rnd_us_phone(); +--------------------+ | gen_rnd_us_phone() | +--------------------+ | 1-555-682-5423 | +--------------------+
          The plugin functions in this section manipulate dictionaries
          of terms and perform generation and masking operations based
          on them. Some of these functions require the
          SUPER privilege.
        
When a dictionary is loaded, it becomes part of the dictionary registry and is assigned a name to be used by other dictionary functions. Dictionaries are loaded from plain text files containing one term per line. Empty lines are ignored. To be valid, a dictionary file must contain at least one nonempty line.
- gen_blacklist(- str,- dictionary_name,- replacement_dictionary_name)- Replaces a term present in one dictionary with a term from a second dictionary and returns the replacement term. This masks the original term by substitution. This function is deprecated in MySQL 8.0.23; use - gen_blocklist()instead.
- gen_blocklist(- str,- dictionary_name,- replacement_dictionary_name)- Replaces a term present in one dictionary with a term from a second dictionary and returns the replacement term. This masks the original term by substitution. This function was added in MySQL 8.0.23; use it instead of - gen_blacklist().- Arguments: - str: A string that indicates the term to replace.
- dictionary_name: A string that names the dictionary containing the term to replace.
- replacement_dictionary_name: A string that names the dictionary from which to choose the replacement term.
 - Return value: - A string randomly chosen from - replacement_dictionary_nameas a replacement for- str, or- strif it does not appear in- dictionary_name, or- NULLif either dictionary name is not in the dictionary registry.- If the term to replace appears in both dictionaries, it is possible for the return value to be the same term. - Example: - mysql> SELECT gen_blocklist('Berlin', 'DE_Cities', 'US_Cities'); +---------------------------------------------------+ | gen_blocklist('Berlin', 'DE_Cities', 'US_Cities') | +---------------------------------------------------+ | Phoenix | +---------------------------------------------------+
- gen_dictionary(- dictionary_name)- Returns a random term from a dictionary. - Arguments: - dictionary_name: A string that names the dictionary from which to choose the term.
 - Return value: - A random term from the dictionary as a string, or - NULLif the dictionary name is not in the dictionary registry.- Example: - mysql> SELECT gen_dictionary('mydict'); +--------------------------+ | gen_dictionary('mydict') | +--------------------------+ | My term | +--------------------------+ mysql> SELECT gen_dictionary('no-such-dict'); +--------------------------------+ | gen_dictionary('no-such-dict') | +--------------------------------+ | NULL | +--------------------------------+
- gen_dictionary_drop(- dictionary_name)- Removes a dictionary from the dictionary registry. - This function requires the - SUPERprivilege.- Arguments: - dictionary_name: A string that names the dictionary to remove from the dictionary registry.
 - Return value: - A string that indicates whether the drop operation succeeded. - Dictionary removedindicates success.- Dictionary removal errorindicates failure.- Example: - mysql> SELECT gen_dictionary_drop('mydict'); +-------------------------------+ | gen_dictionary_drop('mydict') | +-------------------------------+ | Dictionary removed | +-------------------------------+ mysql> SELECT gen_dictionary_drop('no-such-dict'); +-------------------------------------+ | gen_dictionary_drop('no-such-dict') | +-------------------------------------+ | Dictionary removal error | +-------------------------------------+
- gen_dictionary_load(- dictionary_path,- dictionary_name)- Loads a file into the dictionary registry and assigns the dictionary a name to be used with other functions that require a dictionary name argument. - This function requires the - SUPERprivilege.Important- Dictionaries are not persistent. Any dictionary used by applications must be loaded for each server startup. - Once loaded into the registry, a dictionary is used as is, even if the underlying dictionary file changes. To reload a dictionary, first drop it with - gen_dictionary_drop(), then load it again with- gen_dictionary_load().- Arguments: - dictionary_path: A string that specifies the path name of the dictionary file.
- dictionary_name: A string that provides a name for the dictionary.
 - Return value: - A string that indicates whether the load operation succeeded. - Dictionary load successindicates success.- Dictionary load errorindicates failure. Dictionary load failure can occur for several reasons, including:- A dictionary with the given name is already loaded. 
- The dictionary file is not found. 
- The dictionary file contains no terms. 
- The - secure_file_privsystem variable is set and the dictionary file is not located in the directory named by the variable.
 - Example: - mysql> SELECT gen_dictionary_load('/usr/local/mysql/mysql-files/mydict','mydict'); +---------------------------------------------------------------------+ | gen_dictionary_load('/usr/local/mysql/mysql-files/mydict','mydict') | +---------------------------------------------------------------------+ | Dictionary load success | +---------------------------------------------------------------------+ mysql> SELECT gen_dictionary_load('/dev/null','null'); +-----------------------------------------+ | gen_dictionary_load('/dev/null','null') | +-----------------------------------------+ | Dictionary load error | +-----------------------------------------+