ludc
2025-01-15 d42f321ca241ab7f8bb3cdc71f11fe5ec4ebc48d
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
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
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
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
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
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
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
package com.vci.web.service;
 
import com.vci.common.qt.object.Condition;
import com.vci.common.qt.object.QueryTemplate;
import com.vci.corba.omd.data.BusinessObject;
import com.vci.corba.omd.data.LinkObject;
import com.vci.pagemodel.BatchCBO;
import com.vci.starter.web.exception.VciBaseException;
import com.vci.starter.web.pagemodel.DataGrid;
import com.vci.starter.web.pagemodel.PageHelper;
import com.vci.starter.web.wrapper.VciQueryWrapperForDO;
 
import java.util.Collection;
import java.util.List;
import java.util.Map;
 
/**
 * 业务类型操作服务---只能在dao层调用,其他的服务不允许使用
 * 自动封装了平台相关的操作
 * @author weidy
 */
public interface WebBoServiceI {
 
    /**
     * 是否使用数据权限过滤
     * 在查询中conditonMap里面设置这个key即可
     */
     final String QUERY_FILTER_DATARIGHT = "${QUERY_FILTER_DATARIGHT}";
 
    /**
     * 是否使用密级过滤
     */
     final String QUERY_FILTER_SECRET="${QUERY_FILTER_SECRET}";
 
    /**
     * 初始化业务类型
     * --第一次调用的时候会相对慢一下,后续获取就很快的
     * --注意在服务启动时才会清除缓存
     * --创建人默认为当前用户,如果需要修改,可以在获取后自行处理
     * @param btmName 业务类型的名称,会自动变成小写
     * @return
     * @throws VciBaseException
     */
     BusinessObject createCBOByBtmName(String btmName) throws VciBaseException;
    
    /**
     * 根据查询条件来查询业务类型下的数据
     * @param btmType 业务类型的名称,会自动变成小写
     * @param conditionMap 查询条件,注意介于...之间使用xxx_start和xxx_end
     * @return
     * @throws VciBaseException
     */
     List<BusinessObject> queryCBO(String btmType, Map<String, String> conditionMap) throws VciBaseException;
    
    /**
     * 支持排序和分页的查询业务类型下的数据
     * @param btmType 业务类型的名称
     * @param conditionMap 查询条件,注意介于...之间使用xxx_start和xxx_end
     * @param ph 排序和分页
     * @return 
     * @throws VciBaseException
     */
     List<BusinessObject> queryCBO(String btmType, Map<String, String> conditionMap, PageHelper ph) throws VciBaseException;
    
    /**
     * 支持自定义查询字段(包括参照、枚举和生命周期)
     * @param btmType 业务类型
     * @param conditionMap 查询条件
     * @param ph 分页和排序
     * @param clauseList 查询字段,参照字段使用field.yy;枚举字段使用enumCode_field;生命周期会自动处理为lcStatus_text。根据字段映射Map的key而来。
     * @return
     * @throws VciBaseException
     */
     List<BusinessObject> queryCBO(String btmType, Map<String, String> conditionMap, PageHelper ph, List<String> clauseList) throws VciBaseException;
 
    /**
     * 拷贝分页和排序的设置到查询模板
     * @param qt 查询,模板
     * @param pageHelper 分页对象
     */
    void setPageAndOrderToQT(QueryTemplate qt, PageHelper pageHelper);
 
    /**
     * 查询枚举的信息
     * @param cbo 业务数据
     * @param clo 链接属性
     * @param enumAttrName 枚举的名称
     * @throws VciBaseException 查询枚举出错的时候会抛出异常
     */
    void queryEnumText(BusinessObject cbo, LinkObject clo, List<String> enumAttrName) throws VciBaseException;
 
    /**
     * 给链接类型设置属性
     * @param clo 链接类型
     * @param attributeName 属性的名称
     * @param attributeValue 属性的值
     */
     void setAttributeValueForClo(LinkObject clo, String attributeName, String attributeValue);
 
    /**
     * 使用查询方案来查询数据,返回CBO
     * @param queryScheme 查询方案
     * @param conditionMap 查询条件
     * @param replaceMap 替换查询方案里的变量值
     * @return
     * @throws VciBaseException
     */
     List<BusinessObject> queryCBOByScheme(String queryScheme, Map<String, String> conditionMap, Map<String, Object> replaceMap) throws VciBaseException;
    
