European Windows 2012 Hosting BLOG

BLOG about Windows 2012 Hosting and SQL 2012 Hosting - Dedicated to European Windows Hosting Customer

SQL Server Hosting - HostForLIFE :: Understanding Change Data Capture (CDC) and Its Types

clock April 24, 2025 09:05 by author Peter

Imagine you have a large database that stores customer orders, and you need to keep another system like a reporting dashboard — updated in real-time. Instead of repeatedly scanning the entire database for changes, which is inefficient, you can use Change Data Capture (CDC). CDC is a technique that tracks changes made to a database and ensures they are captured and passed on to other systems efficiently. It helps keep data in sync without causing a heavy load on the database.

Why Does CDC Matter?

  • Reduces System Load: Instead of checking all records, CDC tracks only what has changed.
  • Ensures Data Synchronization: Keeps different databases or applications in sync with real-time updates.
  • Enhances Performance: Speeds up data processing and reduces unnecessary computations.
  • Supports Real-Time Analytics: Enables event-driven architectures and live dashboards.

Different Types of Change Data Capture
There are multiple ways to implement CDC, and the right approach depends on your system’s needs. Let’s look at the common types:

1. Trigger-Based CDC
This method uses database triggers, which are special rules that get executed when data changes. Whenever a row is inserted, updated, or deleted, the trigger captures this change and logs it in an audit table.


When to Use:

  • If your database does not support log-based CDC.
  • When you need to maintain a detailed history of changes

Pros:

  • Works even if your database doesn’t have built-in CDC features.
  • Provides a complete history of data changes.

Cons:

  • Can slow down database operations since triggers add extra processing.
  • Increases database complexity with additional tables and logic.

2. Log-Based CDC
This approach reads the database transaction logs — the records of every change made to the database. Instead of modifying the database structure, it monitors changes at the system level.


When to Use:

  • When you need real-time CDC with minimal performance impact.
  • When dealing with high-volume transactional databases.

Pros:

  • Has the least impact on database performance.
  • Efficient for handling large data volumes.

Cons:
Requires access to database transaction logs, which not all databases allow.
More complex to set up and configure.

3. Timestamp-Based CDC
This method relies on a timestamp column (like “LastUpdated”) to identify changed records. When a query runs, it fetches all rows where the timestamp is newer than the last sync.

When to Use:

  • If your tables already have a “Last Updated” timestamp column.
  • When you need a simple CDC method without extra database configurations.

Pros:

  • Easy to implement.
  • No need for additional infrastructure.

Cons:

  • Requires timestamps to be updated accurately, or changes might be missed.
  • Not ideal for real-time processing, as it relies on scheduled queries.

4. Table Differencing (Snapshot-Based CDC)
In this approach, periodic snapshots of the entire table are compared to detect differences. Changes are identified by comparing the current state to a previous snapshot.

When to Use:

  • When other CDC methods are not feasible.
  • When working with small datasets where performance impact is minimal.

Pros:

  • Works with any database, even those without CDC support.
  • No need to modify the database structure.

Cons:

  • Requires scanning the entire table, which can be slow.
  • Not suitable for large datasets or real-time updates.

5. Hybrid CDC
A combination of multiple CDC methods to balance performance and accuracy. For example, log-based CDC might be used for real-time changes, while timestamp-based CDC acts as a fallback.

When to Use:

  • When handling complex architectures with different data sources.
  • When optimizing for both real-time and periodic data updates.

Pros:

  • Offers flexibility to choose the best method per use case.
  • Can improve reliability and accuracy.

Cons:
Requires a more complex setup and maintenance.

Conclusion
Choosing the right CDC method depends on factors like performance needs, database capabilities, and update frequency. Log-based CDC is preferred for real-time, high-volume systems, while timestamp-based CDC is a quick solution for simple use cases. Trigger-based CDC is useful when detailed change tracking is required, and table differencing can be a last resort when no other options are available. By selecting the right CDC approach, businesses can keep their data synchronized efficiently, enabling faster decision-making and better performance across applications.

HostForLIFE.eu SQL Server 2022 Hosting
HostForLIFE.eu is European Windows Hosting Provider which focuses on Windows Platform only. We deliver on-demand hosting solutions including Shared hosting, Reseller Hosting, Cloud Hosting, Dedicated Servers, and IT as a Service for companies of all sizes.



SQL Server Hosting - HostForLIFE :: SQL Query Execution Process vs. Stored Procedures

clock April 22, 2025 07:14 by author Peter

In SQL Server, a lot goes on behind the scenes when you execute a query or invoke a stored procedure. We'll use a special visual model to explain how SQL Server handles both.

