mysql - larval ORM 模型使用find方法無法準確的查找到對應的數據
問題描述
mysql 數據表主鍵Order_ID為bigint(20),使用Order模型查找對應的訂單卻找到了其他的訂單。比如:Order:find(20170214006401),卻查找到Order_ID為20161009000577的訂單.調用代碼如下:<?php$rsOrder = Order::find(20170214006401)->first()->toArray();?>
Order模型如下<?phpuse IlluminateDatabaseEloquentSoftDeletes;
class Order extends IlluminateDatabaseEloquentModel {
use SoftDeletes;protected $dates = [’deleted_at’];//protected $fillable = [’Order_Status’];protected $fillable = array(’Order_Status’,’Is_withdraw’,’Withdraw_Time’);protected $primaryKey = 'Order_ID';protected $table = 'user_order';public $timestamps = false;// 多wherepublic function scopeMultiwhere($query, $arr) { if (!is_array($arr)) {return $query; } foreach ($arr as $key => $value) {$query = $query->where($key, $value); } return $query;}
//無需日期轉換
public function getDates() { return array();}/** * 指定時間內的訂單 * @param $Users_ID 店鋪唯一標識 * @param $Begin_Time 開始時間 * @param $End_Time 結束時間 * @return array 訂單列表 */public function ordersBetween($Users_ID, $Begin_Time, $End_Time, $Order_Status) { $builder = $this::where(’Users_ID’, $Users_ID); if ($Order_Status != ’all’) {$builder = $builder->where(’Order_Status’, $Order_Status); }$builder->whereBetween(’Order_CreateTime’, [$Begin_Time, $End_Time])->orderBy(’Order_CreateTime’, ’desc’); return $builder;}
}
問題解答
回答1:代碼來自:/vendor/laravel/framework/src/Illuminate/Database/Query/Builder.php
public function find($id, $columns = [’*’]) {return $this->where(’id’, ’=’, $id)->first($columns); }
find方法好像默認為id為主鍵進行查找的
回答2:find方法默認搜索的是主鍵
相關文章:
1. 數組按鍵值封裝!2. docker不顯示端口映射呢?3. java - 阿里的開發手冊中為什么禁用map來作為查詢的接受類?4. Docker for Mac 創建的dnsmasq容器連不上/不工作的問題5. python - flask _sqlalchemy 能否用中文作為索引條件6. python3.x - git bash如何運行.bat文件?7. javascript - ES6規范下 repeat 函數報錯 Invalid count value8. 主題切換問題,用過別人的webapp在后臺切換模板主題后手機端打開網頁就是切換到的主題了9. clone - git sourceTree克隆倉庫時,都不停彈出Password Required彈窗,即時輸入正確的git賬號密碼還是彈出10. html5 - 使用echarts中的圖表 一個頁面導入了好幾個js圖表 實現echarts圖表隨著瀏覽器窗口變化而變化時出現了問題
