Mysql database program optimization method

Source: Internet
Author: User

Mysql database program optimization method
1. select the most suitable field attribute

MySQL can support access to large data volumes, but generally, the smaller the table in the database, the faster the query will be executed on it. Therefore, when creating a table, we can set the field width in the table as small as possible to achieve better performance. For example, if you set it to CHAR (255) when defining the zip code field, it is obvious that unnecessary space is added to the database, and even the VARCHAR type is redundant, because CHAR (6) can well complete the task. Similarly, if possible, we should use MEDIUMINT instead of BIGIN to define integer fields.

Another way to improve efficiency is to set the field to not null whenever possible, so that the database does NOT need to compare NULL values during future queries.

Some text fields, such as "Province" or "gender", can be defined as ENUM. In MySQL, The ENUM type is processed as the numeric data, and the numeric data is processed much faster than the text type. In this way, we can improve the database performance.

2. Use JOIN instead of Sub-Queries)

MySQL supports SQL subqueries from 4.1. This technique can use the SELECT statement to create a single column query result, and then use this result as a filter condition in another query. For example, if you want to delete a customer who has no orders in the basic customer information table, you can use the subquery to retrieve the customer IDs of all orders from the sales information table, then pass the result to the primary query, as shown below:

Delete from customerinfo WHERE CustomerID NOT in (SELECT CustomerID FROM salesinfo)

Subqueries can be used to complete SQL operations that require multiple logical steps at a time. At the same time, transactions or tables can be prevented from being locked and can be easily written. However, in some cases, subqueries can be replaced by more efficient JOIN. For example, if we want to retrieve all users without order records, we can use the following query:

SELECT * FROM customerinfo WHERE CustomerID NOT in (SELECT CustomerID FROM salesinfo)

If you use JOIN... to complete this query, the speed will be much faster. Especially when the salesinfo table has an index on CustomerID, the performance will be better. The query is as follows:

SELECT * FROM customerinfo left join salesinfoON customerinfo. CustomerID = salesinfo. CustomerID WHERE salesinfo. CustomerID IS NULL

JOIN... it is more efficient because MySQL does not need to create a temporary table in the memory to perform the query in two steps.

3. Use UNION instead of creating a temporary table manually

MySQL 4.0 and later versions support UNION queries. It can merge two or more SELECT queries in a temporary table. When the query Session on the client ends, the temporary table is automatically deleted to ensure the database is neat and efficient. When using UNION to create a query, we only need to use UNION as the keyword to connect multiple SELECT statements. Note that the number of fields in all SELECT statements must be the same. The following example demonstrates a query using UNION.

SELECT Name, Phone FROM client union select Name, BirthDate FROM author
UNION
SELECT Name, Supplier FROM product

4. Transactions

Although we can use Sub-Queries, JOIN, and UNION to create various Queries, however, not all database operations can be completed with only one or a few SQL statements. In more cases, a series of statements are needed to complete some work. However, in this case, when a statement in the statement block fails to run, the operation of the entire statement block becomes uncertain. Imagine that you want to insert data into two associated tables at the same time. This may happen: after the first table is successfully updated, the database suddenly experiences an unexpected situation, as a result, the operations in the second table are incomplete, which may damage the data in the database. To avoid this situation, you should use a transaction. Its function is to either operate successfully or fail each statement in the statement block. In other words, data consistency and integrity can be maintained in the database. The transaction starts with the BEGIN keyword and ends with the COMMIT keyword. If an SQL operation fails, the ROLLBACK command can restore the database to the State before the start of in.

BEGIN;

Insert into salesinfo SET CustomerID = 14;

UPDATE inventory SET Quantity = 11

WHERE item = 'book ';

COMMIT;

Another important role of transactions is that when multiple users use the same data source at the same time, they can use the database locking method to provide users with a safe access method, this ensures that user operations are not affected by other users.

5. Lock the table

Although transactions are a very good way to maintain database integrity, they sometimes affect database performance, especially in large application systems. Because the database will be locked during transaction execution, other user requests can only wait until the transaction ends. If a database system has only a few users

The impact of transactions will not be a big problem. But suppose there are thousands of users accessing a database system at the same time, for example, accessing an e-commerce website, A serious response latency occurs.

In fact, in some cases, we can lock the table to achieve better performance. The following example uses the table locking method to complete the transaction function in the previous example.

Lock table inventory WRITE
SELECT Quantity FROM inventory
WHEREItem = 'book ';
...

UPDATE inventory SET Quantity = 11
WHEREItem = 'book ';
UNLOCK TABLES

Here, we use a SELECT statement to retrieve the initial data. Through some calculations, we use the UPDATE statement to UPDATE the new value to the table. The lock table statement containing the WRITE keyword ensures that no other access is allowed to insert, update, or delete the inventory before the unlock tables command is executed.

6. Use foreign keys

Locking a table can maintain data integrity, but it cannot guarantee data relevance. In this case, we can use the foreign key. For example, a foreign key can ensure that each sales record points to an existing customer. Here, the foreign key can map the CustomerID in the customerinfo table to the CustomerID in the salesinfo table. No record without a valid CustomerID will be updated or inserted into the salesinfo table.

Create table customerinfo
(
CustomerID int not null,
Primary key (CustomerID)
) TYPE = INNODB;
Create table salesinfo
(
SalesID int not null,
CustomerID int not null,
Primary key (CustomerID, SalesID ),
Foreign key (CustomerID) REFERENCES customerinfo
(CustomerID) ON DELETECASCADE
) TYPE = INNODB;

