BaseDaoImpl.java 12.1 KB
Newer Older
yanzg's avatar
yanzg committed
1
package com.yanzuoguang.dao.Impl;
yanzg's avatar
yanzg committed
2

yanzg's avatar
yanzg committed
3 4
import com.yanzuoguang.dao.BaseDao;
import com.yanzuoguang.dao.DaoConst;
yanzg's avatar
yanzg committed
5 6
import com.yanzuoguang.db.Impl.AllBeanRowMapper;
import com.yanzuoguang.util.base.ObjectHelper;
yanzg's avatar
yanzg committed
7
import com.yanzuoguang.util.exception.CodeException;
yanzg's avatar
yanzg committed
8
import com.yanzuoguang.util.helper.DateHelper;
yanzg's avatar
yanzg committed
9 10
import com.yanzuoguang.util.helper.StringHelper;
import com.yanzuoguang.util.vo.InitDao;
yanzg's avatar
yanzg committed
11
import com.yanzuoguang.util.vo.MapRow;
yanzg's avatar
yanzg committed
12

yanzg's avatar
yanzg committed
13
import java.util.Date;
yanzg's avatar
yanzg committed
14
import java.util.HashMap;
yanzg's avatar
yanzg committed
15
import java.util.List;
yanzg's avatar
yanzg committed
16 17 18 19 20 21 22 23 24 25 26 27 28 29
import java.util.Map;

/**
 * 数据库操作的基本工具类
 * created by yanzu on 2017/5/30.
 */
public abstract class BaseDaoImpl extends BaseDaoSql implements BaseDao {

    /**
     * 获取当前主键
     *
     * @return
     */
    private String getIdentity() {
yanzg's avatar
yanzg committed
30
        return StringHelper.toString(this.db.queryCell(this.getClass(), "GET_KEY", "SELECT @@IDENTITY"));
yanzg's avatar
yanzg committed
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 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186
    }

    /**
     * 获取主键名称
     *
     * @return 获取主键名称
     */
    protected String getKey() {
        if (this.Table == null) {
            throw new CodeException("类" + this.getClass().getName() + "未发现表结构");
        }
        return this.Table.Table.getKeyName();
    }

    /**
     * 获取主键值
     *
     * @param model 需要获取主键的实体
     * @return
     */
    protected String getKeyString(Object model) {
        String keyField = this.getKey();
        Object key = ObjectHelper.get(model, keyField);
        if (StringHelper.isEmpty(key)) {
            return "";
        }
        String keyString = key.toString();
        if ("0".equals(keyString)) {
            keyString = "";
        }
        return keyString;
    }

    /**
     * 设置主键值
     *
     * @param model 需要设置的实体
     * @param key   需要设置的主键值
     */
    protected void setKeyString(Object model, String key) {
        String keyField = this.getKey();
        ObjectHelper.set(model, keyField, key);
    }

    /**
     * 根据输入参数来获取主键
     *
     * @param from 可以为实体或字符串。为实体时必须包含 主键 字段 或者 id 字段。
     * @return
     */
    protected String getInputKey(Object from) {
        String key;
        if (from != null && from.getClass() == String.class) {
            key = StringHelper.toString(from);
        } else {
            key = this.getKeyString(from);
        }
        if (StringHelper.isEmpty(key)) {
            key = StringHelper.toString(ObjectHelper.get(from, "id"));
        }
        if (StringHelper.isEmpty(key)) {
            key = "";
        }
        return key;
    }

    /**
     * 创建数据,当不传入了主键时,则会自动生成主键,传入时不会生成。
     *
     * @param model 需要创建的数据
     * @return 创建的主键编号, 创建成功,返回主键,否则为空
     */
    public String create(Object model) {
        // 判断主键是字符串和需要生成主键
        boolean isKeyString = this.Table.Table.getKeyType() == String.class;
        String keyString = this.getKeyString(model);

        //  生成主键
        if (StringHelper.isEmpty(keyString) && isKeyString) {
            keyString = StringHelper.getNewID();
            this.setKeyString(model, keyString);
        }

        // 检测数据合法性
        this.check(DaoConst.OperatorTypeCreate, keyString, model);

        // 执行创建的SQL语句
        int ret = updateSql(DaoConst.Create, model);
        // 判断是否需要获取自增编号(主键为整形)
        if (StringHelper.isEmpty(keyString) && !isKeyString) {
            keyString = this.getIdentity();
            this.setKeyString(model, keyString);
        }

        // 最终处理
        this.created(model);

        // 返回执行结果
        String retVal = ret > 0 ? keyString : "";
        return retVal;
    }


