首页 > 后端开发 > 正文

在php环境中,从oracle中获取数据如何提取具体值?

2024-12-21 01:46:10 | 我爱编程网

今天我爱编程网小编整理了在php环境中,从oracle中获取数据如何提取具体值?相关信息,希望在这方面能够更好帮助到大家。

本文目录一览:

在php环境中,从oracle中获取数据如何提取具体值?

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 ($num>1){//异常抛出条件
$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().”大于100<br>”;
$msg.=”错误文件:”.$this->getFile().”<Br>”;
$msg.=”错误代码:”.$this->getCode().”<br>”;
$msg.=”行数:”.$this->getLine().”<br>”;
echo $msg;
}
}
class ex2 extends Exception{//定义一个异常类
public function msg(){
$msg=”错误原因:”.$this->getMessage().”等于100<br>”;
$msg.=”错误文件:”.$this->getFile().”<Br>”;
$msg.=”行数:”.$this->getLine().”<br>”;
echo $msg;
}
}
$num2=100;
try {
if ($num2>100){//当条件满足时触发
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环境中,从oracle中获取数据如何提取具体值?我爱编程网

PHP通过Modbus Tcp实时获取设备数据

最近我在参与一个与PLC工控相关的项目。项目背景是,一家茶叶工厂已经构建了自动化的工控系统,并且有朋友为茶园监控和天气环境提供了web页面展示,但工控设备的数据展示尚未实现。


目标是获取工控设备数据,这些数据通过在局域网内运行的modbus tcp协议获取。将数据存入数据库,随后,web界面只需按时间顺序从数据库中获取数据即可。


为了访问对方的计算机,我需要对方的授权。因此,我演示了使用modbus的调试工具和后续的PHP代码请求示例。


所需工具包括:



  • Modbus Slave:用于模拟从机端的软件,作为服务端,PHP作为客户端获取数据。


  • Modbus Poll:用于测试和调试Modbus从设备的主机仿真器,这里也当作客户端使用。


  • MThings:一个国产免费软件,既可模拟主机设备又可模拟从机设备。



获取详细信息,可以扫描二维码,输入“modbus模拟”获取地址。


工具操作示例:


Modbus Slave


  1. 建立TCP/IP连接:



    • 点击connection->connection,弹出参数窗口,确认设置。

    • 配置函数,点击setup->slave definition,弹出参数窗口,通常使用默认设置。

    • 修改数据值,双击对应的框,弹出后修改。




  2. 从机参数说明:



    • ID:设备标识,即slave definition中的slave ID。

    • F:当前节点的函数码,用于主机获取特定数据。




  3. 查看发送和接收数据明细:



    • 点击display,弹出面板。




  4. 注意事项:



    • Modbus Slave每次连接仅持续10分钟,可能未激活。




Modbus Poll


  1. 通过TCP获取从机数据:



    • 连接,点击connection->connection,选择TCP/IP。

    • 输入从机IP地址和端口,保存设置。

    • 连接成功后,查看读写定义,按从机配置修改。




  2. 连接失败时的面板提示:



    • Tx = 4:表示向主站发送数据帧次数。

    • Error = 0:表示通讯错误次数。

    • ID = 1:表示模拟的Modbus子设备地址。

    • F = 03:使用的Modbus功能码。

    • SR = 1000ms:扫描周期。




PHP代码演示:




  1. 下载modbus类库包:



    • 使用Composer要求:composer require adduc/phpmodbus




  2. 编写“03 Read Holding Registers”函数示例代码。




  3. 环境要求。




  4. readMultipleRegisters说明:



    • unitId:modbus设备ID,参照从机的slave ID。

    • reference:地址号,对应设备内存中的数据引用。

    • quantity:读取的数据量,参照从机配置的量。




  5. 请求异常情况:



    • socket_connect() failed:从机连接停止,需重新开启。

    • Modbus response error code: 2 (ILLEGAL DATA ADDRESS):数据地址不正确。参照ModbusMaster类的responseCode方法查看。




  6. 返回数组处理:



    • 请求5个数据,返回10个元素数组;请求2个数据,返回4个元素数组,依此类推。




  7. 返回数组与从机数据块地址的对应方式。




  8. 获取设备数据块实际数据:



    • 枚举数据块下索引对应的标识。

    • 筛选并匹配设备数据标识。

    • 实际数据块索引 = (返回数组索引-1)/2。



在php环境中,从oracle中获取数据如何提取具体值?

我爱编程网(https://www.52biancheng.com)小编还为大家带来在php环境中,从oracle中获取数据如何提取具体值?的相关内容。

连接 <? if ($conn=Ora_Logon("user@TNSNAME","password")) { echo "SUCCESS ! Connected to database\n"; }else {echo "Failed :-( Could not connect to database\n";} Ora_Logoff($conn); phpinfo(); ?>  以上代码使用TNSNAME(在你的tnsnames.ora文件中指明)定义的Oracle数据库名称、用户名称和密码连接数据库。在成功连接的基础上,ora_logon函数返回一个非零的连接ID并储存在变量$conn中。   查询   假设与数据库已经连接就绪,下面我们就来实际的应用对数据库的查询。下面的代码演示了一个连接并查询的典型例子: function printoraerr($in_cur) { // 检查Oracle是否出错 // 如果存在错误则显示 // 当指针被激活时每次请求Oracle后调用该函数 if(ora_errorcode($in_cur)) echo "Oracle code - ".ora_error($in_cur)."\n"; return; } if (!($conn=ora_logon("user@TNSNAME","password"))) {echo "Connection to database failed\n"; exit; } echo "Connected as connection - $conn \n"; echo "Opening cursor ... \n"; $cursor=ora_open($conn); printoraerr($cursor); echo "Opened cursor - $cursor \n"; $qry="select user,sysdate from dual"; echo "Parsing the query $qry ... \n"; ora_parse($cursor,$qry,0); printoraerr($cursor); echo "Query parsed \n"; echo "Executing cursor ... \n"; ora_exec($cursor); printoraerr($cursor); echo "Executed cursor \n"; echo "Fetching cursor ... \n"; while(ora_fetch($cursor)) { $user=ora_getcolumn($cursor,0); printoraerr($cursor); $sysdate=ora_getcolumn($cursor,1); printoraerr($cursor); echo " row = $user, $sysdate \n"; } echo "Fetched all records \n"; echo "Closing cursor ... \n"; ora_close($cursor); echo "Closed cursor \n"; echo "Logging off from oracle... \n"; ora_logoff($conn); echo "Logged off from oracle \n"; ?>  显示结果  以下代码演示了怎样查询数据库并将结果输出: function printoraerr($in_cur, $conn) { // 检查Oracle是否出错 // 如果存在错误则显示 // 当指针被激活时每次请求Oracle后调用该函数 // If it encountered an error, we exit immediately if(ora_errorcode($in_cur)) {echo "Oracle code - ".ora_error($in_cur)." n"; ora_logoff($conn); exit; } return; } function exequery($w_qry,$conn) { $cursor=ora_open($conn); printoraerr($cursor,$conn); ora_parse($cursor,$w_qry,0); printoraerr($cursor,$conn); ora_exec($cursor); printoraerr($cursor,$conn); $numrows=0; $w_numcols=ora_numcols($cursor); // 显示头部 echo " \n"; for ($i=0;$i<$w_numcols;$i++) { $align=(ora_columntype($cursor,$i)=="NUMBER")?"RIGHT":"LEFT"; echo "\t ".ora_columnname($cursor,$i)." \n"; } echo " \n"; while(ora_fetch($cursor)) { echo " \n"; for ($i=0;$i<$w_numcols;$i++) { $align=(ora_columntype($cursor,$i)=="NUMBER")?"RIGHT":"LEFT"; if(ora_columntype($cursor,$i)=="LONG") echo " ". ora_getcolumn($cursor,$i)." \n"; else echo " ".ora_getcolumn($cursor,$i)." \n"; printoraerr($cursor,$conn); } $numrows++; echo " \n"; } if ($numrows==0) echo " Query returned no records \n"; else { echo " \n"; echo " Count \n"; echo " $numrows \n"; echo " \n"; } echo " \n"; ora_close($cursor); return; } // 主程序 if(!($conn=ora_logon("user@SID","password"))) { echo "Error: Cannot connect to database\n"; exit; } $qry="SELECT deptno \"Dept\" ,empno \"Emp\" ,empnm \"Name\" ,salary \"Salary\" FROM employee ORDER BY 1,2"; exequery($qry); ora_logoff($conn); ?>  基于HTTP的Oracle登录  将以下代码加在PHP页面代码之前以确认Oracle登录。注意你必须正确设定$ SID。 if(!isset($PHP_AUTH_USER)) { Header("WWW-authenticate: basic realm=\"$SID\""); Header("HTTP/1.0 401 Unauthorized"); $title="Login Instructions"; echo " You are not authorized to enter the site \n"; exit; } else { if (!($conn=ora_logon("$PHP_AUTH_USER@$SID",$PHP_AUTH_PW))) {Header("WWW-authenticate: basic realm=\"$SID\""); Header("HTTP/1.0 401 Unauthorized"); $title="Login Instructions"; echo " You are not authorised to enter the site \n"; exit; }} ?>

以上,就是我爱编程网小编给大家带来的在php环境中,从oracle中获取数据如何提取具体值?全部内容,希望对大家有所帮助!更多相关文章关注我爱编程网:www.52biancheng.com

免责声明:文章内容来自网络,如有侵权请及时联系删除。
与“在php环境中,从oracle中获取数据如何提取具体值?”相关推荐
php中如何读取环境变量
php中如何读取环境变量

php中如何读取环境变量PHP中的环境变量可以通过$_SERVER获取$_SERVER是一个包含服务器端相关信息的PHP全局环境变量,在PHP4.1.0之前的版本使用$HTTP_SERVER_VARS。下面是详细的说明及用法:$_SERVER['PHP_SELF']当前正在执行脚本的文件名,与documentroot相关。在FORM表单中,如执行文件是本身,你可以在ACTI

2025-01-23 10:35:29
php中如何在数组中随机抽取n个数据的值
php中如何在数组中随机抽取n个数据的值

php中如何在数组中随机抽取n个数据的值array_rand()在你想从数组中取出一个或多个随机的单元时相当有用。它接受input作为输入数组和一个可选的参数num_req,指明了你想取出多少个单元-如果没有指定,默认为1。如果你只取出一个,array_rand()返回一个随机单元的键名,否则就返回一个包含随机键名的数组。这样你就可以随机从数组中取出键名和值。主要是用array_

2025-02-20 06:16:35
php如何从文件夹中提取指定的图片
php如何从文件夹中提取指定的图片

PHP中header用法小结本文实例总结了PHP中header用法。分享给大家供大家参考,具体如下:PHP中header()函数的作用是给客户端发送头信息。什么是头信息?这里只作简单解释,详细的自己看http协议。在HTTP协议中,服务器端的回答(response)内容包括两部分:头信息(header)和体内容,这里的头信息不是HTML中的&lt;head

2025-02-12 22:41:29
php方法中如何获取闭包的值?
php方法中如何获取闭包的值?

php方法中如何获取闭包的值?亲,你好,很高兴为你解答该问题首先,你的这个写法是有问题的哦!~class A {                              public function aa() {                  // 函数体为空,所以外面不会有任何输出,即使设置变量来接受该方法,也不会有任何返回         // 所以你肯定拿不到123

2024-08-24 09:41:13
php页面如何获取请求的url中的参数值
php页面如何获取请求的url中的参数值

urlPHPURL地址获取函数代码端口等推荐在PHP中,获取URL地址是一个基础但重要的操作,涉及到当前脚本的路径、域名、端口等信息。以下是一些用于获取不同URL信息的代码示例。首先,获取当前脚本网址(只包含路径)的代码如下:phpfunctionGetCurUrl(){if(!empty($_SERVER["REQUEST_URI"])){$scrtName=$_S

2024-11-21 14:14:00
php如何获取网址中的参数
php如何获取网址中的参数

php如何获取网址中的参数比如有一个网址为域名/goods.php?u=59&amp;id=24#pinglun我想得到这个id值可以用正则,也可以用php函数解析到数组中用正则可以这样preg_match('/id=(\d+)/',$_SERVER["REQUEST_URI"],$m);//$_SERVER这个表示当前网址urlprint_r

2024-07-23 23:48:12
如何正确理解PHP获取显示数据库数据函数
如何正确理解PHP获取显示数据库数据函数

如何正确理解PHP获取显示数据库数据函数1、PHP获取显示数据库数据函数之mysql_result()mixedmysql_result(resourceresult_set,introw[,mixedfield])从result_set的指定row中获取一个field的数据.简单但是效率低.举例:$link1=@mysql_connect("server1","webu

2024-07-21 15:51:08
php表单怎样提交到当前页面,并用$_POST获取其值?(从表单上输入圆柱的半径和高,然后PHP中求体积)
php表单怎样提交到当前页面,并用$_POST获取其值?(从表单上输入圆柱的半径和高,然后PHP中求体积)

php表单怎样提交到当前页面,并用$_POST获取其值?示例如下:&lt;?php//如果post提交,则进入ifif($_POST){    print_r($_POST);}?&gt;&lt;!DOCTYPE HTML&gt;&lt;html lang="zh-CN"&gt;&lt;head&gt;&lt;meta charset="utf-8" /&gt;&lt;title&gt

2024-11-16 20:12:55