F.29. mchar
 The mchar module provides additional data types for compatibility with Microsoft SQL Server (MS SQL). 
F.29.1. Overview
This module has been designed to improve 1C Enterprise support, most popular Russian CRM and ERP system.
It implements types MCHAR and MVARCHAR, which are bug-to-bug compatible with MS SQL CHAR and VARCHAR respectively. Additionally, these types use libicu for comparison and case conversion, so their behavior is identical across different operating systems.
Postgres Pro also includes citext extension which provides types similar to MCHAR. But this extension doesn't emulate MS-SQL behavior concerning end-of-value whitespace.
Differences from Postgres Pro standard CHAR and VARCHAR are:
- Case insensitive comparison 
- Handling of the whitespace at the end of string 
- These types are always stored as two-byte unicode value regardless of database encoding. 
F.29.2. Additional types
- mchar— analog of the MS SQL char type
- mvarchar— analog of the MS SQL varchar type
F.29.3. MCHAR and MVARCHAR features
- Defines - length(str)function
- Defines - substr(str, pos[, length])function
- Defines - ||operator, which would be applied to concatenate any (mchar and mvarchar) arguments
- Defines set of operators: - <,- <=,- =,- >=,- >for case-insensitive comparison (LibICU)
- Defines set of operators: - &<,- &<=,- &=,- &>=,- &>to case-sensitive comparison (LibICU)
- Implicit cast between - mcharand- mvarchartypes
- B-tree and Hash-index support 
- The - LIKE [ESCAPE]operator support
- The - SIMILAR TO [ESCAPE]operator support
- The ~ operator (POSIX regexp) support 
- Index support for the LIKE operator 
F.29.4. Authors
       Oleg Bartunov <[email protected]>
       Teodor Sigaev <[email protected]>