我在mysql表中有一个字段(demo_field)(varchar)。我想用预定义的前缀增加此字段值。
例如,我的字段第一个值是demo001
。现在,当插入新值时,我想增加demo002, demo003
之类的数字。
我怎么能用PHP做到这一点。
答案 0 :(得分:3)
试试这个 -
//fetch data from table
$sql = $mysqli->query('select count(demo_field) as total,demo_field from tablename limit 1');
$res = $sql->fetch_assoc();
//generate string from existing data
$str = substr($res['demo_field'], 0, 4);
$dig = str_replace($str, '', $res['demo_field']);
$dig = $dig+$res['total'];
//add padding if needed
$dig = str_pad($dig, 3, '0', STR_PAD_LEFT);
//concatenate string & digits
$newStr = $str.$dig;
var_dump($newStr);
另一种没有计数的方法
$sql = $mysqli->query('select max(demo_field) as demo_field from demo');
$res = $sql->fetch_assoc();
$str = substr($res['demo_field'], 0, 4);
$dig = str_replace($str, '', $res['demo_field']);
$dig += 1;
$dig = str_pad($dig, 3, '0', STR_PAD_LEFT);
$newStr = $str.$dig;
var_dump($newStr);
希望这可以解决count
的问题。
另一种解决方案,其中包含字母数字字符串的最大计数且没有填充 -
$sql = $mysqli->query('select max(cast(substring(demo_field, 5) as unsigned)) as digit, demo_field from demo');
$res = $sql->fetch_assoc();
$str = substr($res['demo_field'], 0, 4);
$dig = $res['digit'] + 1;
$newStr = $str.$dig;
var_dump($newStr);
答案 1 :(得分:1)
//use PHP not mysql
$pre = 'demo';
$num = 0;
define('MAX', 100);
for($num = 0; $num < MAX; $num++)
{
$pre_str = $pre . sprintf("%03d", $num);
//insert here
}
答案 2 :(得分:0)
你必须使用INT字段 并将其转换为您想要的任何格式&#34;选择&#34;时间。
在MySQL中,我们不能将AutoIncrement用于Varchar。