php数据库连接异常处理,数据库连接PHP

php频繁刷新网页运行一段时间后出现数据库连接错误?

这是由于数据库连接数过多导致的,说明之前建立的连接你没有释放。

创新互联公司专注为客户提供全方位的互联网综合服务,包含不限于网站制作、做网站、临泽网络推广、重庆小程序开发公司、临泽网络营销、临泽企业策划、临泽品牌公关、搜索引擎seo、人物专访、企业宣传片、企业代运营等,从售前售中售后,我们都将竭诚为您服务,您的肯定,是我们最大的嘉奖;创新互联公司为所有大学生创业者提供临泽建站搭建服务,24小时服务热线:028-86922220,官方网址:www.cdcxhl.com

看到你的需求是实时获取数据库里面的内容,可以考虑使用内存数据库,这样返回的效率高,也会避免过多连接的错误。

可以使用redis和memcache来解决这个问题。代码如下,记得首先要安装redis,并且要安装php-redis扩展。

?php

$redis = new Redis();

$redis-connect('127.0.0.1', 6379);//serverip port

$redis-auth('mypassword');//my redis password

$redis -set( "test" , "Hello World");

echo $redis -get( "test");

PHP中处理异常有几种方式?请详述

php中异常处理方法总结:

当异常被触发时,通常会发生:

在PHP5中添加了类似于其它语言的错误异常处理模块。在 PHP代码中所产生的异常可被 throw语句抛出并被 catch 语句捕获。需要进行异常处理的代码都必须放入 try 代码块内,以便捕获可能存在的异常。每一个 try 至少要有一个与之对应的 catch。使用多个 catch 可以捕获不同的类所产生的异常。当 try 代码块不再抛出异常或者找不到 catch 能匹配所抛出的异常时,PHP 代码就会在跳转到最后一个 catch 的后面继续执行。当然,PHP 允许在 catch 代码块内再次抛出(throw)异常。当一个异常被抛出时,其后(译者注:指抛出异常时所在的代码块)的代码将不会继续执行,而 PHP 就会尝试查找第一个能与之匹配的 catch。如果一个异常没有被捕获,而且又没用使用 set_exception_handler() 作相应的处理的话,那么 PHP 将会产生一个严重的错误,并且输出 Uncaught Exception ... (未捕获异常)的提示信息。

1、异常类的层级关系:

代码如下 复制代码

class NotFoundException extends Exception{}

class InputException extends Exception{}

class DBException extends Exception{}

2、配置未捕捉异常的处理器:

代码如下 复制代码

function exception_uncaught_handler(Exception $e) {

header('Content-type:text/html; charset=utf-8');

if ($e instanceof NotFoundException)

exit($e-getMessage());

elseif ($e instanceof DBException)

exit($e-getMessage());

else

exit($e-getMessage());

}

set_exception_handler('exception_uncaught_handler');

3、在数据库连接代码,手动抛出DBException异常但未使用try…catch进行捕获处理,该异常将被PHP自定义异常处理器

代码如下 复制代码

exception_uncaught_handler()函数处理:

$this-resConn = mysql_connect ($CONFIGS['db_host'], $CONFIGS['db_user'], $CONFIGS['db_pwd']);

if (false == is_resource($this-resConn))

throw new DBException('数据库连接失败。'.mysql_error($this-resConn));

4、业务逻辑一瞥:

if (0 != strcmp($curAlbum-interest_id, $it))

throw new NotFoundException('很抱歉,你所访问的相册不存在');

以上就是PHP自定义异常处理器的具体使用方法

实例

代码如下 复制代码

?php

class customException extends Exception

{

public function errorMessage()

{

//error message

$errorMsg = 'Error on line '.$this-getLine().' in '.$this-getFile()

.': b'.$this-getMessage().'/b is not a valid E-Mail address';

return $errorMsg;

}

}

$email = "someone@example.com";

try

{

//check if

if(filter_var($email, FILTER_VALIDATE_EMAIL) === FALSE)

{

//throw exception if email is not valid

throw new customException($email);

}

//check for "example" in mail address

if(strpos($email, "example") !== FALSE)

{

throw new Exception("$email is an example e-mail");

}

}

catch (customException $e)

{

echo $e-errorMessage();

}

catch(Exception $e)

{

echo $e-getMessage();

}

?

例子解释:

上面的代码测试了两种条件,如何任何条件不成立,则抛出一个异常:

1.customException() 类是作为旧的 exception 类的一个扩展来创建的。这样它就继承了旧类的所有属性和方法。

2.创建 errorMessage() 函数。如果 e-mail 地址不合法,则该函数返回一个错误消息。

3.执行 "try" 代码块,在第一个条件下,不会抛出异常。

4.由于 e-mail 含有字符串 "example",第二个条件会触发异常。

5."catch" 代码块会捕获异常,并显示恰当的错误消息

如果没有捕获 customException,紧紧捕获了 base exception,则在那里处理异常。

重新抛出异常

有时,当异常被抛出时,您也许希望以不同于标准的方式对它进行处理。可以在一个 "catch" 代码块中再次抛出异常。

代码如下 复制代码

?php

/*

*/

