Everything was working fine in my little project, until I decided to clean up a little bit and moved database-related php-files to their own folder. Then things went strange.
I am trying to use two functions here:
function getEntries () {
require_once("mysqliVariables.php");
$mysqli = new mysqli($dbHost, $dbUname, $dbPwd, $dbName);
$sql = "statement...";
$result = $mysqli->query($sql) or die($mysqli->error);
echo $dbHost; // prints host
return $result;
}
function getBiggestMonth () {
require_once("mysqliVariables.php");
$mysqli = new mysqli($dbHost, $dbUname, $dbPwd, $dbName);
echo $dbHost; // prints nothing! why?
$sql = "statement...";
$result = $mysqli->query($sql) or die($mysqli->error); // this line does not run, of course.
return $result;
}
I use another function in a different file (and folder) to call these functions, that starts like this:
function listTasks() {
require_once("db/mysqliFunctions.php");
// Get entries using mysqli.
$tasks = getEntries();
echo "<pre>";
var_dump($tasks);
echo "</pre>"; // program works fine this far.
$bm = getBiggestMonth(); // program breaks somehow during this function call.
My variables are in a php-file like so:
<?php
$dbHost = "host";
$dbUname = "username";
$dbPwd = "password";
$dbName = "databasename";
?>
If I switch the funtion’s call order, then getBiggestMonth() runs fine and the other one won’t. Also, all of this worked fine when all the files were located in the same folder (the functions were then static functions inside a class, but that shouldn’t be an issue, the same problem persists here), so I dont understand how possible variable scope can be different here, and require_once should take care of other things. Help?
This is because you are using
require_once. It will only include the configuration once. You can change it to userequireso that it will work as you expect.You are using
require_onceto pull in a file into the scope of thegetEntries()function. PHP keeps a record of the files that have beenrequired in so when you then callrequire_onceingetBiggestMonth()it knows it has already been included ingetEntries(). Because it has already been included it does not require the file in again so you don’t get your variables in yourgetBiggestMonth()scope.require_oncedoes not have anything to do with variables it just monitors the files that have been included into the current PHP process.