Home Database Mysql Tutorial 6 things you should learn about MySQL

6 things you should learn about MySQL

May 01, 2017 pm 01:46 PM

MySQL is increasingly used in database applications due to its compactness and efficient operation. As an important part of LAMP (or WAMP) development, MySQL deserves the attention and careful study of PHP developers.

1. Each line of command ends with a semicolon (;)

The first thing you must remember about MySQL is that each line of commands ends with a semicolon (;), but when a line of MySQL is inserted into PHP code, it is best to omit the following semicolon. For example:

mysql_query ("INSERT INTO tablename (first_name, last_name) VALUES ('$first_name', $last_name')");
Copy after login

This is because PHP also ends a line with a semicolon. Extra semicolons sometimes confuse the PHP parser, so it is better to omit them. In this case, although the semicolon is omitted, PHP will automatically add it for you when executing the MySQL command.

2. Use associative array to access query results

Look at the following example:

$connection = mysql_connect("localhost", "albert", "shhh");  
mysql_select_db("winestore", $connection);  
$result = mysql_query("SELECT cust_id, surname,  
firstname FROM customer", $connection);  

while ($row = mysql_fetch_array($result))  
{  
echo "ID:t{$row["cust_id"]}n";  
echo "Surnamet{$row["surname"]}n";  
echo "First name:t{$row["firstname"]}nn";  
}
Copy after login

The function mysql_fetch_array() puts a row of the query result into an array, which can be referenced in two ways at the same time. For example, cust_id can be referenced in the following two ways at the same time: $row["cust_id"] or $row[0]. Obviously, the former is much more readable than the latter.

In multi-table continuous query, if two columns have the same name, it is best to separate them with aliases:

SELECT winery.name AS wname, region.name AS rname, FROM winery, region WHERE winery.region_id = region.region_id;  

列名的引用为:$row["wname"] 和 $row["rname"]
Copy after login

​When specifying the table name and column name, only quote the column name:

SELECT winery.region_id   
FROM winery   
列名的引用为: $row["region_id"]
Copy after login

The reference of the aggregate function is the reference name:

SELECT count(*) 
FROM customer; 
列名的引用为: $row["count(*)"]
Copy after login

3. TEXT, DATE, and SET data types

The fields of the MySQL data table must have a data type defined. There are about 25 options, most of which are straightforward and require no further explanation. But there are a few that need to be mentioned.

TEXT is not a data type, although some books may say so. It should actually be "LONG VARCHAR" or "MEDIUMTEXT".

The format of the DATE data type is YYYY-MM-DD, for example: 1999-12-08. You can easily use the date function to get the current system time in this format: date("Y-m-d") Moreover, you can subtract between DATA data types to get the difference in time in days:

$age = ($current_date - $birthdate);
Copy after login

The set SET is a useful data type. It is somewhat similar to the enumeration ENUM, except that SET can save multiple values ​​and ENUM can only save one value. Moreover, the SET type can only have a maximum of 64 predefined values, while the ENUM type can handle a maximum of 65,535 predefined values. What should we do if we need a collection with more than 64 values? At this time, we need to define multiple collections to solve this problem together.

4. Use mysql_unbuffered_query() to develop fast scripts

This function can be used to replace the mysql_query() function. The main difference is that mysql_unbuffered_query() returns immediately after executing the query, without waiting or locking the database. But the number of rows returned cannot be checked with the mysql_num_rows() function because the size of the output result set is unknown.

5. Wildcard

There are two types of wildcard characters in SQL: "*" and "%". Used in different situations. For example: If you want to see all the contents of the database, you can query like this:

SELECT * FROM dbname WHERE USER_ID LIKE '%';
Copy after login

Here, both wildcards are used. They mean the same thing - they both match any string - but they are used in different contexts. " * " is used to match field names, and " % " is used to match field values. Another thing that is not easy to notice is that the "%" wildcard needs to be used with the LIKE keyword. There is also a wildcard character, which is the underscore "_", which has a different meaning from the above and is used to match any single character.

6. NOT NULL and empty records

What happens if the user presses the submit button without filling in anything? If you really need a value, you can use client-side scripting or server-side scripting for data validation. However, in the database, some fields are allowed to be left blank and filled with nothing. For such a record, MySQL will do something for it: insert the value NULL , which is the default operation.

If you declare NOT NULL for it in the field definition (when creating or modifying this field), MySQL will leave this field empty and fill it with nothing. For a field of ENUM enumeration type, if you declare NOT NULL for it, MySQL will insert the first value of the enumeration set into the field. In other words, MySQL uses the first value in the enumeration set as the default value for this enumeration type.

There are some differences between a record with a value of NULL and an empty record. The % wildcard character can match empty records, but it cannot match NULL records. At some point, this distinction can have unintended consequences. As far as my experience goes, any field should be declared NOT NULL . In this way, many SELECT query statements can run normally. Note that when searching for NULL, you must use the "IS" keyword, and LIKE will not work properly. The last thing to mention is that if you already have some records in the database before adding or modifying a new field, the value of the newly added field in the original record may be NULL or NULL. null. This can be regarded as a bug of MySQL, so in this case, you should be particularly careful when using SELECT query.

The above is the detailed content of 6 things you should learn about MySQL. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
3 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Best Graphic Settings
3 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. How to Fix Audio if You Can't Hear Anyone
3 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: How To Unlock Everything In MyRise
3 weeks ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

The relationship between mysql user and database The relationship between mysql user and database Apr 08, 2025 pm 07:15 PM

In MySQL database, the relationship between the user and the database is defined by permissions and tables. The user has a username and password to access the database. Permissions are granted through the GRANT command, while the table is created by the CREATE TABLE command. To establish a relationship between a user and a database, you need to create a database, create a user, and then grant permissions.

MySQL: The Ease of Data Management for Beginners MySQL: The Ease of Data Management for Beginners Apr 09, 2025 am 12:07 AM

MySQL is suitable for beginners because it is simple to install, powerful and easy to manage data. 1. Simple installation and configuration, suitable for a variety of operating systems. 2. Support basic operations such as creating databases and tables, inserting, querying, updating and deleting data. 3. Provide advanced functions such as JOIN operations and subqueries. 4. Performance can be improved through indexing, query optimization and table partitioning. 5. Support backup, recovery and security measures to ensure data security and consistency.

RDS MySQL integration with Redshift zero ETL RDS MySQL integration with Redshift zero ETL Apr 08, 2025 pm 07:06 PM

Data Integration Simplification: AmazonRDSMySQL and Redshift's zero ETL integration Efficient data integration is at the heart of a data-driven organization. Traditional ETL (extract, convert, load) processes are complex and time-consuming, especially when integrating databases (such as AmazonRDSMySQL) with data warehouses (such as Redshift). However, AWS provides zero ETL integration solutions that have completely changed this situation, providing a simplified, near-real-time solution for data migration from RDSMySQL to Redshift. This article will dive into RDSMySQL zero ETL integration with Redshift, explaining how it works and the advantages it brings to data engineers and developers.

How to fill in mysql username and password How to fill in mysql username and password Apr 08, 2025 pm 07:09 PM

To fill in the MySQL username and password: 1. Determine the username and password; 2. Connect to the database; 3. Use the username and password to execute queries and commands.

Query optimization in MySQL is essential for improving database performance, especially when dealing with large data sets Query optimization in MySQL is essential for improving database performance, especially when dealing with large data sets Apr 08, 2025 pm 07:12 PM

1. Use the correct index to speed up data retrieval by reducing the amount of data scanned select*frommployeeswherelast_name='smith'; if you look up a column of a table multiple times, create an index for that column. If you or your app needs data from multiple columns according to the criteria, create a composite index 2. Avoid select * only those required columns, if you select all unwanted columns, this will only consume more server memory and cause the server to slow down at high load or frequency times For example, your table contains columns such as created_at and updated_at and timestamps, and then avoid selecting * because they do not require inefficient query se

Can I retrieve the database password in Navicat? Can I retrieve the database password in Navicat? Apr 08, 2025 pm 09:51 PM

Navicat itself does not store the database password, and can only retrieve the encrypted password. Solution: 1. Check the password manager; 2. Check Navicat's "Remember Password" function; 3. Reset the database password; 4. Contact the database administrator.

Understand ACID properties: The pillars of a reliable database Understand ACID properties: The pillars of a reliable database Apr 08, 2025 pm 06:33 PM

Detailed explanation of database ACID attributes ACID attributes are a set of rules to ensure the reliability and consistency of database transactions. They define how database systems handle transactions, and ensure data integrity and accuracy even in case of system crashes, power interruptions, or multiple users concurrent access. ACID Attribute Overview Atomicity: A transaction is regarded as an indivisible unit. Any part fails, the entire transaction is rolled back, and the database does not retain any changes. For example, if a bank transfer is deducted from one account but not increased to another, the entire operation is revoked. begintransaction; updateaccountssetbalance=balance-100wh

Master SQL LIMIT clause: Control the number of rows in a query Master SQL LIMIT clause: Control the number of rows in a query Apr 08, 2025 pm 07:00 PM

SQLLIMIT clause: Control the number of rows in query results. The LIMIT clause in SQL is used to limit the number of rows returned by the query. This is very useful when processing large data sets, paginated displays and test data, and can effectively improve query efficiency. Basic syntax of syntax: SELECTcolumn1,column2,...FROMtable_nameLIMITnumber_of_rows;number_of_rows: Specify the number of rows returned. Syntax with offset: SELECTcolumn1,column2,...FROMtable_nameLIMIToffset,number_of_rows;offset: Skip

See all articles