SQL Server 2022 UTF-8 Support Enhancements in Collation

In SQL Server 2022, UTF-8 support has been enhanced, offering more efficient storage and better performance for text data. This blog will explore these enhancements using the JBDB database and provide a detailed business use case to illustrate the benefits of adopting UTF-8 collation.

🌍Business Use Case: International E-commerce Platform 🌍

Imagine an international e-commerce platform that serves customers worldwide, offering products in multiple languages. The database needs to handle diverse character sets efficiently, from English to Japanese, Arabic, and more. Previously, using Unicode (UTF-16) required more storage space, leading to increased costs and slower performance. With SQL Server 2022’s improved UTF-8 support, the platform can now store multilingual text data more compactly, reducing storage costs and enhancing query performance.

UTF-8 Support in SQL Server 2022

SQL Server 2019 introduced UTF-8 as a new encoding option, allowing for more efficient storage of character data. SQL Server 2022 builds on this foundation by enhancing collation support, making it easier to work with UTF-8 encoded data. Let’s explore these enhancements using the JBDB database.

Setting Up the JBDB Database

First, we’ll set up the JBDB database and create a table to store product information in multiple languages.

CREATE DATABASE JBDB;
GO

USE JBDB;
GO

CREATE TABLE Products (
    ProductID INT PRIMARY KEY,
    ProductName NVARCHAR(100),
    ProductDescription NVARCHAR(1000),
    ProductDescription_UTF8 VARCHAR(1000) COLLATE Latin1_General_100_BIN2_UTF8
);
GO

In this example, ProductDescription uses the traditional NVARCHAR data type with UTF-16 encoding, while ProductDescription_UTF8 uses VARCHAR with the Latin1_General_100_BIN2_UTF8 collation for UTF-8 encoding.

Inserting Data with UTF-8 Collation πŸš€

Let’s insert some sample data into the Products table, showcasing different languages.

INSERT INTO Products (ProductID, ProductName, ProductDescription, ProductDescription_UTF8)
VALUES
(1, 'Laptop', N'ι«˜ζ€§θƒ½γƒŽγƒΌγƒˆγƒ‘γ‚½γ‚³γƒ³', 'ι«˜ζ€§θƒ½γƒŽγƒΌγƒˆγƒ‘γ‚½γ‚³γƒ³'), -- Japanese
(2, 'Smartphone', N'Ψ§Ω„Ω‡Ψ§Ψͺف Ψ§Ω„Ψ°ΩƒΩŠ Ψ§Ω„Ψ£ΩƒΨ«Ψ± ΨͺΩ‚Ψ―Ω…Ω‹Ψ§', 'Ψ§Ω„Ω‡Ψ§Ψͺف Ψ§Ω„Ψ°ΩƒΩŠ Ψ§Ω„Ψ£ΩƒΨ«Ψ± ΨͺΩ‚Ψ―Ω…Ω‹Ψ§'), -- Arabic
(3, 'Tablet', N'Nueva tableta con caracterΓ­sticas avanzadas', 'Nueva tableta con caracterΓ­sticas avanzadas'); -- Spanish
GO

Here, we use N'...' to denote Unicode literals for the NVARCHAR column and regular string literals for the VARCHAR column with UTF-8 encoding.

Querying and Comparing Storage Size πŸ“Š

To see the benefits of UTF-8 encoding, we’ll compare the storage size of the ProductDescription and ProductDescription_UTF8 columns.

SELECT
    ProductID,
    DATALENGTH(ProductDescription) AS UnicodeStorage,
    DATALENGTH(ProductDescription_UTF8) AS UTF8Storage
FROM Products;
GO

This query returns the number of bytes used to store each product description, illustrating the storage savings with UTF-8.

Working with UTF-8 Data πŸ”

Let’s perform some queries and operations on the UTF-8 encoded data.

Searching for Products in Japanese:

SELECT ProductID, ProductName, ProductDescription_UTF8
FROM Products
WHERE ProductDescription_UTF8 LIKE '%γƒŽγƒΌγƒˆγƒ‘γ‚½γ‚³γƒ³%';
GO

Updating UTF-8 Data:

UPDATE Products
SET ProductDescription_UTF8 = 'ι«˜ζ€§θƒ½γͺγƒŽγƒΌγƒˆγƒ‘γ‚½γ‚³γƒ³'
WHERE ProductID = 1;
GO

Ordering Data with UTF-8 Collation:

SELECT ProductID, ProductName, ProductDescription_UTF8
FROM Products
ORDER BY ProductDescription_UTF8 COLLATE Latin1_General_100_BIN2_UTF8;
GO

Advantages of UTF-8 in SQL Server 2022 πŸ†

  1. Reduced Storage Costs: UTF-8 encoding is more space-efficient than UTF-16, especially for languages using the Latin alphabet.
  2. Improved Performance: Smaller data size leads to faster reads and writes, enhancing overall performance.
  3. Enhanced Compatibility: UTF-8 is a widely-used encoding standard, making it easier to integrate with other systems and technologies.

Conclusion ✨

SQL Server 2022’s enhanced UTF-8 support in collation offers significant advantages for businesses dealing with multilingual data. By leveraging these enhancements, the international e-commerce platform in our use case can optimize storage, improve performance, and provide a seamless user experience across diverse languages.

Whether you’re dealing with global customer data or localized content, adopting UTF-8 collation in SQL Server 2022 can be a game-changer for your database management strategy.

For more tutorials and tips on SQL Server, including performance tuning and database management, be sure to check out our JBSWiki YouTube channel.

Thank You,
Vivek Janakiraman

Disclaimer:
The views expressed on this blog are mine alone and do not reflect the views of my company or anyone else. All postings on this blog are provided β€œAS IS” with no warranties, and confers no rights.

SQL Server 2022: IS [NOT] DISTINCT FROM Predicate

SQL Server 2022 introduces a new predicate, IS [NOT] DISTINCT FROM, which simplifies the comparison of nullable columns. This feature is a boon for developers who often struggle with the nuanced behavior of NULL values in SQL comparisons. In this blog, we’ll explore how this new predicate works, its benefits, and provide a detailed business use case to illustrate its practical application.

Business Use Case: Analyzing Customer Orders

Imagine a retail company, JB Retail, that maintains a database (JBDB) to track customer orders. The company wants to analyze orders to identify customers who have updated their email addresses. However, due to some data migration issues, there are instances where old and new email addresses might be stored as NULL values.

To accurately identify customers who have changed their email addresses (or those whose email addresses are currently NULL but were previously not NULL), the IS [NOT] DISTINCT FROM predicate becomes very useful. This new feature allows us to simplify the logic and handle NULL comparisons more gracefully.

Setting Up the JBDB Database

First, let’s create the JBDB database and set up a sample table CustomerOrders to illustrate our use case.

-- Create JBDB database
CREATE DATABASE JBDB;
GO

-- Use the JBDB database
USE JBDB;
GO

-- Create CustomerOrders table
CREATE TABLE CustomerOrders (
    OrderID INT PRIMARY KEY,
    CustomerID INT,
    OldEmail NVARCHAR(255),
    NewEmail NVARCHAR(255),
    OrderDate DATE
);
GO

-- Insert sample data into CustomerOrders
INSERT INTO CustomerOrders (OrderID, CustomerID, OldEmail, NewEmail, OrderDate)
VALUES
    (1, 101, 'old_email1@example.com', 'new_email1@example.com', '2024-01-15'),
    (2, 102, 'old_email2@example.com', NULL, '2024-02-20'),
    (3, 103, NULL, 'new_email3@example.com', '2024-03-05'),
    (4, 104, 'old_email4@example.com', 'old_email4@example.com', '2024-04-10'),
    (5, 105, NULL, NULL, '2024-05-12');
GO

Understanding IS [NOT] DISTINCT FROM Predicate 🧩

The IS DISTINCT FROM predicate compares two expressions and returns TRUE if they are distinct (i.e., not equal or one is NULL and the other is not). The IS NOT DISTINCT FROM predicate, on the other hand, returns TRUE if they are not distinct (i.e., equal or both are NULL).

This is particularly useful when dealing with nullable columns, as NULL values are traditionally not equal to anything, including themselves, in SQL. The new predicate addresses this challenge.

Example Queries

Finding Customers Who Have Updated Their Email Address

    SELECT CustomerID, OldEmail, NewEmail
    FROM CustomerOrders
    WHERE OldEmail IS DISTINCT FROM NewEmail;

    This query identifies customers whose email addresses have changed. The IS DISTINCT FROM predicate ensures that it catches cases where either the old or new email could be NULL.

    Finding Customers Whose Email Address Remains Unchanged

    SELECT CustomerID, OldEmail, NewEmail
    FROM CustomerOrders
    WHERE OldEmail IS NOT DISTINCT FROM NewEmail;

    This query retrieves customers whose email addresses have not changed, including cases where both old and new emails are NULL.

      Detailed Business Use Case 🎯

      Let’s dive deeper into how JB Retail can use these queries to improve their customer relationship management. The company plans to send personalized emails to customers whose email addresses have been updated, acknowledging the change and ensuring it was intentional.

      Business Workflow

      Identify Updated Emails: The company will first use the IS DISTINCT FROM query to extract a list of customers with updated emails.

      SELECT CustomerID, OldEmail, NewEmail
      FROM CustomerOrders
      WHERE OldEmail IS DISTINCT FROM NewEmail;
      1. This query helps them identify cases where:
        • The old email was NULL and the new email is not, indicating a new addition.
        • The new email was NULL and the old email is not, indicating a removal.
        • Both emails are different but not NULL, indicating an actual change.
      2. Personalized Communication: Once the list is prepared, JB Retail can use it to send personalized communication to these customers. This step ensures that customers are aware of the changes and can report if the change was not authorized.
      3. Customer Service Follow-up: For cases where both old and new emails are NULL, the company can follow up with these customers to update their contact information, ensuring they do not miss out on important communications.

      Find Customers with NULL Values in Either Old or New Email

      This query helps identify customers where either the old or new email address is NULL, but not both.

      SELECT CustomerID, OldEmail, NewEmail
      FROM CustomerOrders
      WHERE OldEmail IS DISTINCT FROM NewEmail
      AND (OldEmail IS NULL OR NewEmail IS NULL);

      List Orders with Same Email Address Before and After

      This query lists orders where the email address remained the same before and after, but takes NULL into account.

      SELECT OrderID, CustomerID, OldEmail, NewEmail
      FROM CustomerOrders
      WHERE OldEmail IS NOT DISTINCT FROM NewEmail
      AND (OldEmail IS NOT NULL AND NewEmail IS NOT NULL);

      Find Orders with NULL Emails in Both Old and New

      This query identifies orders where both the old and new email addresses are NULL.

      SELECT OrderID, CustomerID, OldEmail, NewEmail
      FROM CustomerOrders
      WHERE OldEmail IS NOT DISTINCT FROM NewEmail
      AND OldEmail IS NULL;

      Identify Changes Where Old Email is NULL and New Email is Not

      This query finds orders where the old email address was NULL and the new email address is not NULL.

      SELECT OrderID, CustomerID, OldEmail, NewEmail
      FROM CustomerOrders
      WHERE OldEmail IS DISTINCT FROM NewEmail
      AND OldEmail IS NULL
      AND NewEmail IS NOT NULL;

      Find Orders Where Both Emails are Different or Both are NULL

      This query lists orders where the old and new emails are either both different or both NULL.

      SELECT OrderID, CustomerID, OldEmail, NewEmail
      FROM CustomerOrders
      WHERE (OldEmail IS DISTINCT FROM NewEmail
      AND OldEmail IS NOT NULL AND NewEmail IS NOT NULL)
      OR (OldEmail IS NULL AND NewEmail IS NULL);

      These queries leverage the IS [NOT] DISTINCT FROM predicate to handle various scenarios involving NULL values, providing flexibility and clarity in managing data comparisons. Feel free to adapt these queries based on your specific needs!

      Conclusion 🏁

      The introduction of the IS [NOT] DISTINCT FROM predicate in SQL Server 2022 is a significant enhancement for database developers and administrators. It simplifies the handling of NULL values in comparisons, making queries more readable and efficient.

      In the case of JB Retail, this feature enables a more accurate and efficient way to handle email updates, ensuring that the company maintains accurate customer contact information and strengthens its customer relationship management processes.

      With these new tools at your disposal, handling NULL values in SQL Server has never been easier! πŸŽ‰

      For more tutorials and tips on SQL Server, including performance tuning and database management, be sure to check out our JBSWiki YouTube channel.

      Thank You,
      Vivek Janakiraman

      Disclaimer:
      The views expressed on this blog are mine alone and do not reflect the views of my company or anyone else. All postings on this blog are provided β€œAS IS” with no warranties, and confers no rights.

        Exploring the APPROX_COUNT_DISTINCT Function in SQL Server 2022

        With the release of SQL Server 2022, a range of powerful new functions has been introduced, including the APPROX_COUNT_DISTINCT function. This function provides a fast and memory-efficient way to estimate the number of unique values in a dataset, making it an invaluable tool for big data scenarios where traditional counting methods may be too slow or resource-intensive. In this blog, we will explore the APPROX_COUNT_DISTINCT function, using the JBDB database for practical demonstrations and providing a detailed business use case to illustrate its benefits. Let’s dive into the world of approximate distinct counts! πŸŽ‰


        Business Use Case: E-commerce Customer Segmentation πŸ“¦

        In an e-commerce business, understanding the diversity of customer behavior is crucial for personalized marketing and inventory management. The JBDB database contains customer transaction data, including CustomerID, ProductID, and PurchaseDate. The business aims to estimate the number of unique customers making purchases each month and the variety of products they are buying. Using the APPROX_COUNT_DISTINCT function, the company can quickly analyze this data to identify trends, optimize stock levels, and tailor marketing campaigns.


        Understanding the APPROX_COUNT_DISTINCT Function 🧠

        The APPROX_COUNT_DISTINCT function estimates the number of distinct values in a column, offering a performance-efficient alternative to the traditional COUNT(DISTINCT column) approach. It is particularly useful in large datasets where an exact count is less critical than performance and resource usage.

        Syntax:

        APPROX_COUNT_DISTINCT ( column_name )
        
        • column_name: The column from which distinct values are counted.

        Example 1: Estimating Unique Customers per Month πŸ“…

        Let’s calculate the estimated number of unique customers making purchases each month in the JBDB database.

        Setup:

        USE JBDB;
        GO
        
        CREATE TABLE CustomerTransactions (
            TransactionID INT PRIMARY KEY,
            CustomerID INT,
            ProductID INT,
            PurchaseDate DATE
        );
        
        INSERT INTO CustomerTransactions (TransactionID, CustomerID, ProductID, PurchaseDate)
        VALUES
        (1, 101, 2001, '2023-01-05'),
        (2, 102, 2002, '2023-01-10'),
        (3, 101, 2003, '2023-01-15'),
        (4, 103, 2001, '2023-02-05'),
        (5, 104, 2002, '2023-02-10'),
        (6, 102, 2004, '2023-02-15'),
        (7, 105, 2005, '2023-03-05'),
        (8, 106, 2001, '2023-03-10');
        GO

        Query to Estimate Unique Customers:

        SELECT 
            FORMAT(PurchaseDate, 'yyyy-MM') AS Month,
            APPROX_COUNT_DISTINCT(CustomerID) AS EstimatedUniqueCustomers
        FROM CustomerTransactions
        GROUP BY FORMAT(PurchaseDate, 'yyyy-MM');
        

        Output:

        MonthEstimatedUniqueCustomers
        2023-012
        2023-023
        2023-032

        This output gives an approximate count of unique customers making purchases in each month, providing quick insights into customer engagement over time.


        Example 2: Estimating Product Variety by Month πŸ“Š

        Now, let’s estimate the variety of products purchased each month to understand product diversity and demand trends.

        Query to Estimate Product Variety:

        SELECT 
            FORMAT(PurchaseDate, 'yyyy-MM') AS Month,
            APPROX_COUNT_DISTINCT(ProductID) AS EstimatedUniqueProducts
        FROM CustomerTransactions
        GROUP BY FORMAT(PurchaseDate, 'yyyy-MM');
        
        

        Output:

        MonthEstimatedUniqueProducts
        2023-013
        2023-023
        2023-032

        This data helps the business understand which months had the highest product variety, aiding in inventory and supply chain management.


        Example 3: Comparing Traditional and Approximate Counts πŸ”„

        To illustrate the efficiency of APPROX_COUNT_DISTINCT, let’s compare it with the traditional COUNT(DISTINCT column) method.

        Traditional COUNT(DISTINCT) Method:

        SELECT 
            FORMAT(PurchaseDate, 'yyyy-MM') AS Month,
            COUNT(DISTINCT CustomerID) AS ExactUniqueCustomers
        FROM CustomerTransactions
        GROUP BY FORMAT(PurchaseDate, 'yyyy-MM');
        
        

        Approximate COUNT(DISTINCT) Method:

        SELECT 
            FORMAT(PurchaseDate, 'yyyy-MM') AS Month,
            APPROX_COUNT_DISTINCT(CustomerID) AS EstimatedUniqueCustomers
        FROM CustomerTransactions
        GROUP BY FORMAT(PurchaseDate, 'yyyy-MM');
        

        Comparison:

        MonthExactUniqueCustomersEstimatedUniqueCustomers
        2023-0122
        2023-0233
        2023-0322

        The approximate method provides similar results with potentially significant performance improvements, especially in large datasets.


        Estimating Unique Products by Customer:

        • Calculate the estimated number of unique products purchased by each customer:
        SELECT 
            CustomerID,
            APPROX_COUNT_DISTINCT(ProductID) AS EstimatedUniqueProducts
        FROM CustomerTransactions
        GROUP BY CustomerID;

        Estimating Unique Purchase Dates:

        • Estimate the number of unique purchase dates in the dataset:
        SELECT 
            APPROX_COUNT_DISTINCT(PurchaseDate) AS EstimatedUniquePurchaseDates
        FROM CustomerTransactions;
        

        Regional Sales Analysis:

        • If the dataset includes a region column, estimate unique customers per region:
        SELECT 
            Region,
            APPROX_COUNT_DISTINCT(CustomerID) AS EstimatedUniqueCustomers
        FROM CustomerTransactions
        GROUP BY Region;

        Conclusion 🏁

        The APPROX_COUNT_DISTINCT function in SQL Server 2022 is a powerful tool for quickly estimating the number of distinct values in large datasets. This function is particularly useful in big data scenarios where performance and resource efficiency are crucial. By leveraging APPROX_COUNT_DISTINCT, businesses can gain rapid insights into customer behavior, product diversity, and other key metrics, enabling more informed decision-making. Whether you’re analyzing e-commerce data, customer segmentation, or product sales, this function offers a robust solution for your data analysis needs. Happy querying! πŸŽ‰

        For more tutorials and tips on SQL Server, including performance tuning and database management, be sure to check out our JBSWiki YouTube channel.

        Thank You,
        Vivek Janakiraman

        Disclaimer:
        The views expressed on this blog are mine alone and do not reflect the views of my company or anyone else. All postings on this blog are provided β€œAS IS” with no warranties, and confers no rights.