zhuguifei
2026-03-10 58402bd5e762361363a0f7d7907153c77dbb819f
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
package com.shlanbao.tzsc.base.dao;
 
import java.util.List;
 
import com.shlanbao.tzsc.base.model.PageParams;
/**
 * 通用dao接口
 * @author Leejean
 * @create 2014年8月25日下午10:04:31
 * @param <T> PO
 */
public interface BaseDaoI<T> {
    /**
     * 保存并返回当前对象
     * 
     */
    public T saveAndReturn(T clazz) throws Exception;
    /**
     * 批量添加
     * @param list
     * @param clazz
     * @return
     */
    public boolean batchInsertAndReturn(List<?> list,Class<T> clazz);
    /**
     * 保存
     * @author Leejean
     * @create 2014-7-5下午12:06:02
     * @param t 持久化对象
     * @return 执行结果
     */
    public abstract boolean save(T o);
    
    /**
     * 保存
     * @author Leejean
     * @create 2014-7-5下午12:06:02
     * @param t 持久化对象
     * @return 执行结果
     */
    public abstract String saveBackKey(T o);
    
    
    /**
     * 保存
     * @author Leejean
     * @create 2014-7-5下午12:06:02
     * @param t 持久化对象
     * @return 执行结果
     */
    public abstract boolean update(T o);
    
    /**
     * 保存或者修改
     * @author liuligong
     * @create 2014-11-10 8:58
     * @param t 持久化对象
     * @return 执行结果
     */
    public boolean saveOrUpdate(T o);
    /**
     * 根据ID查找对象
     * @author Leejean
     * @create 2014-7-5下午12:06:17
     * @param clazz 目标对象
     * @param id ID
     * @return 对象实例
     */
    public abstract T findById(Class<T> c, String id);
 
    /**
     * 普通分页查询
     * @author Leejean
     * @create 2014-7-5下午12:08:49
     * @param hql HQL
     * @param pageIndex 当前页
     * @param pageSize 页大小
     * @param params 参数
     * @return 结果集
     */
    public abstract List<T> queryByPage(String hql, int pageIndex, int pageSize,
            Object... params);
 
    /**
     * 分页查询(适用于Easyui分页)
     * 局限:排序仅支持单表
     * @author Leejean
     * @create 2014-6-27下午03:39:31
     * @param hql HQL 目标表取别名为:o 无需后接空格   如:'from MyTable o'
     * @param pageParams 分页参数
     * @param params 用户输入参数,一般用来自于自定义Bean
     * @return 结果集
     */
    public abstract List<T> queryByPage(String hql, PageParams pageParams,
            Object... params);
 
    /**
     * 分页查询带排序功能
     * @author Leejean
     * @create 2014-6-27下午03:39:31
     * @param hql HQL语句
     * @param pageIndex 页码
     * @param pageSize 页大小
     * @param sort 排序列
     * @param order 升序asc&降序desc
     * @param params 参数列表
     * @return 结果集
     */
    public abstract List<T> queryByPage(String hql, int pageIndex, int pageSize,
            String sort, String order, Object... params);
 
    /**
     * 普通查询
     * @param hql HQL语句
     * @param params 参数列表
     * @return 对象集合
     */
    public abstract List<T> query(String hql, Object... params);
    /**
     * 
     * @author Leejean
     * @create 2014年12月4日下午3:36:26
     * @param clazz
     * @param hql
     * @param params
     * @return
     */
    @SuppressWarnings("hiding")
    public abstract <T> T query(Class<T> clazz,String hql, Object... params);
    /**
     * 查询Object数组(使用在查询结果不为对象时,取值(Type)array[index])
     * @author Leejean
     * @create 2014年12月4日下午3:36:35
     * @param hql HQL
     * @param params 参数
     * @return
     */
    public abstract List<Object[]> queryObjectArray(String hql, Object... params);
    public abstract List<Object[]> queryPageObjectArray(String hql, int pageIndex, int pageSize);
    /**
     * 查询Object数组(使用在查询结果不为对象时,取值(Type)array[index])
     * @param hql
     * @param pageParams
     * @param params
     * @return
     */
    public abstract List<Object[]> queryObjectArray(String hql,PageParams pageParams, Object... params);
    
    /**
     * 单值查询
     * @author Leejean
     * @create 2014-6-27下午03:39:31
     * @param hql 
     * @param params 
     * @return
     */
    public abstract Object unique(String hql, Object... params);
    
    /**
     * 单值查询
     * @author Leejean
     * @create 2014-6-27下午03:39:31
     * @param hql 
     * @param params 
     * @return
     */
    public abstract T unique(Class<T> c,String hql, Object... params);
 
    /**
     * 获得记录数(通常用于分页查询)
     * @author Leejean
     * @create 2014-6-27下午03:39:31 
     * @param hql HQL语句
     * @param params 参数列表
     * @return 记录数
     */
    public abstract long queryTotal(String hql, Object... params);
 
    /**
     * 按条件删除或修改
     * @author Leejean
     * @create 2014-6-27下午03:39:31 
     * @param hql
     * @param params
     * @return
     */
    public abstract int updateByParams(String hql, Object... params);
 
    /**
     * 按id删除对象
     * @author Leejean
     * @create 2014-7-5下午12:05:14
     * @param id id
     * @param clazz 目标对象
     * @return
     */
    public abstract int deleteById(String id, Class<T> clazz);
 
    /**
     * 按条件删除或修改
     * @author Leejean
     * @create 2014-7-5下午12:05:51
     * @param hql
     * @param params
     * @return
     */
    public abstract int deleteByParams(String hql, Object... params);
 
    /**
     * SQL拓展查询
     * @author Leejean
     * @create 2014-6-27下午03:39:31
     * @param sql SQL语句
     * @param params 参数列表
     * @return 对象集合
     */
    public abstract List<?> queryBySql(String sql, Object... params);
    /**
     *说明:非注入方式获取查询session
     * @param sql
     * @return
     * shisihai  
     * 20162016年2月24日下午4:14:48
     */
    public abstract List<?> queryBySqlExpand(String sql);
    /**
     * 批量添加(高性能)
     * @author Leejean
     * @create 2014年11月17日上午9:32:52
     * @param list VO集合
     * @param clazz 目标PO类型,决定数据新增到哪个数据表
     */
    @SuppressWarnings("rawtypes")
    public abstract void batchInsert(List list,Class clazz);
    
    /**
     * 根据SQL语句更新
     * @param sql
     */
    public void updateInfo(String sql,List<Object> obj);
    /**
     * 根据SQL语句更新
     * @param sql
     * @param obj
     * @return
     */
    public int updateBySql(String sql,List<Object> obj);
 
 
    public int updateBySqlParam(String sql, Object... params);
}