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盘下了。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值