xuxiuxi
2017-07-20 f3f086afc89eb5007058e6b6214fa6042a39b93b
VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/service/sqlite/RegisterDao.java
@@ -1,8 +1,173 @@
package cn.com.basic.face.service.sqlite;
/**
 * Created by xiuxi on 2017/7/17.
 */
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import org.xutils.http.RequestParams;
import java.io.File;
import cn.com.basic.face.base.Config;
import cn.com.basic.face.discern.query.item.OfflineAttenderRegisterItem;
import cn.com.basic.face.discern.query.item.OfflineVisitorRegisterItem;
import cn.com.basic.face.discern.query.item.UnknownQueryItem;
import cn.com.basic.face.util.FileUtil;
public class RegisterDao {
    public static RegisterDao instance = new RegisterDao();
    public static RegisterDao getInstance() {
        return instance;
    }
    /**
     * 访客注册
     * @param params
     * @param idCardHeadPhoto
     * @return
     */
    public boolean add(RequestParams params, String idCardHeadPhoto) {
        OfflineVisitorRegisterItem item = null;
        String sql =
                "INSERT INTO offline_visitor_register (\n" +
                "   visitor_id,\n" +
                "   username,\n" +
                "   mobile_phone,\n" +
                "   gender_id,\n" +
                "   identity_type_id,\n" +
                "   country_id,\n" +
                "   visitor_type_id,\n" +
                "   identify_num,\n" +
                "   company_id,\n" +
                "   birthday,\n" +
                "   remark,\n" +
                "   raw_surveillance_photo_path,\n" +
                "   raw_surveillance_photo_width,\n" +
                "   raw_surveillance_photo_height,\n" +
                "   surveillance_photo_path,\n" +
                "   upload_custom_photo_path,\n" +
                "   id_card_photo_path,\n" +
                "   create_time\n" +
                ")\n" +
                "VALUES\n" +
                "   (\n" +
                "   null,\n" +
                "   '"+item.getUsername()+"',\n" +
                "   '"+item.getMobilePhone()+"',\n" +
                "   '"+item.getGenderId()+"',\n" +
                "   '"+item.getIdentityTypeId()+"',\n" +
                "   '"+item.getCountryId()+"',\n" +
                "   '"+item.getVisitorTypeId()+"',\n" +
                "   '"+item.getIdentifyNum()+"',\n" +
                "   '"+item.getCompanyId()+"',\n" +
                "   '"+item.getBirthday()+"',\n" +
                "   '"+item.getRemark()+"',\n" +
                "   '"+item.getRawSurveillancePhotoPath()+"',\n" +
                "   '"+item.getRawSurveillancePhotoWidth()+"',\n" +
                "   '"+item.getRawSurveillancePhotoHeight()+"',\n" +
                "   '"+item.getSurveillancePhotoPath()+"',\n" +
                "   '"+item.getUploadCustomPhotoPath()+"',\n" +
                "   '"+item.getIdCardPhotoPath()+"',\n" +
                "   '"+item.getCreateTime()+"'\n" +
                "   )";
        SQLiteDatabase db = Config.sqlMap.getDb();
        db.beginTransaction();
        db.execSQL(sql);
        db.endTransaction();
        return true;
    }
    /**
     * 考勤注册
     * @param params
     * @param idCardHeadPhoto
     * @return
     */
    public boolean addAttender(RequestParams params, String idCardHeadPhoto) {
        return true;
    }
    public boolean hasOfflineVisitorRegisterData() {
        Cursor c = Config.sqlMap.getDb().rawQuery("select count(*) from offline_visitor_register", new String[]{});
        c.moveToFirst();
        return c.getInt(0) > 0 ? true : false;
    }
    public boolean hasOfflineAttenderRegisterData() {
        Cursor c = Config.sqlMap.getDb().rawQuery("select count(*) from offline_attender_register", new String[]{});
        c.moveToFirst();
        return c.getInt(0) > 0 ? true : false;
    }
    public OfflineVisitorRegisterItem readOfflineVisitorRegister() {
        OfflineVisitorRegisterItem item = null;
        String sql =
                "SELECT\n" +
                "   a.visitor_id,\n" +
                "   a.username,\n" +
                "   a.mobile_phone,\n" +
                "   a.gender_id,\n" +
                "   a.identity_type_id,\n" +
                "   a.country_id,\n" +
                "   a.visitor_type_id,\n" +
                "   a.identify_num,\n" +
                "   a.company_id,\n" +
                "   a.birthday,\n" +
                "   a.remark,\n" +
                "   a.raw_surveillance_photo_path,\n" +
                "   a.raw_surveillance_photo_width,\n" +
                "   a.raw_surveillance_photo_height,\n" +
                "   a.surveillance_photo_path,\n" +
                "   a.upload_custom_photo_path,\n" +
                "   a.id_card_photo_path,\n" +
                "   a.create_time\n" +
                "FROM\n" +
                "   offline_visitor_register a";
        SQLiteDatabase db = Config.sqlMap.getDb();
        db.beginTransaction();
        Cursor c = db.rawQuery(sql, new String[]{});
        if (c.moveToFirst()) {
            item = new OfflineVisitorRegisterItem();
            item.setVisitorId(c.getString(c.getColumnIndex("visitor_id")));
            item.setUsername(c.getString(c.getColumnIndex("username")));
            item.setMobilePhone(c.getString(c.getColumnIndex("mobile_phone")));
            item.setGenderId(c.getString(c.getColumnIndex("gender_id")));
            item.setIdentityTypeId(c.getString(c.getColumnIndex("identity_type_id")));
            item.setCountryId(c.getString(c.getColumnIndex("country_id")));
            item.setVisitorTypeId(c.getString(c.getColumnIndex("visitor_type_id")));
            item.setIdentifyNum(c.getString(c.getColumnIndex("identify_num")));
            item.setCompanyId(c.getString(c.getColumnIndex("company_id")));
            item.setBirthday(c.getString(c.getColumnIndex("birthday")));
            item.setRemark(c.getString(c.getColumnIndex("remark")));
            item.setRawSurveillancePhotoPath(c.getString(c.getColumnIndex("raw_surveillance_photo_path")));
            item.setRawSurveillancePhotoWidth(c.getString(c.getColumnIndex("raw_surveillance_photo_width")));
            item.setRawSurveillancePhotoHeight(c.getString(c.getColumnIndex("raw_surveillance_photo_height")));
            item.setSurveillancePhotoPath(c.getString(c.getColumnIndex("surveillance_photo_path")));
            item.setUploadCustomPhotoPath(c.getString(c.getColumnIndex("upload_custom_photo_path")));
            item.setIdCardPhotoPath(c.getString(c.getColumnIndex("id_card_photo_path")));
            item.setCreateTime(c.getString(c.getColumnIndex("create_time")));
        }
        c.close();
        db.endTransaction();
        return item;
    }
    public OfflineAttenderRegisterItem readOfflineAttenderRegister() {
        return null;
    }
    public void removeOfflineVisitorRegister(OfflineVisitorRegisterItem item) {
        try {
            String sql = "delete from offline_visitor_register where visitor_id='"+item.getVisitorId()+"'";
            SQLiteDatabase db = Config.sqlMap.getDb();
            db.beginTransaction();
            db.execSQL(sql);
            db.endTransaction();
            item.deleteFiles();
        }
        catch (Exception e) {
            e.printStackTrace();
        }
    }
}