Implementation of mysql data type conversion

Implementation of mysql data type conversion

1. Problem

There is a table as shown below, we need to find the data whose result value is greater than the reference_high value

Then we wrote the following SQL query

SELECT i.result,i.reference_high FROM report_item i
LEFT JOIN report r ON r.id=i.report_id 
WHERE r.org_id=54 AND r.report_status=1
AND r.add_date BETWEEN '2020-12-01' AND '2020-12-28' 
AND i.reference_high<>'' AND i.result<>''
AND i.result > i.reference_high ;

Then execute to view the results

The query results are not as expected. There are a lot of data that do not meet the query condition i.result > i.reference_high

2. Positioning

Looking at the SQL statement for creating the table, we found that result and reference_high are of varchar type, not numeric type, so the query results did not match expectations.

3. Solution

Method 1: Change the table field data type to numeric

However, considering the business usage scenario, both fields may have non-numeric input, so it is not feasible.

Method 2: Modify the query statement and convert the data type to numeric type

Take the above data as an example

1. Implicit conversion: add 0 to the string to be compared and then compare it. The data is successfully filtered.

2. Display conversion

(1) Use the convert function: convert the string to a floating point number, then compare it, and the data is successfully filtered

(2) Use the cast function: Almost the same as the convert function

This is the end of this article about the implementation of MySQL data type conversion. For more relevant MySQL data type conversion content, please search 123WORDPRESS.COM's previous articles or continue to browse the following related articles. I hope everyone will support 123WORDPRESS.COM in the future!

You may also be interested in:
  • Detailed explanation of MySql data type tutorial examples
  • MySQL 5.7 Common Data Types
  • MySQL chooses the appropriate data type for id
  • MySQL data type selection principles
  • Implementation of mysql decimal data type conversion
  • Detailed explanation of the usage of MySQL data type DECIMAL
  • Detailed explanation of the decimal padding problem of decimal data type in MySQL
  • MySQL data type details

<<:  How to deploy Solidity smart contracts using ethers.js

>>:  A complete guide to clearing floats in CSS (summary)

Recommend

In-depth analysis of MySQL query interception

Table of contents 1. Query Optimization 1. MySQL ...

Go to another file after submitting the form

<br />Question: How to write in HTML to jump...

How to change the system language of centos7 to simplified Chinese

illustrate When you install the system yourself, ...

WeChat applet implements countdown for sending SMS verification code

This article shares the specific code for the WeC...

Detailed explanation of vue simple notepad development

This article example shares the specific code of ...

Notes on the MySQL database backup process

Today I looked at some things related to data bac...

Detailed explanation of Deepin using docker to install mysql database

Query the MySQL source first docker search mysql ...

The difference between JS pre-parsing and variable promotion in web interview

Table of contents What is pre-analysis? The diffe...

Solution to BT Baota Panel php7.3 and php7.4 not supporting ZipArchive

The solution to the problem that the PHP7.3 versi...

JavaScript closure details

Table of contents 1. What is a closure? 2. The ro...

Promise encapsulation wx.request method

The previous article introduced the implementatio...

How to implement Linux deepin to delete redundant kernels

The previous article wrote about how to manually ...

Quickly master the use of Docker to build a development environment

As the platform continues to grow, the project...