mysql 关键字order

本文详细阐述了在使用SQL语句时误将'order'作为关键字而非字段名所引发的错误,并提供了正确的解决方案。通过实例演示,帮助开发者避免常见的语法陷阱,提升SQL编写效率。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

今天写sql语句时没有注意order是mysql的关键字:

$table = 'order_goods,order,goods';
$join = 'inner,left';
$on = 'order_goods.order_id = order.order_id,order_goods.goods_id = goods.goods_id';
$field = "order.*,order_goods.*,goods.goods_spec";
$where = "";
$where .= " order.store_id = '{$_SESSION [store_id]}' && (order.add_time BETWEEN '$searchtime_arr[0]' AND '$searchtime_arr[1]') ";
$where .= " && ( order.orderState not in (0,1,2))";
$order_list = $model->table($table)->join($join)->on($on)->where($where)->field($field)->limit()->page ()->order('order_goods.order_id desc,order_goods.goods_id desc')->select();

以 order.*查询时会报错,而 order.order_id 不会报错。解决方法:把order.*改成`order`.*。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值