The Four Primary Steps Each Query Takes
Whether it's an Normal SQL query or a stored procedure, SQL Server follows the same general flow.

  • Parsing: SQL Server checks for typos and turns your query into a tree structure it can understand.
  • Algebrizing: It links your query to actual tables and columns, and checks for things like permissions.
  • Optimization: SQL Server builds a plan for how it thinks the query should run choosing indexes, join types, etc.
  • Execution: It runs the plan and returns the results.

The Plan Cache: SQL Server’s Memory Trick
To save time, SQL Server stores execution plans in memory (called the plan cache). If a query or procedure has already been run, SQL Server can reuse that plan instead of making a new one.

  • Raw SQL Query: SQL Server saves each unique query. Even small changes (like a space or value) create a new plan.
  • Stored procedures: These are compiled once and reused, so they’re better at plan reuse.

Inside the SQL Server Engine
Let’s break down the key parts involved in running queries.

  • Plan Cache: Stores execution plans.
  • Buffer Pool: Stores data pages from disk in memory so SQL Server can access them quickly.
  • Execution Engine: The part that actually runs the query plan and processes the data.

Normal SQL query and stored procedures both use all these pieces, but stored procedures often make better use of caching.

Examples
Raw SQL Query.
SELECT * FROM Orders WHERE CustomerID = 'PETER';

Equivalent Stored Procedure.
CREATE PROCEDURE sp_GetOrdersByCustomer
    @CustomerID NVARCHAR(5)
AS
BEGIN
    SELECT * FROM Orders WHERE CustomerID = @CustomerID;
END;

Running this many times with different values.

  • The Normal SQL query version creates multiple plans.
  • The stored procedure reuses the same plan with different values.

Side-by-Side Execution Flow

Note: Unless there are schema updates or recompilation triggers, stored procedures bypass parsing, name resolution, and optimization after the initial execution.

Key Differences

Step Raw SQL Query Stored Procedure
Parsing Every time Once
Algebrizing (name resolution) Every time Once
Optimization Every time Once (plan is cached)
Plan Cache Usage Optional (based on parameterization) Always cached
Security Less secure (SQL injection risk) More secure
Performance Slower for repeated queries Faster due to plan reuse

Conclusion

Scenario Best Approach
Dynamic filters or one-off queries Raw SQL Query
Repeated logic, reporting, automation Stored Procedure
Need security, performance, versioning Stored Procedure

Normal SQL queries and stored procedures both help us get data from the database, but they work differently behind the scenes. While both stored procedures and standard SQL queries assist us in retrieving data from the database, their inner workings differ. Every time a standard query is executed, it undergoes parsing, verification, and planning. This is done only once using a stored process, which also saves the plan for later usage, making it faster. When you need to execute the same logic repeatedly or want greater control and security, stored procedures are preferable. Writing better, faster, and safer SQL code is made possible by understanding how both are handled.

HostForLIFE.eu SQL Server 2022 Hosting
HostForLIFE.eu is European Windows Hosting Provider which focuses on Windows Platform only. We deliver on-demand hosting solutions including Shared hosting, Reseller Hosting, Cloud Hosting, Dedicated Servers, and IT as a Service for companies of all sizes.



SQL Server Hosting - HostForLIFE :: Introduction to SQL Server & Its History

clock April 15, 2025 09:01 by author Peter

What is a SQL Server?
Microsoft's SQL Server solution is intended for data management and storage. Imagine it as a digital filing cabinet that is extremely well-organized. Any software or application that requires information sends a request to SQL Server to extract the information. Because of its large data processing capacity, it may be applied to both small and large projects.

A Brief History of SQL Server
SQL Server was first brought to the market by Microsoft back in 1989. This was developed at that time in cooperation with another company named Sybase. Since then, it has gone through lots of changes. Each new version brought several enhancements. Here are some of the significant ones.

  • SQL Server 2000: This version made SQL Server more web-friendly by including the support for XML and HTTP.
  • SQL Server 2005: Provides a utility called SQL Server Management Studio, which provides easier database management. SQL Server 2008: Some new features introduced were the enhancement of management tools and the introduction of new data types to work with. SQL Server 2012: Its powerful features were AlwaysOn Availability Groups, which keep your databases running, and improved security.
  • SQL Server 2016: Extended its functionality to support operation on Linux systems and added real-time data analytics.
  • SQL Server 2019: Added big data clusters, among other advanced features, to handle even more complex data needs of the users.
  • SQL Server 2022: The latest release, whose primary focus is on the speed, security, and manageability of the instances. It has added features like Accelerated Database Recovery.

As of February 2024, the following versions of SQL Server are supported by Microsoft:

  • SQL Server 2014
  • SQL Server 2016
  • SQL Server 2017
  • SQL Server 2019
  • SQL Server 2022

