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

时间:2015-02-26 10:05:34

标签: php mysql

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

例如:如果我的id是“web1”,接下来当我插入shud时给“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;

2 个答案:

答案 0 :(得分:0)

伪实现将是

改变表定义

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}";
    }
}

希望这有帮助

答案 1 :(得分:0)

我认为你可以这样做..把查询写成 " SELECT MAX(CAST(SUBSTRING($ id,4,12)AS UNSIGNED))FROM $ tbl WHERE $ id LIKE'%web%'" 然后将id增加为web +(max + 1)。