Reputation: 661
I am trying to import a large .sql data file using phpMyAdmin in XAMPP. However this is taking a lot of time and I keep getting:
Fatal error: Maximum execution time of 300 seconds exceeded in C:\xampp\phpMyAdmin\libraries\dbi\DBIMysqli.class.php on line 285
And the file is about 1.2 million lines long.
The file is about 30MB big, so it is not that big. I don't really understand why it is taking so long.
;;;;;;;;;;;;;;;;;;;
; Resource Limits ;
;;;;;;;;;;;;;;;;;;;
; Maximum execution time of each script, in seconds
; http://php.net/max-execution-time
; Note: This directive is hardcoded to 0 for the CLI SAPI
max_execution_time=30000
; Maximum amount of time each script may spend parsing request data. It's a good
; idea to limit this time on productions servers in order to eliminate unexpectedly
; long running scripts.
; Note: This directive is hardcoded to -1 for the CLI SAPI
; Default Value: -1 (Unlimited)
; Development Value: 60 (60 seconds)
; Production Value: 60 (60 seconds)
; http://php.net/max-input-time
max_input_time=60
; Maximum input variable nesting level
; http://php.net/max-input-nesting-level
;max_input_nesting_level = 64
; How many GET/POST/COOKIE input variables may be accepted
; max_input_vars = 1000
; Maximum amount of memory a script may consume (128MB)
; http://php.net/memory-limit
memory_limit=200M
The is the config file for php.ini in xampp, for some reason i still get
Fatal error: Maximum execution time of 300 seconds exceeded in C:\xampp\phpMyAdmin\libraries\dbi\DBIMysqli.class.php on line 285.
Upvotes: 56
Views: 220320
Reputation: 653
use mysql workbench , it will import quickly , and will not ask any time error .
Upvotes: 0
Reputation: 315
100% Working Solution
I'm using Xampp:
Step1: open my.ini file from Xampp control panel config option and update below env Variable
myisam_sort_buffer_size=8M
To
myisam_sort_buffer_size=1024M
Navigate to your Xampp folder
C:\xampp\mysql\bin>
Step2: Copy and Paste SQL file you want to import and execute below command in Terminal,
mysql -u user -p test < database.sql
Here user is the user of your Database (i.e root) and test is the database name you created in PHPMyAdmin and after < you have to place your sql file path (in my case there is same directory so i'm placing only name of the file which going to import in our Database).
Hope this Solution Fixed your Problem
Upvotes: 1
Reputation: 419
The working solution:
Update the configuration as mentioned in php.ini file (Located at xampp folder, \xampp\php\php.ini)
post_max_size=1024M
upload_max_filesize=1024M
max_execution_time = 10000
max_input_time=10000
memory_limit=1024M
Update config.inc.php (Located at Xampp folder, \xampp\phpMyAdmin\config.inc.php) if exists update value otherwise add the bellow line
$cfg['ExecTimeLimit'] = 10000;
Update my.ini (Located at Xamp folder, \xampp\mysql\bin\my.ini )
max_allowed_packet=1024M
Stop & Restart Apache & MySQL
Upvotes: 1
Reputation: 6170
There's a configuration variable within the phpMyAdmin directory that you can find in phpmyadmin\config.inc.php
called $cfg['ExecTimeLimit']
that you can set to whatever maximum execution time you need.
Upvotes: 72
Reputation: 393
Set Only 3 Parameters from php.ini
file of your server
A. max_execution_time = 3000000 (Set as per your requirment)
B. post_max_size = 4096M
C. upload_max_filesize = 4096M
Case 1 : If you are Using Xampp, Edit
C:\xampp\phpMyAdmin\libraries\config.default.php
Case 2 : If you are Using Wampp, Edit
c:\wamp64\apps\phpMyAdmin\libraries\config.default.php
Case 3 : If you are Using Laragon, Edit
C:\laragon\etc\apps\phpMyAdmin\libraries\config.default.php
search for $cfg['ExecTimeLimit']
in config.default.php file and make the following changes
$cfg['ExecTimeLimit'] = 0;
After all set, restart your server and import again your database.
Done
Upvotes: 2
Reputation: 29
Changing the max_execution_timeout in php.ini. may help with maximum execution error. but sometimes the database is imported correctly but still it shows maximum execution time error, it can be due to some error of xamp.
I was experiencing the same error even after making all changes in php.ini. which is mentioned above and realized that all the things, tables of database were imported and it was working fine but it was still showing the max_execution_timeout error.
Upvotes: 0
Reputation: 1407
If you are using the laragon
and your database is phpMyAdmin the process is the same for tackle this error.
php.ini
fileconfig.default.php
path is C:\laragon\etc\apps\phpMyAdmin\libraries\config.default.php
$cfg['ExecTimeLimit'] = 0;
I hope it would solve your problem for laragon environment 🙏 #Happy Coding :)
Upvotes: 3
Reputation: 75
1-make a search in your local drive and type "php.ini" 2-you may see many files named php.ini you should choose the one that fits with your php version (see localhost) 3-open the php.ini file make a search on "max_execution_time" then make it equal to "-1" to make it unlimited
Upvotes: 1
Reputation: 245
Best solution for this error when i tried some points. Follow this steps to solve this issue:
Upvotes: 0
Reputation: 189
Set Only 3 Parameters from php.ini
file of your server
A. max_execution_time = 3000000 (Set as per your requirment)
B. post_max_size = 4096M
C. upload_max_filesize = 4096M
Edit C:\xampp\phpMyAdmin\libraries\config.default.php
Page
$cfg['ExecTimeLimit'] = 0;
After all set, restart your server and import again your database.
Done
Upvotes: 18
Reputation: 679
$cfg[‘ExecTimeLimit’] = 0;
means endless execution in the config.inc.php as recommended above. Be aware this is not a "normal" ini file. Its a php script, so you need a open <?php
at the beginning of that file.You have other tools on a server to handle the import.
a) If you have a server admin system like Plesk, use there database import tool.
b) use ssh commands to make database dump or to write databases directly in mysql via ssh. Commands below.
Create a database dump:
mysqldump DBname --add-drop-table -h DBhostname -u DBusername -pPASSWORD > databasefile.sql
Write a database to mysql:
mysql -h rdbms -u DBusername -pPASSWORD DBname < databasefile.sql
Upvotes: 0
Reputation: 33
Simply set $cfg['ExecTimeLimit'] = 0; In xampp/phpMyAdmin/libraries/config.default.php.
Maximum execution time in seconds (0 for no limit).
And make this below changes in php.ini
file as per file size.
post_max_size = 600M
upload_max_filesize = 500M
max_execution_time = 5000
max_input_time = 5000
memory_limit = 600M
But make sure 'post_max_size' and 'memory_limit' should be more than upload_max_filesize.
**Note - Don't forget to restart your server.
Upvotes: 2
Reputation: 4958
Well, to get rid of this you need to set phpMyadmin variable to either 0 that is unlimited or whichever value in seconds you find suitable for your needs. Or you could always use CLI(command line interface) to not even get such errors(For which you would like to take a look at this link.
Now about the error here, first on the safe side make sure you have set PHP parameters properly so that you can upload large files and can use maximum execution time from that end. If not, go ahead and set below three parameters from php.ini file,
Once that's done get back to finding phpMyadmin config file named something like "config.default.php". On XAMPP you will find it under "C:\xampp\phpMyAdmin\libraries" folder. Open the file called config.default.php
and set :
$cfg['ExecTimeLimit'] = 0;
Once set, restart your MySQL and Apache and go import your database.
Enjoy... :)
Upvotes: 48
Reputation: 51
This worked for me.
If you got Maximum execution time 300 exceeded in DBIMysqli.class.php
file. Open the following file in text editor
C:\xampp\phpMyAdmin\libraries\config.default.php
then
search the following line of code:
$cfg[‘ExecTimeLimit’] = 300;
and change value 300
to 900
.
Upvotes: 5
Reputation: 10117
After trying many things with no success, I've managed to get SSH access to the server, and import my 80Mb database with a command line, instead of phpMyAdmin. Here is the command:
mysql -u root -p -D mydatabase -o < mydatabase.sql
It's much easier to import big databases, if you are running xammp on windows, the path for mysql.exe is C:\xampp\mysql\bin\mysql.exe
Upvotes: 1
Reputation: 31740
You're trying to import a huge dataset via a web interface.
By default PHP scripts run in the context of a web server have a maximum execution time limit because you don't want a single errant PHP script tying up the entire server and causing a denial of service.
For that reason your import is failing. PHPMyAdmin is a web application and is hitting the limit imposed by PHP.
You could try raising the limit but that limit exists for a good reason so that's not advisable. Running a script that is going to take a very long time to execute in a web server is a very bad idea.
PHPMyAdmin isn't really intended for heavy duty jobs like this, it's meant for day to day housekeeping tasks and troubleshooting.
Your best option is to use the proper tools for the job, such as the mysql commandline tools. Assuming your file is an SQL dump then you can try running the following from the commandline:
mysql -u(your user name here) -p(your password here) -h(your sql server name here) (db name here) < /path/to/your/sql/dump.sql
Or if you aren't comfortable with commandline tools then something like SQLYog (for Windows), Sequel Pro (for Mac), etc may be more suitable for running an import job
Upvotes: 15
Reputation: 76
you must change php_admin_value max_execution_time
in your Alias config (\XAMPP\alias\phpmyadmin.conf)
answer is here: WAMPServer phpMyadmin Maximum execution time of 360 seconds exceeded
Upvotes: 1
Reputation: 1042
You can increase the limit:
ini_set('max_execution_time', 3000);
(Note that this script can cause high memory usage as well, so you probably have to increase that as well)
Other possible solution: Chunk your sql file, and process it as parts. I assume, it is not one big SQL query, is it?
Update: As @Isaac pointed out, this is about PHPMyAdmin. In this case set max_execution_timeout
in php.ini. (The location depends on your environment)
Upvotes: -2
Reputation: 12432
Is it a .sql file or is it compressed (.zip, .gz, etc)? Compressed formats sometimes require more PHP resources so you could try uncompressing it before uploading.
However, there are other methods you can try also. If you have command-line access, just upload the file and import with the command line client mysql
(once at the mysql>
prompt, use databasename;
then source file.sql
).
Otherwise you can use the phpMyAdmin "UploadDir" feature to put the file on the server and have it appear within phpMyAdmin without having to also upload it from your local machine.
This link has information on using UploadDir and this one has some more tips and methods.
Upvotes: 1
Reputation: 4047
The following might help you:
ini_set('max_execution_time', 100000);
And in your mysql - max_allowed_packet=100M
in some cases where queries are too long sql also produce and error "MySQL server has gone away";
Change the values to whatever you need.
Upvotes: -3