Глобалы обычно считаются плохой практикой. Я не буду рассказывать вам об этом, но прочитайте эту статью: http://blog.case.edu/gps10/2006/07/22/why_global_variables_in_php_is_bad_programming_practice
Вы можете использовать суперглобальный $GLOBALS
для доступа к любой переменной, определенной в глобальной области ( docs ). Таким образом, в вашем примере кода простое использование $GLOBALS['mysql_db1']
будет эквивалентно наличию строки global $mysql_db1;
, а затем использованию $mysql_db1
.
Я не могу достаточно подчеркнуть (не понтифицировав), насколько это плохой план. Вы можете быть в порядке с ним все время, пока вы разрабатываете, но бедный бедный Джонни Следующий, и пусть Боги Кодекса спасут вас, если вы включите сторонний скрипт, который также использует глобальные переменные ... и существует конфликт переменных имена. Теперь вы за это!
Как уже было предложено, вам лучше инкапсулировать функциональность вашей базы данных в классе. Если вы используете статический класс, у вас все еще есть все преимущества глобальной переменной без загрязненной области видимости или опасности перезаписи.
Вот пример класса базы данных вместе с использованием:
// put this in a library file or some place that all scripts include
require_once('database_class.php');
$db = new db(array(
'host'=>'localhost'
'user'=>'db_user_name'
'password'=>'db_password',
'database_name'=>'my_database'
));
// now anywhere in code you want to use it
$array = db::getRows('SELECT id, name FROM users');
$field = db::getField('SELECT name FROM users WHERE id=10');
<?php
// database_class.php
class db {
static protected $resource_link = null;
function __construct($args=false) {
if ($args===false || !is_array($args))
return false;
if (
!isset($args['host']) ||
!isset($args['user']) ||
!isset($args['password']) ||
!isset($args['database_name'])
)
return critical_error('Missing database configuration data.');
self::$resource_link = @mysql_connect($args['host'],$args['user'],$args['password']);
if (!self::$resource_link)
return critical_error('Error connecting to database 2001. MySQL said:<br>'.mysql_error());
@mysql_select_db($args['database_name'], self::$resource_link);
return;
}
// return a single-dimmension array of fields as string
static public function getFields ($sql=false, $field=false) {
$res = null;
if ($sql!==false) {
$query_obj = mysql_query($sql, self::$resource_link);
if ($query_obj) {
$res = array();
while ($this_row = mysql_fetch_array($query_obj)) {
if ($field !== false && isset($this_row[$field]))
$res[] = $this_row[$field];
else
$res[] = $this_row[0];
}
} // end :: if query object is not null
} // end :: if $sql is not false
return $res;
}
// return a single-dimmension array of fields as string with keyfield as key
static public function getKeyFields ($sql=false, $key_field='id', $list_field='id') {
$res = null;
if ($sql!==false) {
$query_obj = mysql_query($sql, self::$resource_link);
if ($query_obj) {
while ($this_row = mysql_fetch_array($query_obj)) {
if (isset($this_row[$key_field]))
$res[$this_row[$key_field]] = $this_row[$list_field];
}
} // end :: if query object is not null
} // end :: if $sql is not false
return $res;
}
// return a single field as string from the first row of results
static public function getField ($sql=false) {
$res = null;
if ($sql!==false) {
$query_obj = mysql_query($sql, self::$resource_link);
if ($query_obj) {
$this_array = mysql_fetch_array($query_obj);
if (is_array($this_array))
return $this_array[0];
} // end :: if query object is not null
} // end :: if $sql is not false
return $res;
}
// return a single row as an array
static public function getRow ($sql=false) {
$res = null;
if ($sql!==false) {
$query_obj = mysql_query($sql, self::$resource_link);
if ($query_obj)
$res = mysql_fetch_assoc($query_obj);
} // end :: if $sql is not false
return $res;
}
// return an array of rows as arrays of strings
static public function getRows ($sql=false) {
$res = null;
if ($sql!==false) {
$query_obj = mysql_query($sql, self::$resource_link);
$res = array();
if ($query_obj) {
while ($this_row = mysql_fetch_assoc($query_obj)) {
$res[] = $this_row;
}
} // end :: if query object is not null
} // end :: if $sql is not false
return $res;
}
// return an array of rows as arrays of strings, using specified field as main array keys
static public function getKeyRows ($sql=false, $key_field='id', $include_key_in_results=true) {
$res = null;
if ($sql!==false) {
$query_obj = mysql_query($sql, self::$resource_link);
if ($query_obj) {
$res = array();
while ($this_row = mysql_fetch_assoc($query_obj)) {
if (isset($this_row[$key_field])) {
$res[$this_row[$key_field]] = $this_row;
if ($include_key_in_results == false)
unset($res[$this_row[$key_field]][$key_field]);
} // end :: if checking for key field in result array
} // end :: while looping query obj
} // end :: if query object is not null
} // end :: if $sql is not false
return $res;
}
// do an update query, return true if no error occurs
static public function update ($sql=false) {
$res = false;
if ($sql!==false) {
$query_obj = mysql_query($sql, self::$resource_link);
if ($query_obj && strlen(mysql_error()) < 1)
$res = true;
}
return $res;
}
// do an insert query, return the auto increment ID (if there is one)
static public function insert ($sql=false) {
$res = null;
if ($sql !== false) {
$query_obj = mysql_query($sql, self::$resource_link);
if ($query_obj)
$res = mysql_insert_id(self::$resource_link);
}
return $res;
}
}
?>