dtu15253 2017-09-04 08:45
浏览 91
已采纳

当此字符串也是字符串变量时,如何为字符串中的变量赋值?

I am having a variable $query1 and in this, I have a query string and in this query string, I have used another variable $sORp. The main problem is that I want to give this $sORp variable a value at runtime without changing my string variable holding the query. Is this possible?

Code Snippet is as below(dummy example):

$query1="SELECT $sORP,name from table1 
    where $sORp=:SRC_NAME 
    group by $sORp,name 
    order by $sORp";

I want to assign this variable $sORp "SRC" and "POOL" at run time as I don't want to write query twice with different values.

Use in code:

$sORp='SRC';
$sql=$query1;
$sth = oci_parse($con,$sql);

And this is not working, Is there any solution for this.

And on running this PHP file the error is: ORA-00936: missing expression

  • 写回答

3条回答 默认 最新

  • dousi2029 2017-09-04 08:52
    关注

    You cannot do this in this scripting language. $sql must be defined after $sORp .

    $sORp='SRC';
    $sth = oci_parse($con,"SELECT $sORP,name from table1 
                            where $sORp=:SRC_NAME 
                         group by $sORp,name 
                         order by $sORp");
    

    If you want your can create a function which will generate the right query on will:;

    function foo($sORp) {
      $retVal="SELECT $sORP,name from table1 
                 where $sORp=:SRC_NAME 
              group by $sORp,name 
              order by $sORp";
      return $retVal;
    }
    
    $sth = oci_parse($con,foo($sORp));
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 关于#matlab#的问题:在模糊控制器中选出线路信息,在simulink中根据线路信息生成速度时间目标曲线(初速度为20m/s,15秒后减为0的速度时间图像)我想问线路信息是什么
  • ¥15 banner广告展示设置多少时间不怎么会消耗用户价值
  • ¥16 mybatis的代理对象无法通过@Autowired装填
  • ¥15 可见光定位matlab仿真
  • ¥15 arduino 四自由度机械臂
  • ¥15 wordpress 产品图片 GIF 没法显示
  • ¥15 求三国群英传pl国战时间的修改方法
  • ¥15 matlab代码代写,需写出详细代码,代价私
  • ¥15 ROS系统搭建请教(跨境电商用途)
  • ¥15 AIC3204的示例代码有吗,想用AIC3204测量血氧,找不到相关的代码。