    /**
     * 使用查询方案来查询数据,返回CBO,支持分页
     * @param queryScheme 查询方案
     * @param conditionMap 查询条件
     * @param replaceMap 替换查询方案里的变量值
     * @param ph 分页和排序
     * @return
     * @throws VciBaseException
     */
     List<BusinessObject> queryCBOByScheme(String queryScheme, Map<String, String> conditionMap, Map<String, Object> replaceMap, PageHelper ph) throws VciBaseException;
 
    /**
     * 使用名字获取查询模板
     * @param name 名称
     * @param replaceMap 源数据
     * @return 查询模板
     * @throws VciBaseException 查询出错的时候会抛出异常
     */
    QueryTemplate getQtByName(String name, Map<String, Object> replaceMap) throws VciBaseException;
 
    /**
     *  使用查询方案来查询数据,返回CBO,支持自定义查询字段,包括参照和枚举;参照字段使用xxx.yy;枚举字段使用xxx_enumCode
     * @param queryScheme 查询方案
     * @param conditionMap 查询条件
     * @param replaceMap 替换查询方案里的变量值
     * @param ph 分页和排序
     * @param clauseList 查询字段
     * @return
     * @throws VciBaseException
     */
     List<BusinessObject> queryCBOByScheme(String queryScheme, Map<String, String> conditionMap, Map<String, Object> replaceMap,
                                           PageHelper ph, List<String> clauseList) throws VciBaseException;
 
    /**
     * 查询数量
     * @param btmType 业务类型名称
     * @param conditionMap 查询条件
     * @return
     * @throws VciBaseException
     */
     int queryCount(String btmType, Map<String, String> conditionMap) throws VciBaseException;
 
    /**
     * 使用sql查询个数,最终的字段必须是count
     * @param sql 查询的sql
     * @param conditionMap 查询条件
     * @return 个数,
     * @throws VciBaseException 查询出错的时候会抛出异常
     */
    int queryCountBySql(String sql,Map<String,String> conditionMap) throws VciBaseException;
    
    /**
     * 使用查询方案来查询数量
     * @param queryScheme 查询方案
     * @param conditionMap 查询条件
     * @param replaceMap 替换查询方案里的变量值
     * @return
     * @throws VciBaseException
     */
     int queryCountByScheme(String queryScheme, Map<String, String> conditionMap, Map<String, Object> replaceMap) throws VciBaseException;
    
    /**
     * 使用对象来查询数量
     * @param c 对象所属类
     * @param conditionMap 查询条件
     * @return
     * @throws VciBaseException
     */
     int queryCount(Class c, Map<String, String> conditionMap) throws VciBaseException;
 
    /**
     * 根据sql语句来查询内容
     * @param sql 为了防止SQL注入,值必须在sql语句里以:xxx格式,如 id =:idvalue,然后在conditionMap中添加建为idvalue的格式
     * @param conditionMap 查询条件,必须与sql里对应
     * @return CBO
     * @throws VciBaseException
     */
     List<BusinessObject> queryBySql(String sql, Map<String, String> conditionMap) throws VciBaseException;
 
    /**
     * 只用sql语句查询,这个和queryBySql区别是,特殊的sql(如包含有函数的)可以用这个方法,但是有sql注入风险
     * @param sql sql语句,查询条件必须自行在其中处理完成
     * @return CBO
     * @throws VciBaseException 查询出错活抛出异常
     */
    List<BusinessObject> queryByOnlySql(String sql) throws VciBaseException;
 
    /**
     * 只用sql语句查询,这个和queryBySqlForMap区别是,特殊的sql(如包含有函数的)可以用这个方法,但是有sql注入风险
     * @param sql sql语句,查询条件必须自行在其中处理完成
     * @return 数据映射。Map中,key值为大写。
     * @throws VciBaseException 查询出错活抛出异常
     */
    List<Map> queryByOnlySqlForMap(String sql) throws VciBaseException;
 
    /**
     * 使用sql语句查询后转换为对象
     * @param sql sql语句
     * @param tClass 对象的类
     * @param <T> 泛型
     * @return 数据的列表
     * @throws VciBaseException 查询和转换出错会抛出异常
     */
    <T> List<T> queryByOnlySqlForObj(String sql, Class<T> tClass) throws VciBaseException;
 
