ホームページ >バックエンド開発 >PHPチュートリアル >PHPデータベース切り替えの問題、オンラインなど
PHP データベース業界データ
RT、私の目的は、1 か所のデータベース リンクを変更し、他のページをクエリするときに新しいリンクを使用することです。 。require_once dirname(__FILE__).'/../common/DbSingleHelper.php'; require_once dirname(__FILE__).'/../svr_yunwei_config.php'; $dbsingleHelper = DBSingleHelper::singleton(); $sql = 'select count(*) as ct from login_log'; $res = $dbsingleHelper -> doSql($sql); echo "查出来的条数:".$res[0]['ct']."<br/>"; //$dbsingleHelper -> changeDbLink("xxxx", "xxx", "xxx", "xxx"); //$r = $dbsingleHelper -> doSql($sql); //echo "新条数:".$r[0]['ct'];
受信データベース条件も選択データベースも表示されません
受信データベース条件も選択データベースも表示されません
public function changeDbLink($server, $user, $pwd, $db_name) { mysql_close(self::$m_con); return $this -> getConnection($server, $user, $pwd, $db_name); } public function killConnetion() { mysql_close(self::$m_con); } //单列方法 public static function singleton() { if(!isset(self::$m_instance)) { $cls = __CLASS__; self::$m_instance = new $cls; } return self::$m_instance; } private function getConnection($server = DB_SERVER, $user = DB_USERID, $pwd = DB_PASSWORD, $db_name = DB_CATALOG) { self::$m_con = mysql_connect($server, $user, $pwd); if(self::$m_con == false) { ErrorLog::saveLog("db connection falid!server:".$server.", user:".$user.", password:".$pwd); exit; } $db_sel = mysql_select_db($db_name); if($db_sel == false) { ErrorLog::saveLog("db can't select database".$dbname); exit; } mysql_query("set names utf8"); return self::$m_con; } public function doSql($sql) { $data_list = array(); $res = $this -> Excute($sql); $i = 0; while($row = mysql_fetch_array($res)) { $data_list[$i] = $row; $i++; } return $data_list; }
changeDbLinkが呼び出されない場合は、もちろん実行できません。データベース
当然、changeDbLink を呼び出さなければ、データベースを他の場所で呼び出すことはできません。 ? ?
同じ接続でクエリの前である限り、どこでも呼び出すことができます
同じ接続でクエリの前である限り、どこでも呼び出すことができます
私はそれをテストしに行きましたmysql_connect の戻り値
self::$m_con = mysql_connect($server, $user, $pwd);var_dump(self::$m_con);
require_once dirname(__FILE__).'/../common/DbSingleHelper.php'; require_once dirname(__FILE__).'/../svr_yunwei_config.php'; $dbsingleHelper = DBSingleHelper::singleton(); $sql = 'select count(*) as ct from login_log'; $res = $dbsingleHelper -> doSql($sql); echo "查出来的条数:".$res[0]['ct']."<br/>";
$dbsingleHelper = DBSingleHelper::singleton(); $site = $_REQUEST['site']; $ip = $svr_url[$site]["url"]; if(substr($ip, 0, 4) == "http") { $ip = substr($ip, 7); } $dbname = "yunwei".$site; $flag = $dbsingleHelper -> changeDbLink($ip.":xx", "xxx", "xxx", $dbname);
シングルトンを使用していないことがわかりましたか? ? ? ? ? ?
両方のページで $dbsingleHelper = DBSingleHelper::singleton() を使用していますが、両方にフラグが立てられていますか? ?
public static function singleton() { if(!isset(self::$m_instance)) { echo "ssssssssssssssssssssssssssss"; $cls = __CLASS__; self::$m_instance = new $cls; } return self::$m_instance; }
情報を確認したところ、PHP 変数はすべてページ レベルであり、ページが再構築のために呼び出されるたびに、ページの実行後にメモリがクリアされると記載されています。同じリンクですか?
2 ページ URL 経由でディスパッチされた場合、同じ接続を使用することはできません
プログラムが終了し、データベースが閉じられます
ただし、シリアル化を通じて 2 ページ間でオブジェクトのシーンを転送できます
2 ページの場合URL 経由でディスパッチされるため、それは不可能です 同じ接続を使用します
プログラムが終了すると、データベースは閉じられます
しかし、シリアル化を通じて 2 ページ間でオブジェクトを転送する方法のサンプルを教えていただけますか?よく分かりません。 。