"/> ">
Heim > Backend-Entwicklung > PHP-Tutorial > ThinkPHP 3.0调用存储过程有关问题

ThinkPHP 3.0调用存储过程有关问题

WBOY
Freigeben: 2016-06-13 13:43:33
Original
984 Leute haben es durchsucht

ThinkPHP 3.0调用存储过程问题

PHP code
<!--

Code highlighting produced by Actipro CodeHighlighter (freeware)
http://www.CodeHighlighter.com/

-->
        $model = D('Demo');
        $str = 'aaa';
        $sql = "SET @uname = '$str'; CALL new_pr(@uname);";
        $data = $model -> query($sql, true);
        echo $model -> getLastSql();

Nach dem Login kopieren


输出
SET @uname = 'aaa'; CALL new_pr(@uname); 
放到查询编辑器里面可以执行

求解

------解决方案--------------------
可能是定界符的问题,试试下面的:
PHP code
$sql = 'delimiter //';
$sql .= "SET @uname = '$str';"
$sql .= "CALL new_pr(@uname)//";
$sql .='delimiter ;';
<br><font color="#e78608">------解决方案--------------------</font><br>你说的情况我遇到过!在thinkphp中调用存储我成我是这样解决的:在链接数据库时多加了个参数就解决了:<br>define('CLIENT_MULTI_RESULTS',131072);<br>$conn =  mysql_connect('127.0.0.1','root','123456','1',CLIENT_MULTI_RESULTS) or die('连接失败');<br><br>你可以试一下!
<br><font color="#e78608">------解决方案--------------------</font><br>
对于 #13 的代码:<br>第一段和第三段除没有对 $str 赋值外,没有什么不同<br>第三段不行的原因,应该是 $str 没赋值<br><br>第一段可以而第二段不可以,则表示  <br>ThinkPHP 3.0 依然没有绕过 php 除声明存储过程外,不能不能在一个 query 中执行一条以上 sql 指令的安全约定<br>你需要分别执行那两条 sql 指令 <div class="clear">
                 
              
              
        
            </div>
Nach dem Login kopieren
Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage