oracle视图导出xml文件,解析xml,生成sql语句建表

今天在做测试数据库的时候,需要把用户提供的视图,转换成我们的测试表。但是由于权限限制,我们没有办法获取用户的正式表(由于安全方面的关系,表结构不好协调)。只能通过plSql操作用户提供的视图,去建立自己的表。用PlSql搞来搞去,能通过plsql将查询结果导出为sql文件,还可以通过视图的描述功能,将字段信息导出xml文件,格式大概如下:
<?xml version="1.0" encoding="utf-8" ?>
<ROWDATA>

<ROW>
<Name>DICTIONARYID</Name>
<Type>VARCHAR2(125)</Type>
<Nullable></Nullable>
<Default></Default>
<Comments></Comments>
</ROW>

<ROW>
<Name>KIND</Name>
<Type>VARCHAR2(110)</Type>
<Nullable></Nullable>
<Default></Default>
<Comments></Comments>
</ROW>

<ROW>
<Name>CODE</Name>
<Type>VARCHAR2(120)</Type>
<Nullable></Nullable>
<Default></Default>
<Comments></Comments>
</ROW>
………..
</ROWDATA>

看来看去,想到,如果能通过解析这个xml文件,把对应的值取到,组成sql语句的话,创建表结构,然后把数据导入进去,不就可以了嘛!
这里就要用到java解析xml内容了。



源代码如下:

import java.io.File;
import java.io.IOException;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;
import org.xml.sax.SAXException;

public class MakeSqlByXml {
         public static DocumentBuilderFactory factory = null;

public static DocumentBuilder builder = null;

public static Document document = null;

public MakeSqlByXml() {

}

public static String MakeSql() {
               String sql = "Create table test_t_dictionary";
      String path = "d:\\tt.xml";
      String fields = "";
     //从 XML 文档获取生成 DOM 对象树的解析器实例
       factory = DocumentBuilderFactory.newInstance();
      try {
//从 XML 文档获取 DOM 文档实例
builder = factory.newDocumentBuilder();

//将给定文件的内容解析为一个 XML 文档
document = builder.parse(new File(path));

//访问文档的子节点
Element rootElement = document.getDocumentElement();

//返回具有给定标记名称的所有后代
NodeList nodeList = rootElement.getElementsByTagName("ROW");

//遍历所有节点
for (int i = 0; i < nodeList.getLength(); i++) {

Node nodel = nodeList.item(i);

//遍历节点的所有属性
for (Node node = nodel.getFirstChild(); node != null; node = node.getNextSibling())  
{  
//获取指定节点的值
if (node.getNodeName().equals("Name")) {  
                      String name = node.getFirstChild().getTextContent(); 
             fields = fields + name + " ";
          }  
    if (node.getNodeName().equals("Type")) {  
      String type = node.getFirstChild().getNodeValue(); 
fields = fields + type + " , ";
      }  
}  
}
fields = fields.substring(0, fields.length()-2);
sql = sql +"("+ fields+")";
} catch (ParserConfigurationException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (SAXException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}

return sql;
}

public static void main(String args[]) {
System.out.println(MakeSql());
}
}


运行结果:



然后在plsql中执行一下,再把数据导入进去,就可以了。

程序中指定了xml文件的路径,我直接把导出的xml文件放在了D盘下了。

猜你喜欢

转载自ywwan2.iteye.com/blog/1414530