Rumah > pembangunan bahagian belakang > tutorial php > 这样的递归如何做?

这样的递归如何做?

WBOY
Lepaskan: 2016-06-13 12:59:42
asal
925 orang telah melayarinya

这样的递归怎么做?!

<br />
select a,<br />
(select b from c where ...) as d,<br />
e<br />
from f,(select j from h where ...) as i<br />
where ....<br />
Salin selepas log masuk

我要把外层select ... from ...中,select后面的内容替换掉,而保留from后面的内容。最后变成:
<br />
select count(*)<br />
from f,(select j from h where ...) as i<br />
where ....<br />
Salin selepas log masuk

其实这相当于xml/html节点的替换,类似递归问题,想了很久也没想到解决方法。
------解决方案--------------------
正则....不行

如果你只是想得到返回的行数, 你总是可以这样做:
select count(*) from (

-- 你的sql --<br /> select a,<br /> (select b from c where ...) as d,<br /> e<br /> from f,(select j from h where ...) as i<br /> where ....<br />
) tmp

如果你非要严格做替换, 要做语法分析, 考虑到单双引号, 括号等等....
------解决方案--------------------
不知道你是要写SQL指令,还是要做字符串替换
如果是做字符串替换,可以这么写
$s = <<< TXT<br />
select a,<br />
(select b from c where ...) as d,<br />
e<br />
from f,(select j from h where ...) as i<br />
where ....<br />
TXT;

$ar = preg_split('/(\(?\bselect\b
------解决方案--------------------
\bfrom\b)/i', $s, -1, PREG_SPLIT_NO_EMPTY
------解决方案--------------------
PREG_SPLIT_DELIM_CAPTURE);

$n = 0;
$st = array();
for($i=0; $i $t = strtolower($ar[$i]);
if($t == 'select'
------解决方案--------------------
$t == '(select') {
$st[] = $i;
}
if($t == 'from') {
if(count($st) == 1) break;
array_pop($st);
}
}
for($i--; $i>$st[0]+1; $i--) unset($ar[$i]);
$ar[$st[0]+1] = " count(*)\n";
echo join('', $ar);
Salin selepas log masuk

select count(*)
from f,(select j from h where ...) as i
where ....

Label berkaitan:
sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan