首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >concat函数修剪变量

concat函数修剪变量
EN

Stack Overflow用户
提问于 2013-08-19 15:21:23
回答 2查看 80关注 0票数 0
代码语言:javascript
复制
$query="update invoice set
invoice_no=CONCAT('W-',$id,'/1420')
where invoice_id=$id";

在这里$id=004,但每次它更新为id=4,所以我的invoice_no变成了W-4/1420,而我想要这样的W-004/1420谁能帮助我摆脱这个问题

EN

回答 2

Stack Overflow用户

发布于 2013-08-19 15:23:36

在PHP代码中对其进行格式化。使用带有前导零的格式的sprintf()

代码语言:javascript
复制
$query = sprintf('update invoice set 
                  invoice_no="W-%03d/1420" 
                  where invoice_id=%d', $id, $id );

或者为了避免重复$id参数:

代码语言:javascript
复制
$query = sprintf('update invoice set 
                  invoice_no="W-%1$03d/1420" 
                  where invoice_id=%1$d', $id );
票数 1
EN

Stack Overflow用户

发布于 2013-08-19 15:37:27

由于您正在传递一个数字...concat将把它作为一个整数来处理。因此,首先尝试使用php连接它,然后将其传递给您的查询:

代码语言:javascript
复制
$invoice_no = 'W-'.$id.'/1420';
$query="update invoice set
invoice_no='$invoice_no'
where invoice_id=$id";
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/18308382

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档