Skip to content

Bits of .NET

Daily micro-tips for C#, SQL, performance, and scalable backend engineering.

  • Asp.Net Core
  • C#
  • SQL
  • JavaScript
  • CSS
  • About
  • ErcanOPAK.com
  • No Access
  • Privacy Policy
SQL

Find numbers with more than two decimal places in SQL

- 02.06.18 | 24.03.26 - ErcanOPAK

The Problem: In financial databases, you often expect values to have exactly two decimal places (e.g., $10.50). However, due to bulk imports or rounding errors, “hidden” decimals like 10.50001 can creep into your tables. These tiny fractions can cause massive discrepancies in your total sums and reports.

The Smart Solution: Instead of slow string parsing, we use a brilliant mathematical trick involving the FLOOR function to identify any value that has more than two active decimal places.


🚀 The Performance-First Query

This query identifies any record where the data exceeds the standard two-decimal limit. It works by shifting the decimal point and comparing the result to its rounded floor:

-- Find records with more than 2 decimal places
SELECT Amount 
FROM YourSQLTable 
WHERE FLOOR(Amount * 100) <> Amount * 100;

/* Example Matches:
   - 42473.7399  --> Detected!
   - 448.899     --> Detected!
   - 10.50       --> Ignored (Correct)
*/

🔍 How the Math Works (The Logic)

This approach is significantly faster than using CAST as VARCHAR. Here is why it works:

  1. Multiply by 100: We shift the decimal two places to the right (e.g., 10.507 becomes 1050.7).
  2. The FLOOR Check: The FLOOR function removes the remaining decimals (making it 1050).
  3. The Comparison: If the “Floored” version is NOT equal to the “Multiplied” version, it means there was extra data beyond those two places.

đź’ˇ Pro Tip: Cleaning the Data

Once you find these “dirty” records, you can fix them instantly using a ROUND update. Be careful with financial data before running this!

-- Fix the hidden decimals by rounding to 2 places
UPDATE YourSQLTable 
SET Amount = ROUND(Amount, 2) 
WHERE FLOOR(Amount * 100) <> Amount * 100;

Summary

Data integrity is the backbone of reliable reporting. Using mathematical logic instead of string manipulation keeps your queries fast and your database clean. Use this audit query regularly to catch rounding bugs before they hit your balance sheet!

Related posts:

SQL “Slow Pagination” — The Secret Trick: Seek Method

SQL Query to Find and Replace text in a stored procedures

How to reset identity seed after deleting records in SQL

Post Views: 448

Post navigation

How to change ReportViewer Date Format
Hide GridView Column on server-side

Leave a Reply Cancel reply

Your email address will not be published. Required fields are marked *

April 2026
M T W T F S S
 12345
6789101112
13141516171819
20212223242526
27282930  
« Mar    

Most Viewed Posts

  • Get the User Name and Domain Name from an Email Address in SQL (950)
  • How to add default value for Entity Framework migrations for DateTime and Bool (859)
  • Get the First and Last Word from a String or Sentence in SQL (836)
  • How to select distinct rows in a datatable in C# (805)
  • How to make theater mode the default for Youtube (754)
  • Add Constraint to SQL Table to ensure email contains @ (578)
  • How to enable, disable and check if Service Broker is enabled on a database in SQL Server (564)
  • Average of all values in a column that are not zero in SQL (531)
  • How to use Map Mode for Vertical Scroll Mode in Visual Studio (489)
  • Find numbers with more than two decimal places in SQL (448)

Recent Posts

  • C#: Use Init-Only Setters for Immutable Objects After Construction
  • C#: Use Expression-Bodied Members for Concise Single-Line Methods
  • C#: Enable Nullable Reference Types to Eliminate Null Reference Exceptions
  • C#: Use Record Types for Immutable Data Objects
  • SQL: Use CTEs for Readable Complex Queries
  • SQL: Use Window Functions for Advanced Analytical Queries
  • .NET Core: Use Background Services for Long-Running Tasks
  • .NET Core: Use Minimal APIs for Lightweight HTTP Services
  • Git: Use Cherry-Pick to Apply Specific Commits Across Branches
  • Git: Use Interactive Rebase to Clean Up Commit History Before Merge

Most Viewed Posts

  • Get the User Name and Domain Name from an Email Address in SQL (950)
  • How to add default value for Entity Framework migrations for DateTime and Bool (859)
  • Get the First and Last Word from a String or Sentence in SQL (836)
  • How to select distinct rows in a datatable in C# (805)
  • How to make theater mode the default for Youtube (754)

Recent Posts

  • C#: Use Init-Only Setters for Immutable Objects After Construction
  • C#: Use Expression-Bodied Members for Concise Single-Line Methods
  • C#: Enable Nullable Reference Types to Eliminate Null Reference Exceptions
  • C#: Use Record Types for Immutable Data Objects
  • SQL: Use CTEs for Readable Complex Queries

Social

  • ErcanOPAK.com
  • GoodReads
  • LetterBoxD
  • Linkedin
  • The Blog
  • Twitter
© 2026 Bits of .NET | Built with Xblog Plus free WordPress theme by wpthemespace.com