MYSQL string forced conversion method example

MYSQL string forced conversion method example

Preface

Since the types of the same fields in the two tables are different, or even the encoding types are different, the query will not use the index and the speed will be very slow.

Forced transfer

Let me give you a direct example:

A table id is int type B table id is char type

If you want to convert to int, it is signed

If you want to convert to char, then char

Note: The type to be converted must be the field of the table after the left join, otherwise the index will not be used.

Because the field types of the joint table are inconsistent, the index is not used.

select t.* from A tleft join B t1 on t.id = t1.id

The first conversion type

select t.* from A tleft join B t1 on t.id = cast(t1.id as signed)

The second conversion type

select t.* from A tleft join B t1 on t.id = convert(t1.id, signed)

ab=fg

However, the two fields b and g have different sorting rules. b is utf8_general_ci, and g is utf8_unicode_ci. If they are equal, SQL will report an error. So I asked my superior for help. The way to write it is:

CONVERT (ab USING utf8) COLLATE utf8_unicode_ci = fg

If the table is not indexed, the fields are transformed in the query, for example:

select a.* from a
LEFT JOIN (SELECT b.*, CONVERT (ab USING utf8) COLLATE utf8_unicode_ci = fg FROM b) a ON ab = fg

CONVERT(user_id USING utf8) COLLATE utf8_general_ci as user_id

This is the end of this article about MYSQL string conversion. For more information about MYSQL string conversion, please search 123WORDPRESS.COM's previous articles or continue to browse the following related articles. I hope you will support 123WORDPRESS.COM in the future!

You may also be interested in:
  • Detailed explanation of MySQL date string timestamp conversion
  • Convert image gif, jpg or mysql longblob or blob field value into hexadecimal string in php
  • Example of converting the mysql string '123' to the number 123

<<:  Research on the Input Button Function of Type File

>>:  Docker implements re-tagging and deleting the image of the original tag

Recommend

The meaning and usage of linux cd

What does linux cd mean? In Linux, cd means chang...

How to configure Http, Https, WS, and WSS in Nginx

Written in front In today's Internet field, N...

JS asynchronous execution principle and callback details

1. JS asynchronous execution principle We know th...

Viewing and analyzing MySQL execution status

When you feel that there is a problem with MySQL ...

jQuery canvas generates a poster with a QR code

This article shares the specific code for using j...

Sharing several methods to disable page caching

Today, when developing, I encountered a method wh...

A brief analysis of MySQL's WriteSet parallel replication

【Historical Background】 I have been working as a ...

Stop using absolute equality operators everywhere in JS

Table of contents Overview 1. Test for null value...

JavaScript code to implement Weibo batch unfollow function

A cool JavaScript code to unfollow Weibo users in...

Deeply understand how nginx achieves high performance and scalability

The overall architecture of NGINX is characterize...

Should nullable fields in MySQL be set to NULL or NOT NULL?

People who often use MySQL may encounter the foll...

Web page header optimization suggestions

Logo optimization: 1.The logo image should be as ...

Vue implements irregular screenshots

Table of contents Image capture through svg CSS p...