Key Features of SQL Server

  • High Availability: Ensure that your data is always available with advanced features like Always On Availability Groups.
  • Security: It secures your data by providing it with advanced security attributes, including encryption and row-level security.
  • Performance: Equips you with the tools that can make your database more rapid and effective.
  • Scalability: Can handle more volumes of data and a large number of users at the same time.
  • Integration: Augments well with reporting and data-processing-like, like SQL Server Reporting Services-SSRS and SQL Server Integration Services-SSIS.
  • Cloud Support: This can be deployed on the cloud for the management of data across more than one environment; one such example is Microsoft Azure.

Management Studio for SQL Server (SSMS)
One tool for managing SQL Server is called SQL Server Management Studio, or SSMS for short. You can set up, monitor, and administer your databases with ease thanks to its incredibly user-friendly interface. In actuality, the importance of SSMS for all SQL Server users—from developers to database administrators—cannot be overstated.

How to Connect to SQL Server?
Connecting to SQL Server is the first step to managing your databases. Here’s a quick guide on how to do it.

  • Choose Your Tool: You can use SSMS, Azure Data Studio, or even programming languages like C#, Java, or Python.
  • Get Your Connection Info: You’ll need the server name or IP address and your login details.
  • Using SSMS
    • Open SSMS.
    • Enter the server name and your authentication method (like a username and password).
    • Click "Connect."
  • Using a Programming Language
    • Install the necessary libraries or drivers.
    • Use a connection string to link to SQL Server. Here’s an example in C#.

using System;
using System.Data.SqlClient;

class Program
{
    static void Main()
    {
        // Connection details for the SQL Server
        string connectionString = "Server=myServerAddress;Database=myDataBase;User Id=myUsername;Password=myPassword;";

        // Creating a connection to the database
        using (SqlConnection connection = new SqlConnection(connectionString))
        {
            try
            {
                // Try to open the connection
                connection.Open();
                Console.WriteLine("Successfully connected to SQL Server!");
            }
            catch (Exception ex)
            {
                // If something goes wrong, show the error message
                Console.WriteLine("Error: " + ex.Message);
            }
        } // Connection gets automatically closed here
    }
}


Test the Connection: Once connected, you can run queries or perform database operations to ensure everything is working correctly.

A Look at the SSMS Interface

  • SSMS is very user-friendly and will enable you to conveniently manage SQL Server databases. Some key components are.
  • Object Explorer: On the left-hand side, it provides a tree view of your databases and server objects.
  • Query Editor: Centre, this is where you write and execute your SQL queries.
  • Properties Window: This usually appears at the bottom right and contains details about the currently selected object.
  • Solution Explorer: Solution Explorer is used to organize our SQL projects and scripts. Registered Servers: Under one instance, we can manage multiple SQL Server instances. Template Explorer: This comes with ready-to-use templates of SQL statements for several routine actions.

Conclusion
SQL Server is a tremendous, robust platform for working with data, from small projects to the enterprise-level business. Throughout the years, it increased its functionality by adding a bunch of neat features that helped people store and protect their data, and work with it. With tools like SQL Server Management Studio, database management has become pretty straightforward. Whether you are starting to work with SQL Server or need to know a bit more about what it can achieve, it will provide all you could want to handle your data well. With the basics now explained to you, you're ready to explore more and make the most of SQL Server.

HostForLIFE.eu SQL Server 2022 Hosting
HostForLIFE.eu is European Windows Hosting Provider which focuses on Windows Platform only. We deliver on-demand hosting solutions including Shared hosting, Reseller Hosting, Cloud Hosting, Dedicated Servers, and IT as a Service for companies of all sizes.



SQL Server Hosting - HostForLIFE :: Comprehending SQL Numerical Functions

clock April 8, 2025 09:56 by author Peter

SQL provides various numeric functions that help perform mathematical operations on numeric data. These functions are useful for calculations, rounding, and other numerical transformations.

Common Numeric Functions

  • ABS(): Returns the absolute value of a number.
  • CEILING(): Rounds a number up to the nearest integer.
  • FLOOR(): Rounds a number down to the nearest integer.
  • ROUND(): Rounds a number to a specified number of decimal places.
  • POWER(): Returns the value of a number raised to a given power.
  • SQRT(): Returns the square root of a number.
  • EXP(): Returns the exponential value of a number.
  • LOG(): Returns the natural logarithm of a number.
  • LOG10(): Returns the base-10 logarithm of a number.
  • RAND(): Returns a random float value between 0 and 1.
  • SIGN(): Returns the sign of a number (-1, 0, or 1).
  • PI(): Returns the value of PI (3.14159265358979).
  • DEGREES(): Converts radians to degrees.
  • RADIANS(): Converts degrees to radians.
  • MOD(): Returns the remainder of a division.
  • TRUNCATE(): Truncates a number to a specified decimal place.

Example Usage of Numeric Functions
1. Using ABS() Function
SELECT ABS(-15) AS AbsoluteValue;

2. Using CEILING() and FLOOR() Functions
SELECT CEILING(4.3) AS CeilValue, FLOOR(4.7) AS FloorValue;

Output

CeilValue FloorValue
5 4

3. Using ROUND() and TRUNCATE() Functions
SELECT ROUND(123.456, 2) AS RoundedValue, TRUNCATE(123.456, 2) AS TruncatedValue;

Output

RoundedValue TruncatedValue
123.46 123.45


4. Using POWER() and SQRT() Functions
SELECT POWER(5, 3) AS PowerValue, SQRT(25) AS SquareRoot;

Output

PowerValue SquareRoot
125 5

5. Using MOD() Function
SELECT MOD(10, 3) AS ModResult;

6. Using PI(), DEGREES(), and RADIANS() Functions
SELECT
    PI() AS PiValue,
    DEGREES(PI()) AS DegreesValue,
    RADIANS(180) AS RadiansValue;

Output

PiValue DegreesValue RadiansValue
3.141593 180 3.141593

When to Use Numeric Functions?

  • Financial Calculations: Useful for interest rates, tax calculations, and rounding amounts.
  • Data Analysis: Helps in statistical computations and mathematical transformations.
  • Scientific Computing: Essential for performing complex mathematical calculations.
  • Random Value Generation: Used for sampling, simulations, and random selections.

Advantages of Numeric Functions

  • Simplifies mathematical computations in SQL.
  • Enhances query efficiency by using built-in SQL functions.
  • Provides precise and accurate results for calculations.

Numeric functions play a crucial role in SQL for performing various mathematical operations.

HostForLIFE.eu SQL Server 2022 Hosting
HostForLIFE.eu is European Windows Hosting Provider which focuses on Windows Platform only. We deliver on-demand hosting solutions including Shared hosting, Reseller Hosting, Cloud Hosting, Dedicated Servers, and IT as a Service for companies of all sizes.



SQL Server Hosting - HostForLIFE :: Knowing SQL Scalar Functions

clock March 24, 2025 08:29 by author Peter

Depending on the input values, scalar functions in SQL return a single value. Instead of working with sets of rows, these functions work with individual values.

Common Scalar Functions
LEN(): Returns the length of a string.
UPPER(): Converts a string to uppercase.
LOWER(): Converts a string to lowercase.
ROUND(): Rounds a number to a specified decimal place.
GETDATE(): Returns the current date and time.

Example Usage of Scalar Functions

1. Using LEN() Function

SELECT LEN('Hello World') AS StringLength;

2. Using UPPER() and LOWER() Functions
SELECT UPPER('hello') AS UpperCase, LOWER('WORLD') AS LowerCase;

Output

UpperCase LowerCase
HELLO world

3. Using ROUND() Function
SELECT ROUND(123.456, 2) AS RoundedValue

4. Using GETDATE() Function
SELECT GETDATE() AS CurrentDateTime;

5. Using ABS() Function

SELECT ABS(-25) AS AbsoluteValue;

6. Using SQRT() Function
SELECT SQRT(49) AS SquareRoot;

7. Using SUBSTRING() Function
SELECT SUBSTRING('SQL Functions', 5, 9) AS SubstringResult;

8. Using REPLACE() Function

SELECT REPLACE('Hello SQL', 'SQL', 'World') AS ReplacedString;

Advanced Use of Scalar Functions
1. Combining Scalar Functions

SELECT UPPER(LEFT('advanced scalar functions', 8)) AS Result;

2. Using Scalar Functions in Computations
SELECT ROUND(AVG(Salary), 2) AS AverageSalary FROM Employees;

3. Formatting Dates Using Scalar Functions
SELECT FORMAT(GETDATE(), 'yyyy-MM-dd') AS FormattedDate;

4. Custom Scalar Function Example
CREATE FUNCTION dbo.Getfullname(@FirstName NVARCHAR(50),
                                @LastName  NVARCHAR(50))
returns NVARCHAR(100)
AS
  BEGIN
      RETURN ( @FirstName + ' ' + @LastName )
  END;


Usage
SELECT dbo.GetFullName('John', 'Doe') AS FullName;

Advantages of Scalar Functions

  • Helps in data formatting and transformation.
  • Improves code readability and maintainability.
  • Enhances query flexibility with built-in SQL functions.

Scalar functions are essential for manipulating individual values in SQL queries.

HostForLIFE.eu SQL Server 2022 Hosting
HostForLIFE.eu is European Windows Hosting Provider which focuses on Windows Platform only. We deliver on-demand hosting solutions including Shared hosting, Reseller Hosting, Cloud Hosting, Dedicated Servers, and IT as a Service for companies of all sizes.



SQL Server Hosting - HostForLIFE :: Comprehending SQL Execution Plans

clock March 21, 2025 08:04 by author Peter

A roadmap that describes how a query will be run is called a SQL Execution Plan. It aids in SQL query analysis and optimization.

Execution Plan Types

Estimated Execution Plan: This illustrates how the query would function even if it were not run.
Actual Execution Plan: This displays runtime information along with the query's actual execution.

How to Get the Execution Plan?
Using SQL Server Management Studio (SSMS)

Estimated Execution Plan: Press Ctrl + L or go to Query > Display Estimated Execution Plan.

Actual Execution Plan: Press Ctrl + M or go to Query > Include Actual Execution Plan, then run the query.

Using T-SQL Commands

Estimated Execution Plan
SET SHOWPLAN_XML ON;
SELECT * FROM Users WHERE UserID = 1;
SET SHOWPLAN_XML OFF;

Actual Execution Plan
SET STATISTICS XML ON;
SELECT * FROM Users WHERE UserID = 1;
SET STATISTICS XML OFF;

Understanding Execution Plan Components

Component Description
Table Scan Reads all rows from a table (slow for large tables).
Index Seek Efficiently retrieves data using an index.
Index Scan Reads the entire index (better than Table Scan but still expensive).
Nested Loops Join Good for small datasets but slow for large joins.
Hash Join Suitable for large datasets, uses hashing for joins.
Sort Operator Sorts data but can be expensive.
Key Lookup Retrieves extra columns from the clustered index (can slow down queries).

Tips to Optimize SQL Queries

Use Indexes: Create indexes on frequently used columns.
Avoid SELECT *: Retrieve only the required columns.
Optimize Joins: Prefer INNER JOIN over OUTER JOIN if possible.
Check Execution Plan: Avoid Table Scans and use Index Seeks.
Avoid Functions on Indexed Columns: Example: WHERE YEAR(DateColumn) = 2023 prevents index usage.

In the next part, we will dive deeper into SQL execution plans, covering advanced topics like operator costs, parallelism, query hints, and execution plan caching, helping you gain a more comprehensive understanding of how SQL Server processes queries efficiently. Stay tuned!

HostForLIFE.eu SQL Server 2022 Hosting
HostForLIFE.eu is European Windows Hosting Provider which focuses on Windows Platform only. We deliver on-demand hosting solutions including Shared hosting, Reseller Hosting, Cloud Hosting, Dedicated Servers, and IT as a Service for companies of all sizes.



SQL Server Hosting - HostForLIFE :: Understanding Precision in SQL Server Calculations

clock March 20, 2025 08:38 by author Peter

Statement of the Problem
Numerous database developers run into unforeseen inconsistencies while using SQL Server for calculations.  When the same mathematical phrase is evaluated differently, one typical problem occurs.  Take the following SQL Server code snippet, for example:

DECLARE @Number1 AS DECIMAL(26,7) = 0.9009000;
DECLARE @Number2 AS DECIMAL(26,7) = 1.000000000;
DECLARE @Number3 AS DECIMAL(26,7) = 1000.00000000;
DECLARE @Result  AS DECIMAL(26,7);

SET @Result = (@Number1 * @Number2) / @Number3;
SELECT @Result; -- 0.0009000
SET @Result = (@Number1 * @Number2);
SET @Result = (@Result / @Number3);
SELECT @Result; -- 0.0009009


In the first case, the output is 0.0009000, while in the second case, the output is 0.0009009. This divergence raises the question: Why are the results different when the same calculation is performed?

Explanation. Single Step Calculation

In the first approach, the entire expression (@Number1 * @Number2) / @Number3 is computed in a single step:

SQL Server first computes the product of @Number1 and @Number2, which equals 0.9009000.
Next, it divides that result by @Number3 (1000.00000000).

The result of this division is affected by how SQL Server handles precision and rounding for decimal operations. This might introduce slight inaccuracies, leading to the outcome of 0.0009000.

Multiple Step Calculation

In the second approach, the operations are separated into two distinct steps:

First, the calculation @Number1 * @Number2 is executed and stored in @Result. This retains the value of 0.9009000.
Then, the variable @Result is divided by @Number3 in a separate statement.

This step-by-step division allows SQL Server to apply different rounding and precision rules, which can sometimes yield a more accurate result of 0.0009009.

Conclusion

The difference in outputs can often be attributed to the varying treatment of precision and rounding during calculations:

  • In a single-step calculation, SQL Server evaluates the entire expression at once, potentially altering precision during the process.
  • In a multiple-step calculation, SQL Server retains more precision through intermediate results, leading to a different output.

Resolution
To achieve consistent results in SQL Server calculations, developers should consider controlling precision explicitly. For example, applying rounding can help standardize outcomes:
SET @Result = ROUND((@Number1 * @Number2) / @Number3, 7);

