0

我想将一个 php 变量发送到一个运行 mysql 查询的类。这是通过 html 表单进行的典型搜索。我必须使用 Smarty。

如何将变量“$minta”传递给 sql 查询以及如何将结果数组返回给 php 以显示?

Smarty tpl 文件正常(lista_keres.tpl 和 ingatlank 变量)。

先感谢您。

图万笔

php:

if (isset($_POST['keresoszo'])){

  include_once "classes/ingatlan.class.php";
  include_once "classes/main.class.php";
  include_once "classes/felhasznalo.class.php";

  $ingatlan = new Ingatlan();
  $felhasznalo = new Felhasznalo();
  $minta = $_POST['keresoszo'];

  $kereses = new Main();
  $kereses->getKeresIngatlan($minta);

        $smarty->assign("kapcsolattartok", $ingatlan->getKapcsolattartok());
        $smarty->assign("ingatlank", $main->getKeresIngatlan());
        $smarty->assign("include_file", lista_keres);

 echo $minta;

}

班上:

<?php

class Main{
private $keresoszo;
...
public function getKeresIngatlan($minta){

    $this->keresoszo=$minta;

    $ret = array();
    $sql="SELECT id FROM table WHERE id LIKE '% ".$keresoszo." %'";
    $ret = $this->db->GetArray($sql);
    return $ret;
}

}
?>
4

1 回答 1

0

声明private $keresoszo; 它成为类对象并且可以通过 $this->keresoszo在您的 sql 查询中访问您已将值分配给该对象但尚未使用它

<?php

class Main{
private $keresoszo;
...
public function getKeresIngatlan($minta){

    $this->keresoszo=$minta;

    $ret = array();
    $sql="SELECT id FROM table WHERE id LIKE '% ".$this->keresoszo." %'";
    $ret = $this->db->GetArray($sql);
    return $ret;
}

}
?>

这是您如何取回结果的方法

  $kereses = new Main();
  $results_set=$kereses->getKeresIngatlan($minta);
  var_dump($results_set);// for testing only 
        $smarty->assign("my_results_set", $results_set);
于 2013-07-17T14:19:06.613 回答