    /**
     * 修改数据
     *
     * @param model 需要修改的数据
     * @return 删除的主键编号
     */
    public String update(Object model) {
        String keyString = this.getKeyString(model);
        if (StringHelper.isEmpty(keyString)) {
            throw new CodeException("表" + this.Table.Table.getName() + "主键值为空时不能更新");
        }
        this.check(DaoConst.OperatorTypeUpdate, keyString, model);
        SqlData sqlData = this.getSql(DaoConst.Update);
        int ret = updateSql(sqlData, model);
        String retVal = ret > 0 ? keyString : "";
        return retVal;
    }

    /**
     * 检测数据
     *
     * @param operatorType 操作方法类型
     * @param keyString    主键
     * @param model        需要检测的数据
     */
    protected void check(int operatorType, String keyString, Object model) {
        if (model instanceof InitDao) {
            InitDao to = (InitDao) model;
            to.init();
        }
    }

    /**
     * 保存数据
     *
     * @param model 需要保存的数据
     * @return 保存的主键编号
     */
    public String save(Object model) {
        String id = this.getKeyString(model);
        if (StringHelper.isEmpty(id)) {
            return create(model);
        } else {
            return update(model);
        }
    }

    /**
     * 删除数据
     *
     * @param model 需要删除的数据
     * @return 删除的主键编号
     */
yanzg's avatar
yanzg committed
187
    public int remove(Object model) {
yanzg's avatar
yanzg committed
188
        // 获取来源主键
yanzg's avatar
yanzg committed
189
        Object from = model;
yanzg's avatar
yanzg committed
190
        String keyString = getInputKey(from);
yanzg's avatar
yanzg committed
191
        // 当主键存在值时,直接通过主键删除
yanzg's avatar
yanzg committed
192
        if (!StringHelper.isEmpty(keyString)) {
yanzg's avatar
yanzg committed
193
            // 去掉其他非主键的属性
yanzg's avatar
yanzg committed
194 195
            from = new HashMap<String, Object>();
            this.setKeyString(from, keyString);
yanzg's avatar
yanzg committed
196 197 198 199 200 201 202 203 204 205 206 207
            // 调用删除日志
            this.check(DaoConst.OperatorTypeRemove, keyString, from);
        } else {
            List<MapRow> rows = this.query(MapRow.class, DaoConst.Load, from);
            for (MapRow row : rows) {
                keyString = this.getKeyString(from);
                if (StringHelper.isEmpty(keyString)) {
                    keyString = StringHelper.toString(AllBeanRowMapper.getLoweRowField(row, this.getKey()));
                }
                // 调用删除日志
                this.check(DaoConst.OperatorTypeRemove, keyString, row);
            }
yanzg's avatar
yanzg committed
208 209
        }

yanzg's avatar
yanzg committed
210
        // 调用删除语句
yanzg's avatar
yanzg committed
211
        SqlData sqlData = this.getSql(DaoConst.Remove);
yanzg's avatar
yanzg committed
212
        return updateSql(sqlData, from);
yanzg's avatar
yanzg committed
213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313
    }

    /**
     * 加载数据
     *
     * @param model 加载数据的请求参数
     * @param cls   需要加载的数据的类型
     * @param <T>   返回数据的类型
     * @return 需要返回的数据
     */
    public <T extends Object> T load(Object model, Class<T> cls) {
        // 获取来源主键
        Object from = model;
        String key = this.getInputKey(from);

        // 当主键存在时,只通过主键加载
        if (!StringHelper.isEmpty(key)) {
            from = new HashMap<String, Object>();
            this.setKeyString(from, key);
        }

        // 通过传入数据进行加载
        T to = this.queryFirst(cls, DaoConst.Load, from);
        if (to == null) {
            return to;
        }

        // 判断来源主键是否存在,不存在则获取加载后的主键
        if (StringHelper.isEmpty(key)) {
            key = this.getKeyString(to);
        }

        check(DaoConst.OperatorTypeLoad, key, to);

        return to;
    }

