whychdw
2019-12-03 07814dd376bbeb36d93950eeb93b9e2b6ddc805b
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
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
package com.fgkj.impl;
 
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
 
import com.fgkj.dao.ActionUtil;
import com.fgkj.dao.BaseDAO;
import com.fgkj.dto.Battalram_data;
import com.fgkj.dto.Page;
 
import java.text.ParseException;
import java.util.ArrayList;
import java.util.List;
 
public class Battalram_dataImpl implements BaseDAO{
 
    @Override
    public boolean add(SQLiteDatabase db, Object obj) {
        return false;
    }
 
    @Override
    public boolean update(SQLiteDatabase db, Object obj) {
        return false;
    }
 
    @Override
    public boolean del(SQLiteDatabase db, Object obj) {
        return false;
    }
    @Override
    public List searchAll(SQLiteDatabase db) {
        return null;
    }
    //查询所有实时或者历史告警数据,全部传100
    @Override
    public List serchByCondition(SQLiteDatabase db, Object obj) {
        Battalram_data adata=(Battalram_data)obj;
        String numsql = "select count(*) from tb_battalarm_data where ";
        String sql="  select * from tb_battalarm_data where ";
        //告警类型
        String typeSqlT=" alm_cleared_type!=? ";
        String typeSqlF=" alm_cleared_type=? ";
        if(adata.getAlm_cleared_type()==100){
            sql+=typeSqlT;
            numsql+=typeSqlT;
        }else{
            sql+=typeSqlF;
            numsql+=typeSqlF;
        }
        //排序
        String endSql=" order by alm_start_time desc  ";
        //分页
        String limitSql=" LIMIT ? OFFSET ? ";
        sql=sql+endSql+limitSql;
        
        //查询总数
        Cursor cs = db.rawQuery(numsql, new String[]{String.valueOf(adata.getAlm_cleared_type())});
        cs.moveToFirst();
        int count = cs.getInt(0);
        cs.close();
      
        List list=new ArrayList();
        Cursor rs=db.rawQuery(sql,new String[]{String.valueOf(adata.getAlm_cleared_type()),String.valueOf(adata.getPage().getPageSize()),String.valueOf((adata.getPage().getPageCurr()-1)*adata.getPage().getPageSize())});
        try {
            while (rs.moveToNext()){
                Battalram_data a=new Battalram_data();
                a.setNum(rs.getInt(rs.getColumnIndex("num")));
                a.setBattGroupId(rs.getInt(rs.getColumnIndex("BattGroupId")));
                a.setMonNum(rs.getInt(rs.getColumnIndex("MonNum")));
                a.setAlm_id(rs.getInt(rs.getColumnIndex("alm_id")));
                a.setAlm_signal_id(rs.getInt(rs.getColumnIndex("alm_signal_id")));
                a.setAlm_start_time(ActionUtil.sdf.parse(rs.getString(rs.getColumnIndex("alm_start_time"))));
                a.setAlm_end_time(ActionUtil.sdf.parse(rs.getString(rs.getColumnIndex("alm_end_time"))));
                a.setAlm_value(rs.getDouble(rs.getColumnIndex("alm_value")));
                a.setAlm_is_confirmed(rs.getInt(rs.getColumnIndex("alm_is_confirmed")));
                a.setAlm_confirmed_time(ActionUtil.sdf.parse(rs.getString(rs.getColumnIndex("alm_confirmed_time"))));
                a.setAlm_cleared_type(rs.getInt(rs.getColumnIndex("alm_cleared_type")));
                Page page=new Page();
                page.setPageAll(count);
                a.setPage(page);
                list.add(a);
            }
        } catch (ParseException e) {
            e.printStackTrace();
        }finally {
            rs.close();
        }
        
        return list;
    }
    //查询所有的告警
    public int serchAllNum(SQLiteDatabase db, Object obj) {
        Battalram_data adata=(Battalram_data)obj;
        String sql=" select count(*) as allnum from tb_battalarm_data where ";
        //告警类型
        String typeSqlT="alm_cleared_type!=?";
        String typeSqlF="alm_cleared_type=?";
        if(adata.getAlm_cleared_type()==100){
            sql+=typeSqlT;
        }else{
            sql+=typeSqlF;
        }
        //排序
        String endSql=" order by alm_start_time desc  ";
        List list=new ArrayList();
        Cursor rs=db.rawQuery(sql,new String[]{String.valueOf(adata.getAlm_cleared_type())});
        rs.moveToFirst();
        int count = rs.getInt(0);
        rs.close();
        return count;
    }
    @Override
    public List serchByInfo(SQLiteDatabase db, Object obj) {
        return null;
    }
}