By managing precision and rounding explicitly, programmers can avoid discrepancies and ensure that their numerical calculations yield the expected results. Understanding these nuances in SQL Server can lead to more reliable and accurate database operations.

HostForLIFE.eu SQL Server 2022 Hosting
HostForLIFE.eu is European Windows Hosting Provider which focuses on Windows Platform only. We deliver on-demand hosting solutions including Shared hosting, Reseller Hosting, Cloud Hosting, Dedicated Servers, and IT as a Service for companies of all sizes.




SQL Server Hosting - HostForLIFE :: Improve the Performance of SQL Server with Memory-Optimized Tables

clock March 11, 2025 09:03 by author Peter

A Memory-Optimized Table Variable: What Is It?
A unique kind of table variable that makes use of SQL Server's In-Memory OLTP engine is called a Memory-Optimized Table Variable. It is maintained in memory, which lowers tempdb contention and improves performance for workloads involving frequent data processing, in contrast to ordinary table variables or temporary tables (#temp).

Why is it Useful?
Memory-Optimized Table Variables provide.

  • Faster performance: Avoids disk I/O by keeping data in memory.
  • Tempdb contention reduction: Traditional temp tables and table variables rely on tempdb, which can be a bottleneck.
  • Optimized latch-free concurrency: Uses memory-optimized data structures for ultra-fast access.
  • Efficient for short-lived data: Ideal for scenarios where data exists only within a session or batch.

When to Use It?
You should use Memory-Optimized Table Variables when,

  • Your queries experience tempdb contention.
  • You perform frequent batch operations with temporary data.
  • You need high-performance OLTP workloads with frequent inserts and lookups.
  • You are working with stored procedures that rely on table variables.

Where to Use It?

  • Stored procedures that process intermediate data.
  • ETL workloads require temporary staging tables.
  • High-performance transaction processing systems.
  • Session-based data caching to avoid repeated database calls.

How to Use a Memory-Optimized Table Variable?
1. Enable Memory-Optimized Tables in the Database
Before using memory-optimized table variables, you must enable In-Memory OLTP.

ALTER DATABASE YourDatabase
ADD FILEGROUP MemoryOptimizedFG CONTAINS MEMORY_OPTIMIZED_DATA;

ALTER DATABASE YourDatabase
ADD FILE (NAME = 'MemOptData', FILENAME = 'C:\Data\MemOptData')
TO FILEGROUP MemoryOptimizedFG;


2. Declare a Memory-Optimized Table Variable
Unlike a regular table variable, you must use MEMORY_OPTIMIZED = ON.
DECLARE @MemOptTable TABLE
(
ID INT NOT NULL PRIMARY KEY NONCLUSTERED,
Name NVARCHAR(100) NOT NULL
) WITH (MEMORY_OPTIMIZED = ON);

3. Insert and Query Data Efficiently
INSERT INTO @MemOptTable (ID, Name) VALUES (1, 'SQL Server'), (2, 'DBA Expert');

SELECT * FROM @MemOptTable;


4. Compare with Traditional Table Variables
A traditional table variable.
DECLARE @TableVar TABLE (ID INT, Name NVARCHAR(100));

Uses tempdb, causing I/O overhead.
Suffers from locking and latching under high concurrency.

Memory-Optimized Table Variables

  • Avoid tempdb entirely.
  • Are lock-free and latch-free, making them 10x faster in some cases.

Real-Time Example: Improving Performance in a High-Traffic System

  • Scenario: A banking application processes thousands of real-time transactions per second. Using traditional table variables slows down the system due to tempdb contention.
  • Solution: By replacing standard table variables with Memory-Optimized Table Variables, the system eliminates tempdb bottlenecks, resulting in a 40% faster transaction processing time.

DECLARE @TransactionLog TABLE
(
TransactionID INT NOT NULL PRIMARY KEY NONCLUSTERED,
AccountID INT NOT NULL,
Amount DECIMAL(10,2) NOT NULL
) WITH (MEMORY_OPTIMIZED = ON);

Memory-optimized table Variables were introduced in SQL Server 2016 and are available in the following versions.
Compatible SQL Server Versions
SQL Server 2016 (13.x)
SQL Server 2017 (14.x)
SQL Server 2019 (15.x)
SQL Server 2022 (16.x)

Not Available In
SQL Server 2014 and earlier (Memory-optimized tables were introduced in 2014, but table variables were not supported as memory-optimized until 2016).

Best Practices & Recommendations
Enable In-Memory OLTP before using Memory-Optimized Table Variables.
Use them in stored procedures or batch processing scenarios for best performance.
Avoid using them for large datasets due to memory limitations.
Use Non-Clustered Indexes properly to avoid performance bottlenecks.
Test with different workloads before applying in production environments.