    /**
     * 根据sql语句来查询内容,返回Map。sql不能是select * 或者 select t.*
     * @param sql 为了防止SQL注入,值必须在sql语句里以:xxx格式,如 id =:idvalue,然后在conditionMap中添加建为idvalue的格式
     * @param conditionMap  查询条件,必须与sql里对应
     * @return map数据
     * @throws VciBaseException
     */
     List<Map> queryBySqlForMap(String sql, Map<String, String> conditionMap) throws VciBaseException;
    /**
     * 根据sql语句来查询内容,返回Map。sql不能是select * 或者 select t.*
     * @param sql 为了防止SQL注入,值必须在sql语句里以:xxx格式,如 id =:idvalue,然后在conditionMap中添加建为idvalue的格式
     * @param conditionMap  查询条件,必须与sql里对应
     * @param selectKeys 查询的字段
     * @return  map数据
     * @throws VciBaseException
     */
    List<Map> queryBySqlForMap(String sql, Map<String, String> conditionMap,  String[] selectKeys) throws VciBaseException;
    
    /**
     * 查询数据,返回对象,对象的字段上可以设置参照和枚举
     * @param c 对象所属类
     * @param conditionMap 查询条件
     * @return
     * @throws VciBaseException
     */
     <T> List<T> queryObject(Class<T> c, Map<String, String> conditionMap) throws VciBaseException;
    
    /**
     * 查询数据,返回对象,支持分页
     * @param c 对象所属类
     * @param conditionMap 查询条件
     * @param ph 分页组件
     * @return
     * @throws VciBaseException
     */
     <T> List<T> queryObject(Class<T> c, Map<String, String> conditionMap, PageHelper ph) throws VciBaseException;
    
    /**
     * 使用查询方案来查询数据,返回对象,支持分页
     * @param queryScheme 查询方案
     * @param c 对象所属类
     * @param conditionMap 查询条件
     * @param ph 分页组件
     * @return
     * @throws VciBaseException
     */
     <T> List<T> queryObjectByScheme(String queryScheme, Class<T> c, Map<String, String> conditionMap, PageHelper ph) throws VciBaseException;
    
    /**
     * 使用查询方案来查询数据,返回对象,支持分页
     * @param queryScheme 查询方案
     * @param c 对象所属类
     * @param conditionMap 查询条件
     * @param ph 分页组件
     * @param replaceMap 替换查询方案中的变量值
     * @return
     * @throws VciBaseException
     */
     <T> List<T> queryObjectByScheme(String queryScheme, Class<T> c, Map<String, String> conditionMap, PageHelper ph, Map<String, Object> replaceMap) throws VciBaseException;
 
    /**
     * 保存数据,可以在request中设置是否持久化
     * @param obj 要保存的对象
     * @param <T>
     * @return 保存后包含的数据对象
     * @throws VciBaseException
     */
    <T> BatchCBO addSave(T obj) throws VciBaseException;
 
    /**
     * 批量保存数据,可以在request里设置不持久化
     * @param list 要保存的数据对象列表
     * @return 需要创建的CBO,CLO;需要修改的CBO,CLO;需要删除的CBO,CLO
     * @throws VciBaseException
     */
    <T> BatchCBO batchAddSave(List<T> list) throws VciBaseException;
 
    /**
     * 修改数据,可以在request里设置不持久化
     * @param obj 修改数据对象
     * @return 需要创建的CBO,CLO;需要修改的CBO,CLO;需要删除的CBO,CLO
     * @throws VciBaseException
     */
    <T> BatchCBO editSave(T obj) throws VciBaseException;
 
    /**
     * 批量修改数据,可以在request里设置不持久化
     * @param list 要保存的数据对象列表
     * @return 需要创建的CBO,CLO;需要修改的CBO,CLO;需要删除的CBO,CLO
     * @throws VciBaseException
     */
    <T> BatchCBO batchEditSave(List<T> list) throws VciBaseException;
 
    /**
     * 删除数据,可以在request里设置不持久化
     * @param obj 删除数据对象
     * @param checkRefered 是否删除引用的数据
     * @return 需要创建的CBO,CLO;需要修改的CBO,CLO;需要删除的CBO,CLO
     * @throws VciBaseException
     */
    <T> BatchCBO delete(T obj,boolean checkRefered) throws VciBaseException;
 
