Innodb tables are just the opposite; row-level lock tables
Internet services, except for paid services, interactive products, news systems, etc. generally read more and write less. It is more appropriate to use the myisam table.
Table design
Fixed-length table: The field lengths of all columns are fixed-length. You can check the mysql manual. The variable length fields are VARCHAR, BLOB or TEXT. Int chars are all fixed-length, and fixed-length tables take up a lot of space.
Dynamic table: The fields are not all fixed length.
Fixed-length tables are retrieved faster than dynamic tables.
The design habit of software systems is to distinguish very clear functions for each table. For example, the user table contains user information. If you need to fetch data from the message table and user information from the user table at the same time, you will use a union. For queries, sometimes some operations will use various complex SQL statements such as left and join, and may also use MySQL functions. If it is an Internet service with a large number of visits and readings, and the data is read concurrently, the amount of data is huge, which is terrible. It is best to have redundant fields on commonly used tables if the data will not be modified, so that all data can be read in one go; redundant write operations can be used, but complex query operations are reduced.
When designing a table, sum up the number of bytes occupied by all field types in the table and multiply it by your expectation (for example: storing 100W of data), which is the capacity that the entire table will occupy in the future.
Dismantle the table and dismantle the database
Split the table is to copy a table to N multiple copies, and store the data with different contents respectively. The HASH algorithm is used to store the data to decide which table to put it into.
For example, the user table user is traditionally one table. Splitting the table means copying the table into user_01, user_02, etc., which all store different user data in the same format.
Deleting a library is similar to dismantling a table, it is a copy of the library.
There are many HASH algorithms for table or database dismantling. The main purpose is to reduce the data volume of the table. The algorithm is used to ensure that the data volume of each table is average. The requests, read and write operations are amortized to reduce the pressure, and it is safe. The most problems occur. Some users are affected. The disadvantage is that retrieval is inconvenient and you need to find another way.
Many websites use discuz products to save trouble in the early stage, such as bbs, blog, etc. There are many introductions and optimization methods about this product on the Internet. I have not studied them in detail. I have heard some websites introduce their optimization methods. For databases The main method is to use the master-slave method to separate the reading and writing of the database to improve performance. However, I personally feel that this method will be over when the amount of data reaches the scale. The concurrency and read and write operations will not be improved, and the data will gradually accumulate beyond the limit. .
Internet services have to deal with large amounts of data and requests, so when designing and developing, don’t be too academic and don’t strive to achieve “beautiful” design of databases and programs. Performance is the most important thing.
The above is the content of mysql database design. For more related content, please pay attention to the PHP Chinese website (www.php.cn)!

本篇文章给大家带来了关于mysql的相关知识,其中主要介绍了关于架构原理的相关内容,MySQL Server架构自顶向下大致可以分网络连接层、服务层、存储引擎层和系统文件层,下面一起来看一下,希望对大家有帮助。

方法:1、利用right函数,语法为“update 表名 set 指定字段 = right(指定字段, length(指定字段)-1)...”;2、利用substring函数,语法为“select substring(指定字段,2)..”。

mysql的msi与zip版本的区别:1、zip包含的安装程序是一种主动安装,而msi包含的是被installer所用的安装文件以提交请求的方式安装;2、zip是一种数据压缩和文档存储的文件格式,msi是微软格式的安装包。

在mysql中,可以利用char()和REPLACE()函数来替换换行符;REPLACE()函数可以用新字符串替换列中的换行符,而换行符可使用“char(13)”来表示,语法为“replace(字段名,char(13),'新字符串') ”。

转换方法:1、利用cast函数,语法“select * from 表名 order by cast(字段名 as SIGNED)”;2、利用“select * from 表名 order by CONVERT(字段名,SIGNED)”语句。

本篇文章给大家带来了关于mysql的相关知识,其中主要介绍了关于MySQL复制技术的相关问题,包括了异步复制、半同步复制等等内容,下面一起来看一下,希望对大家有帮助。

在mysql中,可以利用REGEXP运算符判断数据是否是数字类型,语法为“String REGEXP '[^0-9.]'”;该运算符是正则表达式的缩写,若数据字符中含有数字时,返回的结果是true,反之返回的结果是false。

本篇文章给大家带来了关于mysql的相关知识,其中主要介绍了mysql高级篇的一些问题,包括了索引是什么、索引底层实现等等问题,下面一起来看一下,希望对大家有帮助。


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

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Atom editor mac version download
The most popular open source editor

mPDF
mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),

SublimeText3 Linux new version
SublimeText3 Linux latest version

VSCode Windows 64-bit Download
A free and powerful IDE editor launched by Microsoft

ZendStudio 13.5.1 Mac
Powerful PHP integrated development environment
