b82bf593be1973bd1222cb0fa122ca994ce72dd6.svn-base 9.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327
  1. package UIB.UIB03;
  2. import java.io.File;
  3. import java.io.FileInputStream;
  4. import java.net.URLDecoder;
  5. import java.sql.Array;
  6. import java.sql.CallableStatement;
  7. import java.sql.Connection;
  8. import java.sql.Date;
  9. import java.sql.DriverManager;
  10. import java.sql.SQLException;
  11. import java.util.ArrayList;
  12. import java.util.HashMap;
  13. import java.util.Iterator;
  14. import java.util.List;
  15. import java.util.Map;
  16. import javax.xml.parsers.DocumentBuilder;
  17. import javax.xml.parsers.DocumentBuilderFactory;
  18. import oracle.jdbc.OracleConnection;
  19. import oracle.sql.ARRAY;
  20. import oracle.sql.ArrayDescriptor;
  21. import org.apache.commons.dbcp.DelegatingConnection;
  22. import org.w3c.dom.Element;
  23. import org.w3c.dom.NamedNodeMap;
  24. import org.w3c.dom.Node;
  25. import org.w3c.dom.NodeList;
  26. //import com.sun.org.apache.xerces.internal.impl.xs.dom.DOMParser;
  27. import UIB.COM.DomParserFactory;
  28. import UIB.COM.FileFinder;
  29. import UIB.COM.XgDomParser;
  30. import UIB.COM.XmlSqlParsersFactory;
  31. import UIB.UIB03.ZBS.DataRowList;
  32. import UIB.UIB03.ZBS.QltyTmplParser;
  33. import UIB.UIB03.ZBS.StringFormat;
  34. public class TestCase
  35. {
  36. ArrayList al = new ArrayList();
  37. /**
  38. * @param args
  39. */
  40. private static Connection getNativeConnection(Connection con)
  41. throws SQLException
  42. {
  43. if ((con instanceof DelegatingConnection)) {
  44. Connection nativeCon = ((DelegatingConnection)con).getInnermostDelegate();
  45. return nativeCon != null ? nativeCon : con.getMetaData().getConnection();
  46. }
  47. return con;
  48. }
  49. public static void main(String[] args) throws Exception
  50. {
  51. try
  52. {
  53. String driverClassName = "oracle.jdbc.driver.OracleDriver";
  54. Class.forName(driverClassName);
  55. //连接数据库
  56. String url = "jdbc:oracle:thin:@10.10.0.8:1521:SQMESDB";
  57. String userName = "jhyuser";
  58. String userPsw = "jhyuser";
  59. String sqlString = "{call JHY_QLTY_BASE.TEST(?)}";
  60. Connection conn = DriverManager.getConnection(url , userName , userPsw);
  61. System.out.println(conn);
  62. CallableStatement cstm = conn.prepareCall(sqlString);
  63. //Array al = new ArrayList();
  64. String[]data = {"12" , "2" , "34"};
  65. ArrayList list = new ArrayList();
  66. list.add("1");
  67. list.add("2");
  68. // System.out.println(getNativeConnection(conn));
  69. //OracleConnection oc = (oracle.jdbc.OracleConnection)conn;
  70. ArrayDescriptor ad = ArrayDescriptor.createDescriptor("TEST_ABC",getNativeConnection(conn));
  71. ARRAY array = new ARRAY(ad,getNativeConnection(conn),data);
  72. System.out.println(array);
  73. // ArrayList al = new ArrayList();
  74. // al.add("1");
  75. // al.add("2");
  76. // Object obj = null;
  77. // Array ar = conn.createArrayOf("TEST_ABC", dat);
  78. // cstm.setArray(1, (Array)list);
  79. // cstm.setArray(1, ar);
  80. cstm.setArray(1, array);
  81. cstm.execute();
  82. // System.out.println(num);
  83. // cstm.close();
  84. // conn.close();
  85. }catch(Exception ex)
  86. {
  87. ex.printStackTrace();
  88. }
  89. // String strPath = Thread.currentThread().getContextClassLoader().getResource("").getPath();
  90. // File baseDir = new File(URLDecoder.decode(strPath, "utf-8"));
  91. // File[]a = baseDir.listFiles();
  92. // for(int i =0; i <a.length; i++)
  93. // {
  94. // if(a[i].toString().indexOf("query") != -1)
  95. // {
  96. // ListFilesInDirectory(a[i].toString());
  97. // System.out.println("---------->"+a[i].toString());
  98. // }
  99. // }
  100. //// System.out.println(strPath);
  101. //
  102. //// System.out.println(XmlSqlParsersFactory.getSql("xx"));
  103. // System.out.println(XmlSqlParsersFactory.getInstance().getLen());
  104. // System.out.println(new java.util.Date());
  105. //
  106. // System.out.println("------------->"+strPath.hashCode());
  107. // System.out.println("------------->"+strPath.hashCode());
  108. // System.out.println("------------->"+strPath.hashCode());
  109. //ArrayList list= (ArrayList)FileFinder.findFiles(strPath, "UIB030120-query.xml", 1);
  110. //System.out.println("#######################################"+list.size());
  111. // System.out.println(StringFormat.getNumber("T"));
  112. // TestCase tc= new TestCase();
  113. // String x = Thread.currentThread().getContextClassLoader().getResource("").getPath();
  114. // String xpath = x+"/excelConfig/qltyExcel_Config.xml";
  115. //// System.out.println(f.exists());
  116. // DomParserFactory dpf = new DomParserFactory(xpath);
  117. // Element e = dpf.getElement();
  118. // QltyTmplParser qtp = new QltyTmplParser();
  119. // System.out.println(qtp.getParamer());
  120. // tc.setParamer(e);
  121. //
  122. // HashMap m = new HashMap();
  123. // m.put("1", "23");
  124. // m.put("1", "3");
  125. // System.out.println(m);
  126. // System.out.println(tc.al.size());
  127. // for(int i = 0; i < tc.al.size();i++)
  128. // {
  129. // System.out.println(tc.al.get(i));
  130. // }
  131. // tt(e);
  132. // System.out.println(StringFormat.getNumber("01"));
  133. // System.out.println(true||false);
  134. ////
  135. // UIB030320 uib = new UIB030320();
  136. // uib.downLoad("A00001", "");
  137. //
  138. // Runtime rt = Runtime.getRuntime();
  139. // String[] cmd = {"C:\\Program Files\\Kingsoft\\WPS Office Personal\\office6\\et.exe" , "c:\\test.xls"};
  140. // rt.exec(cmd);
  141. //
  142. // DataRowList drl = new DataRowList();
  143. // drl.put("1", "z");
  144. // drl.put("2", "x");
  145. // drl.put("3", "e");
  146. // System.out.println( drl.getValue("3") );
  147. // drl.put("b", "z");
  148. // drl.put("a", "z");
  149. // drl.print();
  150. // String sql = "";
  151. //
  152. // for(int i =0; i < 10 ;i++)
  153. // {
  154. // sql = XmlSqlParsersFactory.getSql("UIB030130_01.SELECT");
  155. // System.out.println(sql);
  156. // System.out.println(XmlSqlParsersFactory.getSql("NIE042020_OrdPrcINf.select"));
  157. // }
  158. //
  159. // List fileList = new ArrayList();
  160. // //判断目录是否存在
  161. // String baseDirName = "C:\\Program Files\\Apache Software Foundation\\Tomcat5.5\\webapps\\CoreFS\\WEB-INF\\classes\\query";
  162. // File baseDir = new File(baseDirName);
  163. // if (!baseDir.exists() || !baseDir.isDirectory()){
  164. // System.out.println("文件查找失败:" + baseDirName + "不是一个目录!");
  165. // }
  166. // XgDomParser xdp = new XgDomParser();
  167. // HashMap hashmap =xdp.parserEl(element);
  168. // Iterator it = hashmap.keySet().iterator();
  169. // while(it.hasNext())
  170. // {
  171. // Object key = it.next();
  172. // Object value = hashmap.get(key);
  173. // System.out.println(key+"-->"+value);
  174. // }
  175. // XmlSqlParsersFactory xspf = new XmlSqlParsersFactory();
  176. // String sql = "";
  177. // sql = xspf.getSql("NIE042020_OrdPrcINf.select");
  178. // System.out.println(sql);
  179. // sql = xspf.getSql("NIE042020_OrdPrc.update");
  180. // System.out.println(sql);
  181. // Map m = xspf.parseEl(element);
  182. // System.out.println(m);
  183. // System.out.println(xspf.parser(element , "NIE042020_OrdPrcDetPk.select").get("NIE042020_OrdPrcDetPk.select") );
  184. // System.out.println(xspf.parser(element , "NIE042020_OrdPrcDetPk.select"));
  185. /**
  186. * ELEMENT_NODE 1
  187. * TEXT_NODE 3
  188. * CDATA_SECTION_NODE 4
  189. */
  190. //System.out.println("Node Type : "+Node.CDATA_SECTION_NODE);
  191. }
  192. public void setParamer(Element e)
  193. {
  194. if(e.hasChildNodes())
  195. {
  196. NodeList nodelist = e.getChildNodes();
  197. int len = nodelist.getLength();
  198. for(int i = 0; i < len ; i++)
  199. {
  200. Node node = nodelist.item(i);
  201. if(node.getNodeType() == Node.ELEMENT_NODE)
  202. {
  203. if(node.hasAttributes())
  204. {
  205. if("property".equals(node.getNodeName()))
  206. {
  207. HashMap hashmap = new HashMap();
  208. NamedNodeMap nnm = node.getAttributes();
  209. int nnmLen = nnm.getLength();
  210. for(int j = 0; j < nnmLen ; j++)
  211. {
  212. System.out.println(node.getNodeName());
  213. hashmap.put(nnm.item(j).getNodeName(), nnm.item(j).getNodeValue());
  214. }
  215. al.add(hashmap);
  216. }
  217. else if("image".equals(node.getNodeName()))
  218. {
  219. HashMap hashmap = new HashMap();
  220. NamedNodeMap nnm = node.getAttributes();
  221. int nnmLen = nnm.getLength();
  222. for(int j = 0; j < nnmLen ; j++)
  223. {
  224. System.out.println(node.getNodeName());
  225. hashmap.put(nnm.item(j).getNodeName(), nnm.item(j).getNodeValue());
  226. }
  227. al.add(hashmap);
  228. }
  229. }
  230. Element element = (Element)node;
  231. setParamer(element);
  232. }
  233. }
  234. }
  235. }
  236. public static void tt(Element e)
  237. {
  238. if (e.hasChildNodes())
  239. {
  240. NodeList nodelist = e.getChildNodes();
  241. int j = nodelist.getLength();
  242. for(int i = 0 ; i< j; i++)
  243. {
  244. Node node = nodelist.item(i);
  245. if(node.getNodeType() == Node.ELEMENT_NODE) //element
  246. {
  247. if(node.hasAttributes())
  248. {
  249. // System.out.println("--->"+node.getNodeName());
  250. NamedNodeMap nnm = node.getAttributes();
  251. int len = nnm.getLength();
  252. for(int z = 0 ; z < len ; z++)
  253. {
  254. // System.out.println(nnm.item(z).getNodeName()+"=========>"+nnm.item(z).getNodeValue());
  255. }
  256. }
  257. Element element = (Element)nodelist.item(i);
  258. // System.out.println(element.getTagName());//取得标签名
  259. tt(element);
  260. }
  261. // if(node.getNodeType() == Node.CDATA_SECTION_NODE)
  262. // {
  263. // System.out.println("------>"+node.getNodeValue());
  264. // }
  265. // if(node.getNodeType() == Node.TEXT_NODE)
  266. // {
  267. // System.out.println(node.getNodeName()+"===>>"+node.getNodeValue());
  268. // }
  269. //
  270. }
  271. }
  272. }
  273. public static void ListFilesInDirectory(String path)
  274. {
  275. File file = new File(path);
  276. File[] files = file.listFiles();
  277. int len = files.length;
  278. //System.out.println(path);
  279. for(int i = 0; i < len; i++)
  280. {
  281. if(files[i].isDirectory())
  282. {
  283. //System.out.println("######################");
  284. ListFilesInDirectory(files[i].toString());
  285. }
  286. else
  287. {
  288. DomParserFactory dpf = new DomParserFactory(files[i].getAbsolutePath());
  289. XgDomParser xdp = new XgDomParser();
  290. // HashMap hashmap = xdp.parserEl(dpf.getElement());
  291. XmlSqlParsersFactory.getInstance().putAll(xdp.parserEl(dpf.getElement()));
  292. // for(Iterator it = hashmap.keySet().iterator(); it.hasNext(); )
  293. // {
  294. // Object key = it.next();
  295. // Object value = hashmap.get(key);
  296. // XmlSqlParsersFactory.putSql(key, value);
  297. // }
  298. }
  299. }
  300. }
  301. }