WEB应用中,大量静态数据应当储存在数据库,还是直接储存在PHP业务层
WEB应用中,大量静态数据应该储存在数据库,还是直接储存在PHP业务层?
意思是,一个存在大量静态数据的WEB应用,比如一个MYSQL-PHP-JS架构的WEB游戏,它存在大量相对静态的数据,比如每升一级需要多少经验,比如每个城市、每个道具的各项参数等等。这些数据通常仅在版本更新时可能发生一定变化。
如果储存在数据库(只读的表),那么每一个业务都需要查询一张或多张这样的静态数据表。
如果直接以关联数组的形式储存在PHP业务层(当然是从EXCEL策划表架构自动产生的PHP代码),那么对庞大的关联数组进行定义、操作似乎也会影响服务器PHP文件执行效率。
相比之下,上述两种选择哪种效率更高?相当于说把压力放在MYSQL层上还是PHP层上,哪个更轻松。
如果觉得我还没表述清楚请回帖说明,我会补充说明的。
------解决思路----------------------
比如每升一级需要多少经验,比如每个城市、每个道具的各项参数等等
如果升级是由 php 代码完成的,那么存成什么都无所谓
如果升级是由 SQL 指令码完成的,那么当然要存成表,以便后台实现
------解决思路----------------------
个人觉得你这个有点像是系统配置的信息一样。量多的话建议放在数据库中吧,放到缓存中方便读取
------解决思路---------------------- 为什么非要二选一呢,结合使用不行吗
数据源就放在mysql里,维护也是直接更新库里的数据
然后写一个程序,将每一组静态数据缓存成一个php脚本文件,例如:升级经验.data.php:1, 2=> 2)...
需要用到数据时,$升级经验 = include '升级经验.data.php';
分成多文件保存,用哪个读哪个,避免大量声明
数据更新时,改好mysql里的数据,将缓存文件删掉重新运行程序生成即可
------解决思路----------------------
个人感觉可以存数据库和redis里,
一般获取从redis来,如果redis没有值就去mysql获取
mysql的值通过php设置
只要维护好mysql和redis的同步(比如mysql重启就更新redis,mysql更新也更新redis)
这样又好维护,也能直接放内存中,维护和访问速度都没问题
同二楼,不推荐放php代码中,这是最不好的办法。。。如果你真的要,那就在一个公共文件中define...
楼主自己取舍

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











MySQL and phpMyAdmin can be effectively managed through the following steps: 1. Create and delete database: Just click in phpMyAdmin to complete. 2. Manage tables: You can create tables, modify structures, and add indexes. 3. Data operation: Supports inserting, updating, deleting data and executing SQL queries. 4. Import and export data: Supports SQL, CSV, XML and other formats. 5. Optimization and monitoring: Use the OPTIMIZETABLE command to optimize tables and use query analyzers and monitoring tools to solve performance problems.

AI can help optimize the use of Composer. Specific methods include: 1. Dependency management optimization: AI analyzes dependencies, recommends the best version combination, and reduces conflicts. 2. Automated code generation: AI generates composer.json files that conform to best practices. 3. Improve code quality: AI detects potential problems, provides optimization suggestions, and improves code quality. These methods are implemented through machine learning and natural language processing technologies to help developers improve efficiency and code quality.

In MySQL, add fields using ALTERTABLEtable_nameADDCOLUMNnew_columnVARCHAR(255)AFTERexisting_column, delete fields using ALTERTABLEtable_nameDROPCOLUMNcolumn_to_drop. When adding fields, you need to specify a location to optimize query performance and data structure; before deleting fields, you need to confirm that the operation is irreversible; modifying table structure using online DDL, backup data, test environment, and low-load time periods is performance optimization and best practice.

session_start()iscrucialinPHPformanagingusersessions.1)Itinitiatesanewsessionifnoneexists,2)resumesanexistingsession,and3)setsasessioncookieforcontinuityacrossrequests,enablingapplicationslikeuserauthenticationandpersonalizedcontent.

To safely and thoroughly uninstall MySQL and clean all residual files, follow the following steps: 1. Stop MySQL service; 2. Uninstall MySQL packages; 3. Clean configuration files and data directories; 4. Verify that the uninstallation is thorough.

Efficient methods for batch inserting data in MySQL include: 1. Using INSERTINTO...VALUES syntax, 2. Using LOADDATAINFILE command, 3. Using transaction processing, 4. Adjust batch size, 5. Disable indexing, 6. Using INSERTIGNORE or INSERT...ONDUPLICATEKEYUPDATE, these methods can significantly improve database operation efficiency.

MySQL functions can be used for data processing and calculation. 1. Basic usage includes string processing, date calculation and mathematical operations. 2. Advanced usage involves combining multiple functions to implement complex operations. 3. Performance optimization requires avoiding the use of functions in the WHERE clause and using GROUPBY and temporary tables.

The essential Laravel extension packages for 2024 include: 1. LaravelDebugbar, used to monitor and debug code; 2. LaravelTelescope, providing detailed application monitoring; 3. LaravelHorizon, managing Redis queue tasks. These expansion packs can improve development efficiency and application performance.