Note the parameter "on delete cascade" in the example ". This parameter ensures that when a customer record in the customerinfo table is deleted, all records related to this customer in the salesinfo table will also be deleted automatically. If you want to use foreign keys in MySQL, remember to define the table type as the InnoDB type of the Transaction Security table when creating the table. This type is not the default MySQL table type. The defined method is to add TYPE = INNODB In the create table statement. As shown in the example.

7. Use Indexes

Index is a common method to improve database performance. It allows database servers to retrieve specific rows at a much faster speed than no index, especially when a query statement contains MAX (), when using the MIN () and ORDERBY commands, the performance improvement is more obvious. Which fields should be indexed? In general, the index should be built on the fields that will be used for JOIN, WHERE judgment and order by sorting. Try not to index a field in the database that contains a large number of repeated values. For an ENUM type field, it is very likely that a large number of repeated values appear, such as "province" in customerinfo ".. it is not helpful to create an index on such a field. On the contrary, it may also reduce the performance of the database. When creating a TABLE, we can CREATE an appropriate INDEX at the same time, or use alter table or create index to CREATE an INDEX later. In addition, MySQL

Full-text indexing and search are supported from version 3.23.23. Full-text index is a FULLTEXT index in MySQL, but it can only be used for tables of the MyISAM type. For a large database, it is very fast to load data to a TABLE without FULLTEXT indexes and then CREATE an INDEX using alter table or create index. However, if you load data to a table with a FULLTEXT index, the execution will be very slow.

8. Optimized query statements

In most cases, using indexes can increase the query speed. However, if an SQL statement is improperly used, indexes cannot play its due role. The following are some notes. First, it is best to compare fields of the same type. Before MySQL 3.23, this is even a required condition. For example, you cannot compare an indexed INT field with a BIGINT field. However, in special cases, when a CHAR field is of the same size as a VARCHAR field, you can compare them. Second, do not use functions to operate indexed fields.

For example, when the YEAE () function is used on a DATE field, the index cannot play its due role. Therefore, although the two queries below return the same results, the latter is much faster than the former.

SELECT * FROM order where year (OrderDate) <2001;
SELECT * FROM order WHERE OrderDate <"2001-01-01 ";

In the same case, when the numeric field is calculated:

SELECT * FROM inventory WHERE Amount/7 <24;
SELECT * FROM inventory WHERE Amount <24*7;

The above two queries also return the same results, but the subsequent query will be much faster than the previous one. Third, when searching for a struct field, we sometimes use the LIKE keyword and wildcard. Although this method is simple, it is at the cost of system performance. For example, the following query will compare each record in the table.

SELECT * FROM books
WHERE name like "MySQL %"

However, if the following query is used, the returned results are the same, but the speed is much faster:

SELECT * FROM books
WHERE name> = "MySQL" and name <"MySQM"

1: Adjust server Parameters
  
Use the shell> mysqld-help command to output the following information:
  
Possible variables for option -- set-variable (-o) are:
  
Back_log current value: 5 // the number of connections that mysql can have. back_log indicates how many connection requests can be stored in the stack during the time when mysql suspends the connection.
  
Connect_timeout current value: 5 // mysql Server waits for a connection time before responding with bad handshake
  
Delayed_insert_timeout current value: 200 // The time for an insert delayed to wait for the insert before termination
  
Delayed_insert_limit current value: 50 // The insert delayed processor checks whether any select statements are not executed. If yes, run these statements before resuming.
  
Delayed_queue_size current value: 1000 // the size of the queue allocated for insert delayed
  
Flush_time current value: 0 // if it is set to a non-0 value, all tables are closed for each flush_time.
  
Interactive_timeout current value: 28800 // time the server waits for a foreign interactive connection before closing it
  
Join_buffer_size current value: 131072 // the buffer size connected to all
  
Key_buffer_size current value: 1048540 // the buffer size of the clause index block. You can increase it to better process the index.
  
Lower_case_table_names current value: 0 //
  
Long_query_time current value: 10 // If a query takes more time than this time, the slow_queried count will increase
  
Max_allowed_packet current value: 1048576 // size of a package
  
Max_connections current value: 300 // number of concurrent connections allowed
  
Max_connect_errors current value: 10 // if there are more than this number of interrupted connections, further connections will be blocked. You can use flush hosts to solve this problem.
  
Max_delayed_threads current value: 15 // Number of insert delayed processes that can be started
  
Max_heap_table_size current value: 16777216 //
  
Max_join_size current value: 4294967295 // Number of connections that can be read
  
Max_sort_length current value: 1024 // number of bytes used for sorting blob or text
  
Max_tmp_tables current value: 32 // number of temporary tables simultaneously opened by a connection
  
Max_write_lock_count current value: 4294967295 // specify a value (usually very small) to start mysqld, so that the read lock occurs after a certain number of write locks.
  
Net_buffer_length current value: 16384 // communication buffer size -- reset to this size during Query
  
Query_buffer_size current value: 0 // buffer size during Query
  
Record_buffer current value: 131072 // size of the buffer allocated to each table scanned by connections for each Sequential Scan
  
Sort_buffer current value: 2097116 // size of the buffer allocated for each sort connection
  
Table_cache current value: 64 // number of tables opened for all connections
  
Thread_concurrency current value: 10 //
  
Tmp_table_size current value: 1048576 // temporary table size
  
Thread_stack current value: 131072 // the size of each thread
  
Wait_timeout current value: 28800 // time the server waits for a connection before closing it 3
  
Configuring the above information as needed will help you.

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.