The difference between storing full-width characters and half-width characters in MySQL

The difference between storing full-width characters and half-width characters in MySQL

Unfortunately, the MYSQL_DATA_TRUNCATED error occurred again during the company's internal testing of IM, and the log record appeared when mysql_stmt_fetch was called. Based on previous experience, it should be caused by the insufficient length of the given result set binding area. I checked it repeatedly many times but did not find the problem. I have corresponding relationships in the code. For example, for char(20), I will define the char buffer[20] array in my code to store it. It looks so right and perfect. I had no choice but to print each line of data, find the line with the error, and discover that the font was different from the others. for example:

123456789 (half-width)
123456789(full width)

This is not controlled by me entering spaces, but by the full-width and half-width input method. For a full-width character, it is twice the length of a half-width character, and my MySQL uses utf-8, so in the database a full-width character is 3 bytes long.

select length(column) from table_name where…;

Use this to print the length and you can tell. At this time, you need to consider the problem of matching the length of the type in the code with the length of the database field, such as full-width characters or Chinese characters. The char(20) in the database represents 20 characters, not 20 bytes. Please note that when retrieving data, do not use 20 as the result set length.

<<:  WeChat Mini Programs Achieve Seamless Scrolling

>>:  Two ways to enable firewall in Linux service

Recommend

The image element img has extra blank space in IE6

When doing DIV+CSS layout of the page, it is very...

MySQL 8.0.15 installation and configuration method graphic tutorial

This article records the installation and configu...

Vue.js implements simple folding panel

This article example shares the specific code of ...

MySQL Series 11 Logging

Tutorial Series MySQL series: Basic concepts of M...

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

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

Detailed explanation of NodeJS modularity

Table of contents 1. Introduction 2. Main text 2....

Execute initialization sql when docker mysql starts

1. Pull the Mysql image docker pull mysql:5.7 2. ...

VMware12.0 installation Ubuntu14.04 LTS tutorial

I have installed various images under virtual mac...

Implementing a shopping cart with native JavaScript

This article shares the specific code of JavaScri...

Practice of multi-layer nested display of element table

There is a requirement for a list containing mult...

Various types of MySQL indexes

What is an index? An index is a data structure th...

What are the drawbacks of deploying the database in a Docker container?

Preface Docker has been very popular in the past ...

Using MySQL database in docker to achieve LAN access

1. Get the mysql image docker pull mysql:5.6 Note...