6 things you should learn about MySQL
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')");
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"; }
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"]
When specifying the table name and column name, only quote the column name:
SELECT winery.region_id FROM winery 列名的引用为: $row["region_id"]
The reference of the aggregate function is the reference name:
SELECT count(*) FROM customer; 列名的引用为: $row["count(*)"]
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);
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 '%';
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!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics











The main role of MySQL in web applications is to store and manage data. 1.MySQL efficiently processes user information, product catalogs, transaction records and other data. 2. Through SQL query, developers can extract information from the database to generate dynamic content. 3.MySQL works based on the client-server model to ensure acceptable query speed.

The process of starting MySQL in Docker consists of the following steps: Pull the MySQL image to create and start the container, set the root user password, and map the port verification connection Create the database and the user grants all permissions to the database

Laravel is a PHP framework for easy building of web applications. It provides a range of powerful features including: Installation: Install the Laravel CLI globally with Composer and create applications in the project directory. Routing: Define the relationship between the URL and the handler in routes/web.php. View: Create a view in resources/views to render the application's interface. Database Integration: Provides out-of-the-box integration with databases such as MySQL and uses migration to create and modify tables. Model and Controller: The model represents the database entity and the controller processes HTTP requests.

I encountered a tricky problem when developing a small application: the need to quickly integrate a lightweight database operation library. After trying multiple libraries, I found that they either have too much functionality or are not very compatible. Eventually, I found minii/db, a simplified version based on Yii2 that solved my problem perfectly.

Article summary: This article provides detailed step-by-step instructions to guide readers on how to easily install the Laravel framework. Laravel is a powerful PHP framework that speeds up the development process of web applications. This tutorial covers the installation process from system requirements to configuring databases and setting up routing. By following these steps, readers can quickly and efficiently lay a solid foundation for their Laravel project.

MySQL and phpMyAdmin are powerful database management tools. 1) MySQL is used to create databases and tables, and to execute DML and SQL queries. 2) phpMyAdmin provides an intuitive interface for database management, table structure management, data operations and user permission management.

Compared with other programming languages, MySQL is mainly used to store and manage data, while other languages such as Python, Java, and C are used for logical processing and application development. MySQL is known for its high performance, scalability and cross-platform support, suitable for data management needs, while other languages have advantages in their respective fields such as data analytics, enterprise applications, and system programming.

MySQL is suitable for web applications and content management systems and is popular for its open source, high performance and ease of use. 1) Compared with PostgreSQL, MySQL performs better in simple queries and high concurrent read operations. 2) Compared with Oracle, MySQL is more popular among small and medium-sized enterprises because of its open source and low cost. 3) Compared with Microsoft SQL Server, MySQL is more suitable for cross-platform applications. 4) Unlike MongoDB, MySQL is more suitable for structured data and transaction processing.
