438bfa0732ed3dba14caf7b15d1836e90e4694f6.svn-base 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394
  1. package QCM.COMMUNAL.QCM02;
  2. import java.beans.BeanInfo;
  3. import java.beans.Introspector;
  4. import java.beans.PropertyDescriptor;
  5. import java.sql.ResultSet;
  6. import java.sql.ResultSetMetaData;
  7. import java.sql.SQLException;
  8. import java.text.SimpleDateFormat;
  9. import java.util.ArrayList;
  10. import java.util.Calendar;
  11. import java.util.Date;
  12. import java.util.GregorianCalendar;
  13. import java.util.List;
  14. import javax.script.ScriptEngine;
  15. import javax.script.ScriptEngineManager;
  16. import javax.script.ScriptException;
  17. import com.alibaba.fastjson.JSONArray;
  18. import com.alibaba.fastjson.JSONException;
  19. import com.alibaba.fastjson.JSONObject;
  20. public class SqlJoint {
  21. public static String resultSetToJson(ResultSet rs) throws SQLException,JSONException
  22. {
  23. // json����
  24. JSONArray array = new JSONArray();
  25. // ��ȡ����
  26. ResultSetMetaData metaData = rs.getMetaData();
  27. int columnCount = metaData.getColumnCount();
  28. // ����ResultSet�е�ÿ�����
  29. while (rs.next()) {
  30. JSONObject jsonObj = new JSONObject();
  31. // ����ÿһ��
  32. for (int i = 1; i <= columnCount; i++) {
  33. String columnName =metaData.getColumnLabel(i);
  34. String value = rs.getString(columnName);
  35. jsonObj.put(columnName, value);
  36. }
  37. array.add(jsonObj);
  38. }
  39. return array.toString();
  40. }
  41. /**
  42. * ����ʵ����֮�����ͬ���Ը�ֵ
  43. * @param source �����Ƶ�ʵ�������
  44. * @param to ��������ʵ�������
  45. * @throws Exception
  46. */
  47. public static void CopyEntity(Object source, Object to) throws Exception {
  48. // ��ȡ����
  49. BeanInfo sourceBean = Introspector.getBeanInfo(source.getClass(),java.lang.Object.class);
  50. PropertyDescriptor[] sourceProperty = sourceBean.getPropertyDescriptors();
  51. BeanInfo destBean = Introspector.getBeanInfo(to.getClass(),java.lang.Object.class);
  52. PropertyDescriptor[] destProperty = destBean.getPropertyDescriptors();
  53. String sourceName="",destName="";
  54. try {
  55. for (int i = 0; i < sourceProperty.length; i++) {
  56. for (int j = 0; j < destProperty.length; j++) {
  57. sourceName=sourceProperty[i].getName().replaceAll("_", "").toLowerCase();
  58. destName=destProperty[j].getName().replaceAll("_", "").toLowerCase();
  59. if (sourceName.equals(destName)) {
  60. System.out.print(sourceName+"=="+destName);
  61. // ����source��getter������dest��setter����
  62. destProperty[j].getWriteMethod().invoke(to,sourceProperty[i].getReadMethod().invoke(source));
  63. break;
  64. }
  65. }
  66. }
  67. } catch (Exception e) {
  68. throw new Exception("����"+sourceName+"����ʧ��");
  69. }
  70. }
  71. /**
  72. *ResultSetת��ΪJSON����
  73. *
  74. * @param ResultSet
  75. * @return JSONArray
  76. */
  77. public static JSONArray resultSetToJsonArry(ResultSet rs) throws SQLException, JSONException {
  78. JSONArray array = new JSONArray();
  79. ResultSetMetaData metaData = rs.getMetaData();
  80. int columnCount = metaData.getColumnCount();
  81. while (rs.next()) {
  82. JSONObject jsonObj = new JSONObject();
  83. for (int i = 1; i <= columnCount; i++) {
  84. String columnName = metaData.getColumnLabel(i);
  85. String value = rs.getString(columnName);
  86. jsonObj.put(columnName, value);
  87. }
  88. array.add(jsonObj);
  89. }
  90. return array;
  91. }
  92. public static boolean IsNullOrSpace(String value){
  93. if(value==null){
  94. return true;
  95. }else{
  96. return value.trim().equals("");
  97. }
  98. }
  99. /**
  100. * ����Ƿ��ϱ�׼
  101. * @param sign ���
  102. * @param signValue ��׼ֵ
  103. * @param value �Ա�ֵ
  104. * @return
  105. */
  106. public static boolean checkSignAndValue1(String sign,Double signValue,String value){
  107. if(sign==null){
  108. return true;
  109. }else if(value==null||value==""){
  110. return false;
  111. }
  112. /*switch(sign){
  113. case ">":
  114. return signValue.doubleValue()<Double.parseDouble(value);
  115. case ">=":
  116. return signValue.doubleValue()<=Double.parseDouble(value);
  117. case "<":
  118. return signValue.doubleValue()>Double.parseDouble(value);
  119. case "<=":
  120. return signValue.doubleValue()>=Double.parseDouble(value);
  121. case "=":
  122. return signValue.doubleValue()==Double.parseDouble(value);
  123. default:
  124. return true;
  125. }*/
  126. if(sign.equals(">"))
  127. return signValue.doubleValue()<Double.parseDouble(value);
  128. else if(sign.equals(">="))
  129. return signValue.doubleValue()<=Double.parseDouble(value);
  130. else if(sign.equals("<"))
  131. return signValue.doubleValue()>Double.parseDouble(value);
  132. else if(sign.equals("<="))
  133. return signValue.doubleValue()>=Double.parseDouble(value);
  134. else if(sign.equals("="))
  135. return signValue.doubleValue()==Double.parseDouble(value);
  136. else
  137. return true;
  138. }
  139. /**
  140. * ����Ƿ��ϱ�׼
  141. * @param sign ���
  142. * @param signValue ��׼ֵ
  143. * @param value �Ա�ֵ
  144. * @return
  145. */
  146. public static boolean checkSignAndValue(String sign,Double signValue,String value){
  147. if(value==null||value==""){
  148. return true;
  149. }
  150. if(sign==null){
  151. return true;
  152. }
  153. /*switch(sign){
  154. case ">":
  155. return signValue.doubleValue()<Double.parseDouble(value);
  156. case ">=":
  157. return signValue.doubleValue()<=Double.parseDouble(value);
  158. case "<":
  159. return signValue.doubleValue()>Double.parseDouble(value);
  160. case "<=":
  161. return signValue.doubleValue()>=Double.parseDouble(value);
  162. case "=":
  163. return signValue.doubleValue()==Double.parseDouble(value);
  164. default:
  165. return true;
  166. }*/
  167. if(sign.equals(">"))
  168. return signValue.doubleValue()<Double.parseDouble(value);
  169. else if(sign.equals(">="))
  170. return signValue.doubleValue()<=Double.parseDouble(value);
  171. else if(sign.equals("<"))
  172. return signValue.doubleValue()>Double.parseDouble(value);
  173. else if(sign.equals("<="))
  174. return signValue.doubleValue()>=Double.parseDouble(value);
  175. else if(sign.equals("="))
  176. return signValue.doubleValue()==Double.parseDouble(value);
  177. else
  178. return true;
  179. }
  180. /**
  181. * ��������
  182. * @param filed ��ݿ��ֶ���
  183. * @param start ��ʼ����
  184. * @param end ��������
  185. * @return
  186. */
  187. public static String CreateSqlConditionDate(String filed,Date start,Date end){
  188. Calendar calendar=new GregorianCalendar();
  189. calendar.setTime(end);
  190. calendar.add(Calendar.DATE,1);
  191. end=calendar.getTime();
  192. String condition=filed+" BeTween to_Date('" +SqlJoint.GetDateFormatString(start, Enum_DateType.Date_long)+ "','yyyy-MM-dd hh24:mi:ss') "+
  193. " And to_Date('" + SqlJoint.GetDateFormatString(end, Enum_DateType.Date_long) + "','yyyy-MM-dd hh24:mi:ss')";
  194. return condition;
  195. }
  196. /**
  197. * ����תString����
  198. * @param date ����
  199. * @param dateType ��ʽ������
  200. * @return
  201. */
  202. public static String GetDateFormatString(Date date,Enum_DateType dateType){
  203. SimpleDateFormat simpleFormat=GetDateFormat(dateType.toString());
  204. return simpleFormat.format(date);
  205. }
  206. /**
  207. * ���ڸ�ʽ����
  208. * @author ZQ
  209. *
  210. */
  211. public enum Enum_DateType{
  212. /**
  213. * yyyyMMdd
  214. */
  215. Date_Customer,
  216. /**
  217. * ������ yyyy-MM-dd HH:mm:ss
  218. */
  219. Date_long,
  220. /**
  221. * ������ yyyy-MM-dd
  222. */
  223. Date_Short,
  224. /**
  225. * �ꡢ����� yyyy-MM
  226. */
  227. Date_YearJoinMonth,
  228. /**
  229. * �¡������ MM-dd
  230. */
  231. Date_MonthJoinDay
  232. }
  233. /**
  234. * �������ڸ�ʽ����
  235. * @param dateType ��������
  236. * @return
  237. */
  238. public static SimpleDateFormat GetDateFormat(String dateType){
  239. SimpleDateFormat simpleFormat=new SimpleDateFormat();
  240. Enum_DateType _dateType=Enum_DateType.valueOf(dateType);
  241. switch (_dateType) {
  242. case Date_Customer:
  243. simpleFormat.applyPattern("yyyyMMdd");
  244. break;
  245. case Date_long:
  246. simpleFormat.applyPattern("yyyy-MM-dd HH:mm:ss");
  247. break;
  248. case Date_Short:
  249. simpleFormat.applyPattern("yyyy-MM-dd");
  250. break;
  251. case Date_YearJoinMonth:
  252. simpleFormat.applyPattern("yyyy-MM");
  253. break;
  254. case Date_MonthJoinDay:
  255. simpleFormat.applyPattern("MM-dd");
  256. break;
  257. default:
  258. simpleFormat.applyPattern("yyyy-MM-dd HH:mm:ss");
  259. break;
  260. }
  261. return simpleFormat;
  262. }
  263. /**
  264. * ִ�б��ʽ
  265. * @param expression ���ʽ
  266. * @return ������
  267. * @throws ScriptException
  268. */
  269. public static double GetFormulaResult(String expression) throws ScriptException{
  270. ScriptEngineManager _mgr=new ScriptEngineManager();
  271. ScriptEngine _enginer=_mgr.getEngineByName("javascript");
  272. Object result=_enginer.eval(expression);
  273. double value=Double.parseDouble(result.toString());
  274. return value;
  275. }
  276. /**
  277. * String ת double
  278. * @param value
  279. * @return
  280. */
  281. public static Double GetDouble(String value){
  282. if(value==null){
  283. return null;
  284. }else{
  285. return Double.parseDouble(value);
  286. }
  287. }
  288. /**
  289. * Double ת String
  290. * @param value
  291. * @return
  292. */
  293. public static String GetString(Double value){
  294. if(value==null){
  295. return null;
  296. }else{
  297. return value.toString();
  298. }
  299. }
  300. /**
  301. * ���ʹ��� ��sqlע��
  302. * @param value
  303. * @return
  304. */
  305. public static String TrimSqlDangerMark(String value){
  306. if(IsNullOrSpace(value)){
  307. return value;
  308. }else{
  309. return value.trim().replaceAll("'", "");
  310. }
  311. }
  312. /**
  313. * �����ѯcondition
  314. * @param listValue ԭ�ַ�ֵ��
  315. * @param field ��ݿ��ֶ���
  316. * @return
  317. */
  318. public static String CreateSqlCondition(List<String> listValue,String field){
  319. if(listValue==null||listValue.size()<1){
  320. return null;
  321. }else{
  322. StringBuilder condition=new StringBuilder(field+" in(");
  323. for (String value : listValue) {
  324. condition.append("'"+value+"',");
  325. }
  326. return condition.substring(0, condition.length()-1)+")";
  327. }
  328. }
  329. /**
  330. * �����ѯcondition
  331. * @param values ԭ�ַ�ֵ����
  332. * @param field ��ݿ��ֶ���
  333. * @param flag �ָ��ַ�
  334. * @return
  335. */
  336. public static String CreateSqlCondition(String values,String field,String flag){
  337. if(IsNullOrSpace(values)){
  338. return null;
  339. }else{
  340. String[] valueArray=values.split(flag);
  341. StringBuilder condition=new StringBuilder(field+" in(");
  342. for (String value : valueArray) {
  343. condition.append("'"+value+"',");
  344. }
  345. return condition.substring(0, condition.length()-1)+")";
  346. }
  347. }
  348. /**
  349. * �����ѯcondition
  350. * @param valueArray ԭ�ַ�ֵ����
  351. * @param field ��ݿ��ֶ���
  352. * @return
  353. */
  354. public static String CreateSqlCondition(String[] valueArray,String field){
  355. if(valueArray==null||valueArray.length<1){
  356. return null;
  357. }else{
  358. StringBuilder condition=new StringBuilder(field+" in(");
  359. for (String value : valueArray) {
  360. condition.append("'"+value+"',");
  361. }
  362. return condition.substring(0, condition.length()-1)+")";
  363. }
  364. }
  365. }