/*

* 总结:PHP异常的使用方法分三步:

* 第一步:定义异常类,如果不定义就用系统默认的异常类;

* 第二步:当出现异常时用 throw 抛出异常,例如 ex1($num2);异常的参数是$num2用该异常的getMessage()获取;

* 第三步:触发异常,用try子句,当满足条件时 throw new ex1($num);

* 第四步:catch捕获异常 catch (ex2 $e),相当于实例化一个定义好的异常类ex2为$e;

*

* 注意,异常可以定义多个,但是只能触发一个,也就是说只能用catch捕获一个异常

*/

//================基本异常类

//创建可抛出一个异常的函数

function num($num){

if ($num1){//异常抛出条件

$msg=”数值不能大于1″;//异常提示信息

throw new Exception($msg);//抛出异常

}

echo “数值小于1″;

}

//在 “try” 代码块中触发异常

try {

num(3);

echo “执行正常”;

}

//捕获异常

catch (Exception $e){

echo “错误信息:”.$e-getMessage();//Exception()的系统方法获取异常信息

echo “错误文件:”.$e-getFile();//Exception()的系统方法获取异常文件名

echo “行数:”.$e-getLine();//Exception()的系统方法获取异常行数

}

//======================================================================

echo “br========================================================br”;

//扩展基本异常类

function checkEmail($email){//定义一个可以抛出异常的判断EMAIL合法性的函数

if (filter_var($email,FILTER_VALIDATE_EMAIL)==false){

throw new checkEmailException($email);//抛出异常用EMAIL做参数

}

echo “邮件合法”;

}

class checkEmailException extends Exception{//定义扩展异常类

public function errormsg(){

$msg=”错误原因:”.$this-getMessage().”不是一个合法的EMAIL地址!”;

$msg.=”错误文件名:”.$this-getFile();

$msg.=”错误行数:”.$this-getLine();

echo $msg;

}

}

$email=”email…..@chhua.com“;

try {//触发异常

checkEmail($email);

}

//捕获异常

catch (checkEmailException $e){

$e-errormsg();

}

//==================================多个异常的捕获

echo “br===================================================br”;

class ex1 extends Exception{//定义一个异常类

public function msg(){

$msg=”错误原因:”.$this-getMessage().”大于100br”;

$msg.=”错误文件:”.$this-getFile().”Br”;

$msg.=”错误代码:”.$this-getCode().”br”;

$msg.=”行数:”.$this-getLine().”br”;

echo $msg;

}

}

class ex2 extends Exception{//定义一个异常类

public function msg(){

$msg=”错误原因:”.$this-getMessage().”等于100br”;

$msg.=”错误文件:”.$this-getFile().”Br”;

$msg.=”行数:”.$this-getLine().”br”;

echo $msg;

}

}

$num2=100;

try {

if ($num2100){//当条件满足时触发

throw new ex1($num2);

}

if ($num2==100){//当条件满足时触发

throw new ex2($num2);

}

}

catch (ex2 $e){//捕获触发的异常

$e-msg();

}

catch (ex1 $e){//捕获触发的异常

$e-msg();

}

/*

* 总结:PHP异常的使用方法分三步:

* 第一步:定义异常类,如果不定义就用系统默认的异常类;

* 第二步:当出现异常时用 throw 抛出异常,例如 ex1($num2);异常的参数是$num2用该异常的getMessage()获取;

* 第三步:触发异常,用try子句,当满足条件时 throw new ex1($num);

* 第四步:catch捕获异常 catch (ex2 $e),相当于实例化一个定义好的异常类ex2为$e;

*

* 注意,异常可以定义多个,但是只能触发一个,也就是说只能用catch捕获一个异常

*/

?

php连接数据库错误显示mysql_connect not found,配置什么的都配置了

看了你和楼上的对答,有个小建议。

首先你从java转php,说明有语言基础,php基础可以先跳过。

原生写法可能浪费时间,建议你找个php框架入手,里面集成了连接数据库的方法,避免出现如此低级的问题。

还有,你也可以将java的思想带入PHP中,都可以以对象来处理,没必要从这种面对过程方面来学习。

我用XAMPP搭建的PHP环境连接数据库时出现如下错误, 如何解决?

说明mysql_connect

时候就密码错误了,test数据库是可以匿名登录的

php访问数据库出错:Warning: mysql_fetch_array() expects parameter 1 to be resource, boolean given i

php访问数据库出错:Warning: mysql_fetch_array(),是参数设置错误造成的,解决方法如下:

1、首先打开电脑后,同时按住电脑键盘的【开始键】和【R键】,打开电脑的程序运行弹窗。

2、在电脑左下角弹出的程序运行弹窗中,输入字母【cmd】,然后点击【确定】按钮。

3、在弹出的运行界面中,输入【mysql -u root -p】,此时会出现属于密码的命令行,在后面输入自己数据库的密码即可。

4、数据库连接成功后,输入【show global variables like 'port';】,注意不要忘记输入最后的分号。

5、在展现出来的Mysql信息中,可以看到port的值,这个值就是本地数据库的端口号。,一般都是3306。

6、知道本地数据库端口号后,回到php代码的数据库配置中将端口号改成正确的端口号即可,这样就不会报数据库端口异常的错误了。


分享标题:php数据库连接异常处理,数据库连接PHP
新闻来源:http://ybzwz.com/article/dssiopg.html