    /**
     * 添加统计数据
     *
     * @param cls   类型
     * @param model 实体
     * @param <T>   泛型类型
     * @return 增加统计的数据编号
     */
    public <T extends Object> String addGroup(Class<T> cls, T model) {
        // 判断前台实体
        if (model == null) {
            return "";
        }

        // 获取前台分组的MD5标识
        String md5 = this.getMd5(DaoConst.GroupQuery, model);
        if (!StringHelper.isEmpty(this.Table.Table.getMD5KeyName())) {
            ObjectHelper.set(model, this.Table.Table.getMD5KeyName(), md5);
        }

        // 获取标识的实体
        T from;
        if (this.Table.Table.getKeyType() == String.class) {
            from = model;
            this.setKeyString(model, md5);
        } else if (!StringHelper.isEmpty(this.Table.Table.getMD5KeyName())) {
            Map<String, Object> map = new HashMap<String, Object>();
            map.put(this.Table.Table.getMD5KeyName(), md5);
            from = this.load(map, cls);
        } else {
            from = this.queryFirst(cls, DaoConst.GroupQuery, model);
        }

        // 当没有存在,则创建,否则 UpdateAdd
        if (from == null) {
            return this.create(model);
        } else {
            // 获取后台的编号,并写入到前台传入的数据上面
            String keyField = this.getKey();
            Object key = ObjectHelper.get(from, keyField);
            ObjectHelper.set(model, keyField, key);

            // 执行更新SQL语句
            SqlData sqlData = this.getSql(DaoConst.GroupAdd);
            int ret = this.updateSql(sqlData, model);
            if (ret < 1) {
                return this.create(model);
            } else {
                return key.toString();
            }
        }
    }

    /**
     * 根据SQL语句名称和实体获取MD5值
     *
     * @param sqlName SQL语句名称
     * @param model   获取加密之后的实体
     * @param <T>     获取的类型
     * @return 获取加密之后的值
     */
    protected <T extends Object> String getMd5(String sqlName, T model) {
        SqlData sql = this.getSql(sqlName);
        StringBuilder sb = new StringBuilder();
yanzg's avatar
yanzg committed
314
        String date = StringHelper.EMPTY;
yanzg's avatar
yanzg committed
315 316 317 318 319 320
        for (SqlDataField field : sql.sqlDataFields) {
            if (sb.length() > 0) {
                sb.append(":");
            }
            Object item = ObjectHelper.get(model, field.paraName);
            sb.append(item);
yanzg's avatar
yanzg committed
321 322 323 324 325 326 327 328 329

            if (StringHelper.isEmpty(date)) {
                String itemString = String.valueOf(item);
                if (item instanceof Date) {
                    date = DateHelper.getDateTimeString((Date) item);
                } else if (DateHelper.isDateFormat(itemString)) {
                    date = itemString;
                }
            }
yanzg's avatar
yanzg committed
330
        }
yanzg's avatar
yanzg committed
331 332
        if (StringHelper.isEmpty(date)) {
            return StringHelper.md5(sb.toString());
yanzg's avatar
yanzg committed
333 334
        } else {
            return StringHelper.getNewMD5Id(DateHelper.getDateTime(date), sb.toString());
yanzg's avatar
yanzg committed
335
        }
yanzg's avatar
yanzg committed
336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395
    }

    /**
     * 添加统计数据列表
     *
     * @param sqlName 需要执行的SQL语句名称
     * @param model   需要执行的SQL语句的实体
     * @return
     */
    protected int addGroupList(String sqlName, Object model) {
        this.updateSql(sqlName + "_GroupInit", model);
        return this.updateSql(sqlName + "_GroupAdd", model);
    }

    /***
     * 查询数据是否存在,当存在时修改,否则增加
     * @param cls 需要创建的实体的类型
     * @param sqlName   执行的SQL语句
     * @param request 前台参数,不能包含主键以及其他不需要修改的字段
     * @return 保存成功,返回保存的ID,保存失败,返回空值
     */
    public <T extends Object> String saveWith(Class<T> cls, String sqlName, Object request) {
        T from = this.queryFirst(cls, sqlName, request);
        if (from == null) {
            try {
                from = cls.newInstance();
            } catch (Exception ex) {
                throw new CodeException("创建对象" + cls.getName() + "出错", ex);
            }
            ObjectHelper.writeWithFrom(from, request);
            return this.create(from);
        } else {
            ObjectHelper.writeWithFrom(from, request);
            return this.update(from);
        }
    }

    /**
     * 创建成功后的处理
     *
     * @param model 创建的实体数据
     */
    protected void created(Object model) {

    }

    /**
     * 执行是否存在的SQL语句
     *
     * @param sqlName SQL语句名称
     * @param model   实体
     * @param msg     消息
     */
    protected void checkExist(String sqlName, Object model, String msg) {
        MapRow row = this.queryFirst(sqlName, model);
        if (row != null) {
            throw new CodeException(msg);
        }
    }
}