Передать id last_inserted из одной функции в другую функцию в том же классе в codeigniter - PullRequest
0 голосов
/ 04 февраля 2019

Я хочу передать свою переменную $ lastid другой функции в том же классе.Как я могу это сделать? .. Я пытался что-то, но это не работает?

class ProductmModel extends CI_Model
{

  var $PRODUCTNAME='';
  var $DESCRIPTION='';
  var $CATEGORY='';
  var $SUBCAT='';
  var $IMAGE='';


public function addproductm()
{
$this->load->database();
$data = array(
"p_name" => $this->PRODUCTNAME,
"p_des" => $this->DESCRIPTION,
"cat" => $this->CATEGORY,
"subcat" => $this->SUBCAT

);
$this->db->insert('product_multi', $data);
$lastid = $this->db->insert_id();

}

Это следующая функция

public function addimage()
{
$last= $this->addproductm();
$this->load->database();

$data = array(
"pid" => $lastid,
"images" => $this->IMAGE

);
$this->db->insert('image', $data);
}
}

Ответы [ 3 ]

0 голосов
/ 04 февраля 2019

Вы можете вызвать функцию addimage в вашей первой функции.Я надеюсь, что это поможет.

public function addproductm()
{
$this->load->database();
$data = array(
"p_name" => $this->PRODUCTNAME,
"p_des" => $this->DESCRIPTION,
"cat" => $this->CATEGORY,
"subcat" => $this->SUBCAT
);
$this->db->insert('product_multi', $data);
$lastid = $this->db->insert_id();
$id=$this->addimage($lastid);
}

public function addimage($id)
{
$last= $this->addproductm();
$this->load->database();

$data = array(
"pid" => $id,
"images" => $this->IMAGE

);
$this->db->insert('image', $data);
}
}
0 голосов
/ 04 февраля 2019

Вот способ сделать это.Предположим, у вас есть функция типа

function getCirclePoints($center,$radius){

}

при вызове функции из того же класса

$this->getCirclePoints($latlng,radius));
0 голосов
/ 04 февраля 2019

Во-первых, убедитесь, что у вас есть автоматически увеличенный идентификатор в вашей таблице

Во-вторых, верните $this->db->insert_id() из модели после вставки

public function addproductm()
{
    $this->load->database();
    $data = array(
       "p_name" => $this->PRODUCTNAME,
       "p_des" => $this->DESCRIPTION,
       "cat" => $this->CATEGORY,
       "subcat" => $this->SUBCAT
    );
    $this->db->insert('product_multi', $data);
    return $this->db->insert_id();
}

Здесь вы получили последний вставленный идентификатор вмодель как $last_id = $this->db->insert('image', $data)

Передать $last_id в функцию

public function addimage()
{
   $last= $this->addproductm();
   $this->load->database();

   $data = array(
      "pid" => $lastid,
      "images" => $this->IMAGE
   );
   $last_id = $this->db->insert('image', $data);
   $this->function_name($last_id);
}
...