Notes for executing SQL statements in MySQL

Source: Internet
Author: User

Case sensitivity when executing the SEARCH Command

By default, MySQL does not distinguish uppercase and lowercase letters when performing search. When you use like 'a % 'for search, all column values starting with a or a are returned by default, you need to use the collate operator for implementation. The specific example is as follows:

 

 

      col_name COLLATE latin1_general_cs LIKE 'a%'col_name LIKE 'a%' COLLATE latin1_general_cscol_name COLLATE latin1_bin LIKE 'a%'col_name LIKE 'a%' COLLATE latin1_bin

If you want to keep a column case sensitive during search, use case sensitive or binary collation to define the column features.

When performing simple comparison operations, such as >=, >,=, <<=, sorting, and grouping, the internal sequence values of the characters, such as 'E ', 'E', and 'then©'These characters have the same internal Sequence Value.

Problems related to NULL values

The concept of NULL values is confusing. Some people think that NULL and NULL characters ''are incorrect. For example,

 

      mysql> INSERT INTO my_table (phone) VALUES (NULL);mysql> INSERT INTO my_table (phone) VALUES ('');

The preceding two statements have different meanings and results. The first sentence indicates that the phone number of a person in the record inserted into the table is NULL, which means that the person's phone number in the record is unknown, the second sentence inserts a ''null character into the table, which means that you already know the phone number of the person in the record. The phone number is '', you can also confirm that this person does not have a normal phone number.

The help method for processing NULL values is mainly implemented by executing the is null operation, is not null operation, and IFNULL () function operation. In SQL, any result that has an operational relationship with NULL cannot be true (that is, it is always false ). To find the NULL value, the is null test operation must be executed.

You can add an index when a null value is contained in a table store such as MyISAM, InnoDB, BDB, or MEMORY. However, the index must be declared as not null, in this way, you cannot enter null values in this column.

When the load data infile statement is used to load data, NULL values are replaced ''. When DISTINCT, group by, or order by is used, all null values are considered equal. Summary functions such as COUNT (), MIN (), SUM () Ignore NULL values.

But for some special types of columns, such as the timestamp type and columns with the auto_increment attribute, the former inserts NULL to insert the current time value, when NULL is inserted to the backend, it is the next positive integer sequence.

Related Article

Contact Us

The content source of this page is from Internet, which doesn't represent Alibaba Cloud's opinion; products and services mentioned on that page don't have any relationship with Alibaba Cloud. If the content of the page makes you feel confusing, please write us an email, we will handle the problem within 5 days after receiving your email.

If you find any instances of plagiarism from the community, please send an email to: info-contact@alibabacloud.com and provide relevant evidence. A staff member will contact you within 5 working days.

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.