    /**
     * 删除数据,可以在request里设置不持久化
     * @param obj 删除数据对象
     * @return 需要创建的CBO,CLO;需要修改的CBO,CLO;需要删除的CBO,CLO
     * @throws VciBaseException
     */
    <T> BatchCBO delete(T obj) throws VciBaseException;
 
    /**
     * 批量删除数据,可以在request里设置不持久化
     * @param list 需要删除数据对象列表
     * @param checkRefered 是否删除引用的数据
     * @return 需要创建的CBO,CLO;需要修改的CBO,CLO;需要删除的CBO,CLO,checkRefered:[false/true]是否检查被引用,默认不检查
     * @throws VciBaseException
     */
    <T> BatchCBO batchDelete(List<T> list,boolean checkRefered) throws VciBaseException;
 
    /**
     * 批量删除数据,可以在request里设置不持久化
     * @param list 需要删除数据对象列表
     * @return 需要创建的CBO,CLO;需要修改的CBO,CLO;需要删除的CBO,CLO,checkRefered:[false/true]是否检查被引用,默认不检查
     * @throws VciBaseException
     */
    <T> BatchCBO batchDelete(List<T> list) throws VciBaseException;
 
    /**
     * 根据查询条件来删除数据
     * @param c 删除数据对象所属类
     * @param conditionMap 查询条件
     * @return 需要创建的CBO,CLO;需要修改的CBO,CLO;需要删除的CBO,CLO
     * @throws VciBaseException
     */
     <T> BatchCBO deleteByCondition(Class<T> c, Map<String, String> conditionMap) throws VciBaseException;
    
    /**
     * 根据查询条件来删除数据
     * @param btmType 业务类型名称
     * @param conditionMap 查询条件
     * @return 需要创建的CBO,CLO;需要修改的CBO,CLO;需要删除的CBO,CLO
     * @throws VciBaseException
     */
     <T> BatchCBO deleteByCondition(String btmType, Map<String, String> conditionMap) throws VciBaseException;
    
    /**
     * 通过sql语句来删除
     * @param sql 防止SQL注入,值必须使用:xxx方式,如id=:idvalue,并在conditionMap里放置idvalue为key的数据
     * @param conditionMap 查询条件
     * @return 删除的数据量
     * @throws VciBaseException
     */
     BatchCBO deleteBySql(String sql, Map<String, String> conditionMap) throws VciBaseException;
 
    /**
     * 检验是否为最新的
     * @param obj 数据对象,里面必须包括主键和ts字段
     * @return 相等时为true
     * @throws VciBaseException
     */
     boolean checkTs(Object obj) throws VciBaseException;
    
    /**
     * 根据业务类型来查询列表数据;
     * @param btmType 业务类型名称
     * @param conditionMap 查询条件
     * @return 列表数据,数据是Map形式的,包含分页信息
     * @throws VciBaseException
     */
     DataGrid queryGridByBo(String btmType, Map<String, String> conditionMap) throws VciBaseException;
    
    /**
     * 根据业务类型来查询列表数据;可以在pageHelper中设置是否查询总数
     * @param btmType 业务类型名称
     * @param conditionMap 查询条件
     * @param ph 分页和排序组件
     * @return 列表数据,数据是Map形式的,包含分页信息
     * @throws VciBaseException
     */
     DataGrid queryGridByBo(String btmType, Map<String, String> conditionMap, PageHelper ph) throws VciBaseException;
    
    /**
     * 根据业务类型来查询列表数据;可以设置要查询的字段,包括参照和枚举字段;可以在pageHelper中设置是否查询总数
     * @param btmType 业务类型名称
     * @param conditionMap 查询条件
     * @param ph 分页和排序组件
     * @param clauseList 列表数据,数据是Map形式的,
     * @return 列表数据,数据是Map形式的,包含分页信息
     * @throws VciBaseException
     */
     DataGrid queryGridByBo(String btmType, Map<String, String> conditionMap, PageHelper ph, List<String> clauseList) throws VciBaseException;
    
    /**
     * 根据查询方案来查询列表数据;
     * @param queryScheme 查询方案
     * @param conditionMap 查询条件
     * @return 列表数据,数据是Map形式的,包含分页信息
     * @throws VciBaseException
     */
     DataGrid queryGridByScheme(String queryScheme, Map<String, String> conditionMap) throws VciBaseException;
    
