defaultOrderมีอาร์เรย์โดยที่คีย์คือชื่อคอลัมน์และค่าคือ a   SORT_DESCหรือ   SORT_ASCนั่นคือสาเหตุที่โค้ดด้านล่างไม่ทำงาน
$dataProvider = new ActiveDataProvider([
        'query' => $query,
        'sort' => ['defaultOrder'=>'topic_order asc']
    ]);
วิธีที่ถูกต้อง
$dataProvider = new ActiveDataProvider([
    'query' => $query,
    'sort' => [
        'defaultOrder' => [
            'topic_order' => SORT_ASC,
        ]
    ],
]);
หมายเหตุ: หากแบบสอบถามระบุอนุประโยค orderBy อยู่แล้วคำสั่งการสั่งซื้อใหม่ที่กำหนดโดยผู้ใช้ปลายทาง (ผ่านการกำหนดค่าการเรียงลำดับ) จะถูกผนวกเข้ากับอนุประโยค orderBy ที่มีอยู่ ขีด จำกัด และส่วนออฟเซ็ตที่มีอยู่จะถูกเขียนทับโดยคำขอแบ่งหน้าจากผู้ใช้ปลายทาง (ผ่านการกำหนดค่าการแบ่งหน้า)
คุณสามารถเรียนรู้รายละเอียดได้จาก 
 Yii2 Guide of Data Provider
การเรียงลำดับโดยส่งเรียงลำดับวัตถุในแบบสอบถาม
 $sort = new Sort([
        'attributes' => [
            'age',
            'name' => [
                'asc' => ['first_name' => SORT_ASC, 'last_name' => SORT_ASC],
                'desc' => ['first_name' => SORT_DESC, 'last_name' => SORT_DESC],
                'default' => SORT_DESC,
                'label' => 'Name',
            ],
        ],
    ]);
    $models = Article::find()
        ->where(['status' => 1])
        ->orderBy($sort->orders)
        ->all();