php mysql 如何切换数据库_php切换数据库的问题,在线等

PHP 数据库 行业数据 RT,我的目的是想通过一个地方改变数据库链接,其他页面查询的时候使用新的链接。。

现在我进入一个查询页面tttt.php,用的默认链接,查询出数据为3

然后我通过页面下拉框选择其他区域,选择下拉框的时候我用ajax从后台切换了数据库的链接

这时候我再进入查询页面ttt.php,数据依然是上一个DB的数据,求破。。。

除了把每个区域的DB都列出来切换,请问还有没有其他比较好的方法?(因为区域是动态增加的)

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']."

";//$dbsingleHelper -> changeDbLink("xxxx", "xxx", "xxx", "xxx");//$r = $dbsingleHelper -> doSql($sql);//echo "新条数:".$r[0]['ct'];

上图的代码,把注释打开是正确的,但是问题是我切换的动作是由操作者触发的,在另外一个页面,另外一个页面触发切换后,这个查询的结果依然是上个DB的数据。。。

意思就是我在一个地方切换db后,无法改变所有页面其他的地方。。。尽管用单列也不行

求指点。。。

回复讨论(解决方案)

既没有看到传入的数据库条件,也没有看到选择数据库

既没有看到传入的数据库条件,也没有看到选择数据库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,当然就不能切换数据库了

没有调用changeDbLink,当然就不能切换数据库了 我在其他的地方调用changeDbLink不行吗???

在哪里调用都可以,只要是针对的是同一连接、并且是在查询前

在哪里调用都可以,只要是针对的是同一连接、并且是在查询前

刚去测试了,var_dump了mysql_connect的返回值self::$m_con = mysql_connect($server, $user, $pwd);var_dump(self::$m_con);

其中$m_con是db类的静态变量,并且在每次查询的时候同样var_dump这个值。。

先运行查询页面tttt.php显示结果resource(6) of type (mysql link) 查出来的条数:5(查询的时候var_dump $m_con的值)

然后运行切换DBLINK的页面dbchange.php,显示resource(7) of type (mysql link)(重建链接打印的$m_con的值)

接着再运行tttt.php,结果还是resource(6) of type (mysql link),为什么呢?

tttt.php的代码

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']."

";

changedb.php的代码

$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);

我发现我用的不是单例??????

我2个页面都用$dbsingleHelper = DBSingleHelper::singleton(),但是都打了flag??public static function singleton(){if(!isset(self::$m_instance)){echo "ssssssssssssssssssssssssssss";$cls = __CLASS__;self::$m_instance = new $cls;}return self::$m_instance;}

查了下资料,说php变量都是页面级的,每次调用页面重建,页面执行完毕清理内存,这样我怎么保证我2个页面用的是同一个链接呢

2个页面通过url调度的话,就不可能用同一连接

程序结束,数据库也就关闭了

但是你可以通过序列化在两个页面间传递对象的现场

2个页面通过url调度的话,就不可能用同一连接

程序结束,数据库也就关闭了

但是你可以通过序列化在两个页面间传递对象的现场 能给个sample吗?不是很懂。。

f68f2add0b68e4f9810432fce46917b7.png

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
©️2022 CSDN 皮肤主题:游动-白 设计师:我叫白小胖 返回首页
评论

打赏作者

倪闻天

你的鼓励将是我创作的最大动力

¥2 ¥4 ¥6 ¥10 ¥20
输入1-500的整数
余额支付 (余额:-- )
扫码支付
扫码支付:¥2
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、C币套餐、付费专栏及课程。

余额充值