cloudroam
2025-03-03 4cb9946eff3626389ae93feef4250dd3d45fb694
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
package com.example.firstapp.dao
 
import androidx.room.*
import com.example.firstapp.model.PackageInfo
import com.example.firstapp.model.CourierStat
import com.example.firstapp.model.DailyStat
import kotlinx.coroutines.flow.Flow
 
@Dao
interface PackageDao {
    @Query("SELECT * FROM packages WHERE date(receivedTime/1000, 'unixepoch', 'localtime') = date(:date/1000, 'unixepoch', 'localtime') ORDER BY receivedTime DESC")
    fun getPackagesByDay(date: Long): Flow<List<PackageInfo>>
 
    @Query("""
        SELECT * FROM packages 
        WHERE strftime('%Y-%W', receivedTime/1000, 'unixepoch', 'localtime') = 
              strftime('%Y-%W', :date/1000, 'unixepoch', 'localtime') 
        ORDER BY receivedTime DESC
    """)
    fun getPackagesByWeek(date: Long): Flow<List<PackageInfo>>
 
    @Query("""
        SELECT * FROM CourierStat 
        WHERE EXISTS (
            SELECT 1 FROM packages p 
            WHERE p.courierName = CourierStat.courierName
            AND strftime('%Y-%W', p.receivedTime/1000, 'unixepoch', 'localtime') = 
                strftime('%Y-%W', :date/1000, 'unixepoch', 'localtime')
        )
    """)
    fun getCourierStatsByWeek(date: Long): Flow<List<CourierStat>>
 
    @Query("""
        SELECT * FROM DailyStat 
        WHERE EXISTS (
            SELECT 1 FROM packages p 
            WHERE date(p.receivedTime/1000, 'unixepoch', 'localtime') = DailyStat.date
            AND strftime('%Y-%W', p.receivedTime/1000, 'unixepoch', 'localtime') = 
                strftime('%Y-%W', :date/1000, 'unixepoch', 'localtime')
        )
    """)
    fun getDailyStatsByWeek(date: Long): Flow<List<DailyStat>>
 
    @Insert(onConflict = OnConflictStrategy.REPLACE)
    fun insert(packageInfo: PackageInfo)
 
    @Update
    fun update(packageInfo: PackageInfo)