PHP错误Warning:mysql_query()解决方法
php提示错误:Warning:mysql_query()[function.mysql-query]:Accessdeniedforuser'ODBC'@'localhost'(usingpassword:NO)
代码:
<?php classmysqlClass { functionmysqlClass($host='localhost',$user='root',$pw='',$db='mysql') { $this->link=mysql_connect($host,$user,$pw); mysql_select_db($db); } functionquery($sql){ mysql_query($sql); } function__destruct(){ mysql_close($this->link);//multiconstructwillcauseerror } //liehuo,net } $db=newmysqlClass(); $db=newmysqlClass(); $db->query("select*fromuser");
原因:
mysqlClass第二次初使化时,先初使化mysqlClass,得到跟第一个$db相同的$this->link,然后调用__construct函数会把this->link关闭。
最后导致$db中mysql资源为空,弹出错误。
解决办法:
$db=$db?$db:newmysqlClass();
或者
$this->link=mysql_connect($host,$user,$pw,true);
希望提供的解决方法可以真正的帮助到大家。