    /**
     * 根据查询方案来查询列表数据;
     * @param queryScheme 查询方案
     * @param conditionMap 查询条件
     * @param replaceMap 替换查询方案的变量值
     * @return 列表数据,数据是Map形式的,包含分页信息
     * @throws VciBaseException
     */
     DataGrid queryGridByScheme(String queryScheme, Map<String, String> conditionMap, Map<String, Object> replaceMap) throws VciBaseException;
    
    /**
     * 根据查询方案来查询列表数据;可以在pageHelper中设置是否查询总数,pageHelper的优先级最大;
     * @param queryScheme 查询方案
     * @param conditionMap 查询条件
     * @param replaceMap 替换查询方案的变量值
     * @param ph 分页和排序字段
     * @return 列表数据,数据是Map形式的,包含分页信息
     * @throws VciBaseException
     */
     DataGrid queryGridByScheme(String queryScheme, Map<String, String> conditionMap, Map<String, Object> replaceMap,
                                PageHelper ph) throws VciBaseException;
    
    /**
     * 根据查询方案来查询列表数据,可以自定义查询的列,包括参照和枚举
     * @param queryScheme 查询方案
     * @param conditionMap 查询条件
     * @param replaceMap 替换查询方案的变量值
     * @param ph 分页和排序字段
     * @param clauseList 查询的列,参照使用xx.yy;枚举使用xx_enumCode;
     * @return 列表数据,数据是Map形式的,包含分页信息
     * @throws VciBaseException
     */
     DataGrid queryGridByScheme(String queryScheme, Map<String, String> conditionMap, Map<String, Object> replaceMap,
                                PageHelper ph, List<String> clauseList) throws VciBaseException;
 
    /**
     * 查询对象的列表数据 
     * @param c 查询对象所属类
     * @param conditionMap 查询条件
     * @return 列表数据,数据是对象形式的,包含分页信息
     * @throws VciBaseException
     */
     DataGrid queryGridClass(Class c, Map<String, String> conditionMap) throws VciBaseException;
    
    /**
     * 查询对象的列表数据
     * @param c 查询对象所属类
     * @param conditionMap 查询条件
     * @param ph 分页和排序字段,可以设置是否查询总数
     * @return 列表数据,数据是对象形式的,包含分页信息
     * @throws VciBaseException
     */
     DataGrid queryGridClass(Class c, Map<String, String> conditionMap, PageHelper ph) throws VciBaseException;
    
    /**
     * 通过查询方案查询对象的列表数据
     * @param queryScheme 查询方案
     * @param c 查询对象所属类
     * @param conditionMap 查询条件
     * @return 列表数据,数据是对象形式的,包含分页信息
     * @throws VciBaseException
     */
     DataGrid queryGridClassByScheme(String queryScheme, Class c, Map<String, String> conditionMap, Map<String, Object> replaceMap) throws VciBaseException;
    
    /**
     * 通过查询方案查询对象的列表数据
     * @param queryScheme 查询方案
     * @param c 查询对象所属类
     * @param conditionMap 查询条件
     * @param ph 分页和排序字段,可以设置是否查询总数
     * @return 列表数据,数据是对象形式的,包含分页信息
     * @throws VciBaseException
     */
     DataGrid queryGridClassByScheme(String queryScheme, Class c, Map<String, String> conditionMap, Map<String, Object> replaceMap, PageHelper ph) throws VciBaseException;
    
    /**
     * BusinessObject 转为HashMap
     * @param cbos CBOS
     * @return map
     * @throws VciBaseException
     */
     List<Map> cbos2Map(List<BusinessObject> cbos) throws VciBaseException;
    
    /**
     * BusinessObject 转为HashMap
     * @param cbo
     * @return
     * @throws VciBaseException
     */
     Map cbo2Map(BusinessObject cbo) throws VciBaseException;
    
    /**
     * map转为BusinessObject
     * @param map 
     * @return
     * @throws VciBaseException
     */
     List<BusinessObject> map2Cbos(List<Map> map) throws VciBaseException;
    
    /**
     * map转为BusinessObject
     * @param map
     * @return
     * @throws VciBaseException
     */
     BusinessObject map2Cbo(Map map) throws VciBaseException;
    
    /**
     * 批量保存业务类型和链接类型的信息
     * @param batchCbos 批量数据容器
     * @throws VciBaseException
     */
     void persistenceBatch(BatchCBO batchCbos) throws VciBaseException;
    
