获取最后插入的varchar id,该id是主键


getting a last inserted varchar id which is an primary key

我有多个表,必须使用不同的形式插入,所有表都有一个id,它是主键及其varchar(NOT NULL),所以我有一个名为id_calc($tbl,$id)的类函数,其中$tbl是一个具有表名的参数,$id是一个字段id。每次插入时,都必须为id调用此函数。

例如:如果我的id是"web1",那么接下来当我插入它时,会给出"web2"、"web3"。。。。。。我尝试过LAST_INSERT_ID(),但它不起作用。所以我尝试过获取max(ID)并拆分字符串和变量,但也遇到了一些问题。所以我该如何做到这一点。请帮忙!!!

class first{
public function id_calc($tbl,$id)
    {
        $sql = mysql_query("SELECT max($id) FROM $tbl where $id like '%web%'");
        if($sql)
        {
            while ($row = mysql_fetch_assoc($sql)) 
             {
             $user=$row;
             $a=implode(" ",$user);
        }   
     $pattern = "/('d+)/";
     $array = preg_split($pattern, $a, -1, PREG_SPLIT_NO_EMPTY | PREG_SPLIT_DELIM_CAPTURE);
     $new[]=$array['0'];
     $new[]=$array['1']+1;
     $result=implode("",$new);
        return $result;
        }
    }
}

这个函数被称为类似

 public function insertreport1()
    {
    $obj=new first();
    $id=$obj->id_calc(tablename,idfield);
    //insert query
    }

这是我的表格结构

CREATE TABLE `report` (
  `inc_id` varchar(25) NOT NULL,
  `inc_status` int(11) NOT NULL,
  `inc_date` datetime NOT NULL,
  `inc_Name` varchar(45) NOT NULL,
  `inc_Age` int(11) NOT NULL,
  `inc_Gender` varchar(45) NOT NULL,
  `inc_Mobile` varchar(45) NOT NULL,
  `inc_Address` varchar(250) NOT NULL,
  `inc_treatment` varchar(45) DEFAULT NULL,
  `inc_userid` varchar(10) NOT NULL,
  `inc_repTime` datetime NOT NULL
  PRIMARY KEY (`inc_id`),
) ENGINE=InnoDB DEFAULT CHARSET=latin1;

我想你可以这样做。。将查询编写为"从$tbl中选择最大值(CAST(将($id,4,12)替换为未签名),其中$id类似于"%web%"然后将id递增为web+(max+1)。

伪实现将是

更改表格定义

alter table `table` add column id int(11) not null auto_increment

更改代码

public function id_calc($tbl,$idcol) {
    $sql = mysql_query("SELECT id FROM $tbl order by id desc limit 1");
    if($sql){
        while($row = mysql_fetch_assoc($sql));
        $id = isset($row['id']) ? $row['id'] + 1 : 1;
        return "{$idcol}{$id}";
    }
}

希望这能帮助