HostForLIFE.eu SQL Server 2022 Hosting
HostForLIFE.eu is European Windows Hosting Provider which focuses on Windows Platform only. We deliver on-demand hosting solutions including Shared hosting, Reseller Hosting, Cloud Hosting, Dedicated Servers, and IT as a Service for companies of all sizes.



SQL Server Hosting - HostForLIFE :: Efficient SQL Query to Remove Duplicates with ROW_NUMBER

clock March 6, 2025 07:04 by author Peter

Using ROW_NUMBER() and PARTITION BY (Preferred Approach)
The ROW_NUMBER() function assigns a unique row number to each record within a partition (group). We can use this to identify and delete duplicates while keeping only the required data.

Query Syntax
WITH CTE AS (
    SELECT
        *,
        ROW_NUMBER() OVER (PARTITION BY column1, column2 ORDER BY id) AS row_num
    FROM table_name
    WHERE condition  -- Apply filtering condition here
)
DELETE FROM CTE
WHERE row_num > 1;


Example
Consider a Customer table with duplicate entries based on Email.

ID Name Email City
1 John [email protected] NY
2 Jane [email protected] LA
3 John [email protected] NY
4 Sam [email protected] TX

Removing Duplicates While Keeping the First Entry.

;WITH CTE AS (
    SELECT ID
    FROM (
        SELECT ID,
               ROW_NUMBER() OVER (PARTITION BY NAME, Email, City ORDER BY ID) AS RN
        FROM Customers
        WHERE City = 'NY'  -- Only NY state filtering condition
    ) AS sub
    WHERE RN > 1
)
DELETE FROM Customers
WHERE ID IN (SELECT ID FROM CTE);


Explanation of the Query
Identifies Duplicates

  • ROW_NUMBER() OVER (PARTITION BY Name, Email, City ORDER BY ID)
  • Assign a row number (RN) for each duplicate group, keeping the first record (RN = 1).

Filters Out Duplicates (RN > 1): Only marks duplicate records where City = 'NY'.
Deletes Duplicate Records: Deletes only IDs from the CTE that have RN > 1
This syntax will be useful when we are joining more tables and deleting duplicates from one specific table.

HostForLIFE.eu SQL Server 2022 Hosting
HostForLIFE.eu is European Windows Hosting Provider which focuses on Windows Platform only. We deliver on-demand hosting solutions including Shared hosting, Reseller Hosting, Cloud Hosting, Dedicated Servers, and IT as a Service for companies of all sizes.

 



SQL Server Hosting - HostForLIFE :: Using Tablock to Unlock Faster INSERT Operations in SQL Server

clock February 13, 2025 07:29 by author Peter

Performance is frequently the main issue in any SQL Server system when working with big datasets. The INSERT operation is one frequent operation that occasionally turns into a bottleneck. The time required to input data increases with its size, which can have a major effect on system performance and user experience in general. The usage of the TABLOCK hint is one of the many methods and improvements that SQL Server offers to help speed up data insertions. When working with huge datasets or when parallelism is crucial, this straightforward yet effective method can significantly increase the pace of your INSERT operations.

What is the TABLOCK Hint?
The TABLOCK hint is a table-level lock hint that forces SQL Server to take a schema modification (Sch-M) lock on the target table when performing an INSERT, UPDATE, or DELETE operation. This hint ensures that the table is locked for the duration of the operation, which can help speed up data loading by minimizing logging and reducing contention.

A key benefit of the TABLOCK hint is that it reduces the amount of log space used during the operation, as the minimal logging mechanism is activated. This means that SQL Server does not have to log each individual row insertion, but rather just the metadata for the bulk operation. As a result, this significantly reduces the overhead and speeds up data loading.

Additionally, because the table is locked at the schema level, it allows SQL Server to parallelize the operation, leading to faster execution times. This is particularly useful for large-scale data-loading tasks.

When to Use TABLOCK Hint

The TABLOCK hint is ideal for scenarios where:

  • You are inserting a large number of rows into a table.
  • You can afford to lock the table for the duration of the operation (i.e., no other transactions need access to the table while the insert is in progress).
  • You want to reduce the logging overhead and speed up bulk insertions.
  • You want to use parallel insertions to take advantage of SQL Server's ability to use multiple threads for data loading.

It’s also important to note that the TABLOCK hint works well with temporary tables, so you can take advantage of these performance benefits when working with temp tables, often used in ETL processes or batch operations.

Benefits of Using TABLOCK

  • Improved Performance: The primary benefit of using the TABLOCK hint is the performance improvement during large INSERT operations. By reducing the amount of logging, SQL Server can insert rows much faster.
  • Parallel Insertion: With TABLOCK, SQL Server can use parallelism to load the data, speeding up the operation of systems with sufficient resources.
  • Reduced Logging Overhead: Since SQL Server logs less information, the system consumes less log space, which can be crucial when working with large datasets.
  • Works with Temp Tables: You can apply TABLOCK to temporary tables as well, giving you the same performance benefits for in-memory operations.

Example
Let’s consider a scenario where we need to insert a large number of rows from the Sales.SalesOrderDetail table into the Sales.SalesOrderDetailTemp table in the HostForLIFE database.
Create table script for Sales.SalesOrderDetailTem
USE [HostForLIFE]
GO

DROP TABLE IF EXISTS [Sales].[SalesOrderDetailTemp]
GO

SET ANSI_NULLS ON
GO

SET QUOTED_IDENTIFIER ON
GO

CREATE TABLE [Sales].[SalesOrderDetailTemp](
    [SalesOrderID] [int] NOT NULL,
    [SalesOrderDetailID] [int] NOT NULL,
    [CarrierTrackingNumber] [nvarchar](25) NULL,
    [OrderQty] [smallint] NOT NULL,
    [ProductID] [int] NOT NULL,
    [SpecialOfferID] [int] NOT NULL,
    [UnitPrice] [money] NOT NULL,
    [UnitPriceDiscount] [money] NOT NULL,
    [LineTotal]  [money] NULL,
    [rowguid] [uniqueidentifier] ROWGUIDCOL  NOT NULL,
    [ModifiedDate] [datetime] NOT NULL,
 CONSTRAINT [PK_SalesOrderDetailTemp_SalesOrderID_SalesOrderDetailTempID] PRIMARY KEY CLUSTERED
(
    [SalesOrderID] ASC,
    [SalesOrderDetailID] ASC
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON, OPTIMIZE_FOR_SEQUENTIAL_KEY = OFF) ON [PRIMARY]
) ON [PRIMARY]
GO


Without the TABLOCK hint, this operation may take a considerable amount of time, especially when the table is large and the database is under load.

Here’s a basic example of how you can speed up the INSERT operation by using the TABLOCK hint.
USE HostForLIFE
GO

SET STATISTICS TIME, IO ON

SET NOCOUNT ON

INSERT INTO Sales.SalesOrderDetailTemp
SELECT *
FROM Sales.SalesOrderDetail;


Truncate the table.
USE HostForLIFE
GO

TRUNCATE TABLE Sales.SalesOrderDetailTemp


Now, let’s modify the query to use the TABLOCK hint.
USE HostForLIFE
GO

SET STATISTICS TIME, IO ON

SET NOCOUNT ON

INSERT INTO Sales.SalesOrderDetailTemp
WITH (TABLOCK)
SELECT *
FROM Sales.SalesOrderDetail;


Comparison
Execution 1 (without TABLOCK) took longer, with higher CPU and elapsed time (204 ms and 284 ms), indicating a slower operation. Execution 2 (with TABLOCK) performed better, completing in 125 ms CPU time and 157 ms elapsed time, making the TABLOCK version more efficient in this case.

Considerations When Using TABLOCK

While the TABLOCK hint can greatly improve performance, it’s important to be aware of some considerations:

  • Table Locking: The TABLOCK hint locks the entire table for the duration of the operation. This means that other transactions cannot access the table until the INSERT operation is complete, so be sure that this behavior aligns with your application’s requirements.
  • Transaction Log Growth: Although TABLOCK reduces the amount of logging, it still logs certain details of the operation. If you’re inserting a massive amount of data, you may need to monitor transaction log growth and ensure that you have enough log space available.
  • Not Suitable for OLTP Workloads: The TABLOCK hint is more suited to batch operations or bulk-loading scenarios. It may not be appropriate for transactional systems that require frequent concurrent access to the table.

Conclusion
If you are working with large datasets and want to speed up your INSERT operations in SQL Server, the TABLOCK hint can be a game-changer. By reducing logging overhead and enabling parallel insertions, it helps improve performance and can significantly reduce the time it takes to load data.

HostForLIFE.eu SQL Server 2022 Hosting
HostForLIFE.eu is European Windows Hosting Provider which focuses on Windows Platform only. We deliver on-demand hosting solutions including Shared hosting, Reseller Hosting, Cloud Hosting, Dedicated Servers, and IT as a Service for companies of all sizes.



About HostForLIFE.eu

HostForLIFE.eu is European Windows Hosting Provider which focuses on Windows Platform only. We deliver on-demand hosting solutions including Shared hosting, Reseller Hosting, Cloud Hosting, Dedicated Servers, and IT as a Service for companies of all sizes.

We have offered the latest Windows 2016 Hosting, ASP.NET Core 2.2.1 Hosting, ASP.NET MVC 6 Hosting and SQL 2017 Hosting.


Tag cloud

Sign in