    /**
     * 批量保存业务类型和链接类型的信息---只有确保数据容器里有参照字段,枚举字段等内容的时候,才调用这个方法,因为这个方法性能低下
     * @param batchCbos 批量数据容器
     * @param isCheckReferColumn 是否校验是否含有参照字段
     * @throws VciBaseException
     */
     void persistenceBatch(BatchCBO batchCbos, boolean isCheckReferColumn) throws VciBaseException;
 
    /**
     * 获取查询条件,
     * @param conditionMap
     * @return
     */
    Condition getConditionByMap(Map<String, String> conditionMap);
 
    /**
     * 根据属性来查询主键
     * @param referInfo  业务类型.属性名
     * @param value 属性的值
     * @return
     * @throws VciBaseException
     */
    Map<String,String> queryOidByPropertie(String referInfo, List<String> value) throws VciBaseException;
 
    /**
     * 校验特定属性的值是否存在
     * @param btmName 业务类型
     * @param columnName 列名称
     * @param columnValues 列的值
     * @return
     * @throws VciBaseException
     */
    boolean checkDataExsitByColumn(String btmName, String columnName, Collection<String> columnValues) throws VciBaseException;
 
    /**
     * 校验特定属性的值是否存在
     * @param btmName 业务类型
     * @param columnName 列名称
     * @param columnValues 列的值
     * @return
     * @throws VciBaseException
     */
    boolean checkDataExsitByColumn(String btmName, String columnName, String columnValues) throws VciBaseException;
    
    /**
     * 使用主键获取对象
     * @param oid 主键
     * @param doClass 数据对象的类
     * @return 数据对象
     * @throws VciBaseException 参数为空,数据对象不存在会抛出异常
     */
    <T> T selectByOid(String oid, Class<T> doClass) throws VciBaseException;
 
    /**
     * 使用主键获取对象
     * @param oid 主键
     * @param btmName 业务类型的名称
     * @return cbo
     * @throws VciBaseException 参数为空,数据不存在会抛出异常
     */
    BusinessObject selectCBOByOid(String oid,String btmName) throws VciBaseException;
    
    /**
     * 使用主键集合获取对象
     * @param oidCollection 主键集合
     * @param doClass 数据对象的类
     * @return 数据对象, 为空的时候列表为空,不是Null
     * @throws VciBaseException 参数为空,查询出错会抛出异常
     */
    <T> List<T> selectByOidCollection(Collection<String> oidCollection, Class<T> doClass) throws VciBaseException;
 
    /**
     * 使用主键集合获取对象
     * @param oidCollection 主键集合
     * @param btmName 业务类型的名称
     * @return 业务数据的集合
     * @throws VciBaseException 参数为空,查询出错会抛出异常
     */
    List<BusinessObject> selectCBOByOidCollection(Collection<String> oidCollection,String btmName) throws VciBaseException;
 
    /**
     * 使用新的查询封装器来查询
     * @param queryWrapperForDO 查询封装器
     * @param doClass 对象的所属类
     * @param <T> 泛型
     * @return 数据
     * @throws VciBaseException 查询出错的会抛出异常
     */
    <T> List<T> selectByQueryWrapper(VciQueryWrapperForDO queryWrapperForDO,Class<T> doClass) throws VciBaseException;
 
    /**
     * 使用新的查询封装器来查询总数
     * @param queryWrapperForDO 查询封装器
     * @param doClass 对象的所属类
     * @param <T> 泛型
     * @return 数据
     * @throws VciBaseException 查询出错的会抛出异常
     */
    <T> int countByQueryWrapper(VciQueryWrapperForDO queryWrapperForDO,Class<T> doClass) throws VciBaseException;
 
    /**
     * 是否为修改忽略的属性
     * @param attrName 属性的名字
     * @return true 表示应该忽略
     */
    default boolean checkUnAttrUnEdit(String attrName){
        return  (VciQueryWrapperForDO.OID_FIELD.equalsIgnoreCase(attrName)
                ||"ts".equalsIgnoreCase(attrName)
                || "lastmodifier".equalsIgnoreCase(attrName)
                || "lastmodifytime".equalsIgnoreCase(attrName)
                || "createtime".equalsIgnoreCase(attrName)
                || "checkintime".equalsIgnoreCase(attrName)
                ||"checkouttime".equalsIgnoreCase(attrName)
                || "modifier".equalsIgnoreCase(attrName)
                || "modifytime".equalsIgnoreCase(attrName));
    }
}