mysqli 遇到非数字值
A non-numeric value encountered mysqli
遇到非数值
on line number 51 means this line
it show me an error non-numeric value
->update('purchase',array('item_qty'=>'item_qty'+$item_qty));
function upd_sales($upd_sales)
{
$item_name=$upd_sales['item_name'];
$item_qty=$upd_sales['item_qty'];
$this->db
->where('item_code', $item_name)
->update('purchase',array('item_qty'=>'item_qty'+$item_qty));
}
这不是 javascript
array('item_qty'=>'item_qty'+$item_qty)
如果您试图与 +
联系起来。否则添加字符串没有多大意义。也许你想要这个
array('item_qty'=>'item_qty'.$item_qty)
带点.
或者您可能只需要它的值。
array('item_qty'=>$item_qty)
这更有可能是因为 PHP 不关心变量类型,但数据库可能和你的错误说 NON-Numeric
所以 concat 总是会给你一个非数字的字符串在它的类型中。
你在做字符串+数字而不是数学运算
正好在这条线上->update('purchase',array('item_qty'=>'item_qty'+$item_qty));
function upd_sales($upd_sales)
{
$item_name=$upd_sales['item_name'];
$item_qty=$upd_sales['item_qty'];
$this->db
->where('item_code', $item_name)
->update('purchase',array('item_qty'=>$item_qty));
}
function upd_sales($upd_sales)
{
$item_name=$upd_sales['item_name'];
$item_qty=$upd_sales['item_qty'];
$this->db
->where('item_code', $item_name)
->update('purchase',array('item_qty'=>'item_qty'+$item_qty)); //'item_qty is string where as $item_qty in number
}
那是因为您正在尝试获取字符串和数字的总和。
将代码更改为
function upd_sales($upd_sales)
{
$item_name=$upd_sales['item_name'];
$item_qty=$upd_sales['item_qty'];
$this->db
->where('item_code', $item_name)
->update('purchase',array('item_qty'=> $item_qty));
}
试试这个方法,你需要在mysql中写一个方法更新商品数量
function upd_sales($upd_sales)
{
$item_name=$upd_sales['item_name'];
$item_qty=$upd_sales['item_qty'];
$this->db->where('item_code', $item_name)
->set('item_qty', 'item_qty+'.$item_qty, FALSE);
->update('purchase');
}
case $competitor1 : // 竞争对手 1 获胜
$result = $resultwin1;
$won1 = get_post_meta($competitor1, 'won', true);
update_post_meta($competitor1, 'won', $won1 + 1);
wps_update_history ( $competitor1, 'won', '', $lastIP );
update_post_meta($competitor1, 'lasttimestampbattle', current_time( "timestamp" ) );
$lost2 = get_post_meta($competitor2, 'lost', true);
update_post_meta($competitor2, 'lost', $lost2 + 1);
wps_update_history ( $competitor2, 'lost', '', $lastIP );
if ($haswon != "") {
// get actual post title
$postdata = get_post($competitor1);
if ( strlen ( $postdata->post_title ) > 0 )
$result = $postdata->post_title . " " . $haswon;
}
break;
遇到非数值
on line number 51 means this line it show me an error non-numeric value
->update('purchase',array('item_qty'=>'item_qty'+$item_qty));
function upd_sales($upd_sales)
{
$item_name=$upd_sales['item_name'];
$item_qty=$upd_sales['item_qty'];
$this->db
->where('item_code', $item_name)
->update('purchase',array('item_qty'=>'item_qty'+$item_qty));
}
这不是 javascript
array('item_qty'=>'item_qty'+$item_qty)
如果您试图与 +
联系起来。否则添加字符串没有多大意义。也许你想要这个
array('item_qty'=>'item_qty'.$item_qty)
带点.
或者您可能只需要它的值。
array('item_qty'=>$item_qty)
这更有可能是因为 PHP 不关心变量类型,但数据库可能和你的错误说 NON-Numeric
所以 concat 总是会给你一个非数字的字符串在它的类型中。
你在做字符串+数字而不是数学运算
正好在这条线上->update('purchase',array('item_qty'=>'item_qty'+$item_qty));
function upd_sales($upd_sales)
{
$item_name=$upd_sales['item_name'];
$item_qty=$upd_sales['item_qty'];
$this->db
->where('item_code', $item_name)
->update('purchase',array('item_qty'=>$item_qty));
}
function upd_sales($upd_sales)
{
$item_name=$upd_sales['item_name'];
$item_qty=$upd_sales['item_qty'];
$this->db
->where('item_code', $item_name)
->update('purchase',array('item_qty'=>'item_qty'+$item_qty)); //'item_qty is string where as $item_qty in number
}
那是因为您正在尝试获取字符串和数字的总和。
将代码更改为
function upd_sales($upd_sales)
{
$item_name=$upd_sales['item_name'];
$item_qty=$upd_sales['item_qty'];
$this->db
->where('item_code', $item_name)
->update('purchase',array('item_qty'=> $item_qty));
}
试试这个方法,你需要在mysql中写一个方法更新商品数量
function upd_sales($upd_sales)
{
$item_name=$upd_sales['item_name'];
$item_qty=$upd_sales['item_qty'];
$this->db->where('item_code', $item_name)
->set('item_qty', 'item_qty+'.$item_qty, FALSE);
->update('purchase');
}
case $competitor1 : // 竞争对手 1 获胜 $result = $resultwin1;
$won1 = get_post_meta($competitor1, 'won', true);
update_post_meta($competitor1, 'won', $won1 + 1);
wps_update_history ( $competitor1, 'won', '', $lastIP );
update_post_meta($competitor1, 'lasttimestampbattle', current_time( "timestamp" ) );
$lost2 = get_post_meta($competitor2, 'lost', true);
update_post_meta($competitor2, 'lost', $lost2 + 1);
wps_update_history ( $competitor2, 'lost', '', $lastIP );
if ($haswon != "") {
// get actual post title
$postdata = get_post($competitor1);
if ( strlen ( $postdata->post_title ) > 0 )
$result = $postdata->post_title . " " . $haswon;
}
break;