This article mainly introduces you to the steps of upgrading the MySQL version to 5.7.17 in phpStudy. The article introduces it in detail through the example code. It has certain reference learning value for everyone's study or work. Friends who need it Let’s take a look together below.
Preface
I found an error at work today. When importing data tables locally, I always get an error:
[Err] 1294 - Invalid ON UPDATE clause for '字段名' column
Error data table fields:
`字段名` datetime DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP
Colleagues said that he could successfully import the same sql file. I guess it may be a problem with the database version. My colleague's version is 5.6. I checked the local database version and it is 5.5.53. After checking online, it turned out to be a version problem. 5.5 and 5.6 have different behaviors of TIMESTEMP. Versions before 5.6.5 do not support multiple CURRENT_TIMESTAMP default values.
Since the local integrated environment is phpStudy 2016, there is no option to upgrade the MySQL version, so I upgraded it myself.
Download the higher version of MySQL from the official website:
Official website: https://dev.mysql.com/downloads/file/?id=467269
Baidu Cloud Disk address: https://pan.baidu.com/s/1mi4UHtA
The selected version is 5.7.17 (later I discovered that the installation, system table fields, etc. of version 5.7 are different from the previous version) ).
Steps:
1. Back up the original MySQL installation directory in phpStudy
2. Unzip the downloaded MySQL compressed file Go to the MySQL directory under phpStudy, copy my-default.ini, and rename it to my.ini.
Open my.ini, find #basedir and edit:
basedir=D:/phpStudy/MySQL datadir=D:/phpStudy/MySQL/data
3. Add the MySQL installation path to the system environment variable
4. Enter the MySQL bin under cmd Directory (mine is D:/phpStudy/MySQL/bin), execute:
mysqld --initialize
Initialize database
5. Install service:
mysqld -install
Start service:
net start MySQL
6. Log in to MySQL at this time and an error message is reported:
C:\Users\dell>mysql -uroot -p Enter password: **** ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: YES)
Try to change the root user password:
Open my.ini, find [mysqld], and add below:
skip-grant-tables
At this time, use the root account and press Enter in the password field to log in.
Change password:
mysql>update mysql.user set authentication_string=password('new_password') where user='root' and Host ='localhost' mysql> ALTER USER USER() IDENTIFIED BY 'news_password';
Refresh permissions:
FLUSH PRIVILEGES;
Comment out the
skip-grant-tables
just added in my.ini and log in again.
Check mySQL version at this time:
mysql> select version(); +-----------+ | version() | +-----------+ | 5.7.17 | +-----------+
The above is the detailed content of Steps to upgrade MySQL version to 5.7.17 in phpStudy. For more information, please follow other related articles on the PHP Chinese website!

ThesecrettokeepingaPHP-poweredwebsiterunningsmoothlyunderheavyloadinvolvesseveralkeystrategies:1)ImplementopcodecachingwithOPcachetoreducescriptexecutiontime,2)UsedatabasequerycachingwithRedistolessendatabaseload,3)LeverageCDNslikeCloudflareforservin

You should care about DependencyInjection(DI) because it makes your code clearer and easier to maintain. 1) DI makes it more modular by decoupling classes, 2) improves the convenience of testing and code flexibility, 3) Use DI containers to manage complex dependencies, but pay attention to performance impact and circular dependencies, 4) The best practice is to rely on abstract interfaces to achieve loose coupling.

Yes,optimizingaPHPapplicationispossibleandessential.1)ImplementcachingusingAPCutoreducedatabaseload.2)Optimizedatabaseswithindexing,efficientqueries,andconnectionpooling.3)Enhancecodewithbuilt-infunctions,avoidingglobalvariables,andusingopcodecaching

ThekeystrategiestosignificantlyboostPHPapplicationperformanceare:1)UseopcodecachinglikeOPcachetoreduceexecutiontime,2)Optimizedatabaseinteractionswithpreparedstatementsandproperindexing,3)ConfigurewebserverslikeNginxwithPHP-FPMforbetterperformance,4)

APHPDependencyInjectionContainerisatoolthatmanagesclassdependencies,enhancingcodemodularity,testability,andmaintainability.Itactsasacentralhubforcreatingandinjectingdependencies,thusreducingtightcouplingandeasingunittesting.

Select DependencyInjection (DI) for large applications, ServiceLocator is suitable for small projects or prototypes. 1) DI improves the testability and modularity of the code through constructor injection. 2) ServiceLocator obtains services through center registration, which is convenient but may lead to an increase in code coupling.

PHPapplicationscanbeoptimizedforspeedandefficiencyby:1)enablingopcacheinphp.ini,2)usingpreparedstatementswithPDOfordatabasequeries,3)replacingloopswitharray_filterandarray_mapfordataprocessing,4)configuringNginxasareverseproxy,5)implementingcachingwi

PHPemailvalidationinvolvesthreesteps:1)Formatvalidationusingregularexpressionstochecktheemailformat;2)DNSvalidationtoensurethedomainhasavalidMXrecord;3)SMTPvalidation,themostthoroughmethod,whichchecksifthemailboxexistsbyconnectingtotheSMTPserver.Impl


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

MantisBT
Mantis is an easy-to-deploy web-based defect tracking tool designed to aid in product defect tracking. It requires PHP, MySQL and a web server. Check out our demo and hosting services.

EditPlus Chinese cracked version
Small size, syntax highlighting, does not support code prompt function

Dreamweaver Mac version
Visual web development tools

Atom editor mac version download
The most popular open source editor

WebStorm Mac version
Useful JavaScript development tools
