Java将数据库中表中字段转化为xml

最近在使用元数据开发页面,在开发的过程中遇到了一个问题,需要将数据库中的表字段以及相应的类型等信息转化为固定格式,并存入xml文件中。
刚开始的我,一本正经的在复制着每行的格式,然后对照着数据字典来一个一个添加。随着做的时间越来越长,最终当我遇到了一个表中有100多个字段的时候我崩溃了,撸完这么多内容我岂不是大半天都浪费了,而且也没什么成就感。不愿循规守矩的我决定自己写一个简单的工具类!
我先讲下我的大体思路,以便下面方便各位老师理解。首先将连接到相应数据库,然后读取相应表信息,读取之后将相应的信息整合,然后再按照自己所需要的格式输出到xml文件中。So easy!
闲话不多说,直接上代码。
首先是连接数据库

public DomainMetaBuildTest(String tableName) {

        this.tableName = tableName;
        try {
            //驱动注册
            Class.forName(DRIVERCLASSNAME);
            if (connection == null || connection.isClosed()) {
                //获得链接
                connection = DriverManager.getConnection(URL, USER, PASSWORD);
            }
        } catch (ClassNotFoundException ex) {
            ex.printStackTrace();
            System.out.println("Oh,not");
        } catch (SQLException e) {
            e.printStackTrace();
            System.out.println("Oh,not");
        }
    }

接下来是获取数据库表中的相应数据

/**
     * 功能描述:获取数据库相应信息
     */
    private List<String> doAction() {
        String sql = "select * from " + tableName;
        List<String> list = new ArrayList<String>();
        try {
            PreparedStatement statement = connection.prepareStatement(sql);
            //获取数据库的元数据
            ResultSetMetaData metadata = statement.getMetaData();
            ResultSet rs = connection.getMetaData().getPrimaryKeys(null, null, tableName);
            String id = "";
            //获取组键字段
            if (rs.next()) {
                id = rs.getString(4);
            }
            //数据库的字段个数
            int len = metadata.getColumnCount();
            //字段名称
            colNames = new String[len + 1];
            //字段类型 --->已经转化为java中的类名称了
            colTypes = new String[len + 1];
            //字段长度
            colLengths = new Integer[len + 1];
            for (int i = 1; i <= len; i++) {
                //获取字段名称
                colNames[i] = metadata.getColumnName(i);
                list.add(colNames[i]);
                //获取字段类型
                Integer displaySize = metadata.getColumnDisplaySize(i);
                colTypes[i] = convertType(metadata.getColumnTypeName(i), displaySize);
                colLengths[i] = displaySize;
            }
            list.add(id);
        } catch (SQLException e) {
            e.printStackTrace();
        }
        return list;
    }

最后是将处理后的数据存入xml文件中,此处可以根据自己的相应的格式处理,此段可改成自动生成Java实体类。

private void createXml() {
        try {
            // 创建解析器工厂
            DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
            DocumentBuilder db = factory.newDocumentBuilder();
            Document document = db.newDocument();
            // 不显示standalone="no"
            document.setXmlStandalone(true);

            Element root = document.createElement("attributes");

            // 此处 for 循环可替换成 遍历 数据库表的结果集操作;
            for (int i = 0; i < colNames.length; i++) {

                // 创建节点 attribute
                Element elements = document.createElement("attribute");
                if (colNames[i] != null) {
                    // 给 attribute 节点添加属性
                    elements.setAttribute("columnName", colNames[i]);
                    elements.setAttribute("name", colNames[i]);
                    elements.setAttribute("title", "");
                    elements.setAttribute("type", colTypes[i]);
                    elements.setAttribute("iLength", String.valueOf(colLengths[i]));

                    root.appendChild(elements);
                }

            }
            document.appendChild(root);

            // 创建TransformerFactory对象
            TransformerFactory tff = TransformerFactory.newInstance();

            // 创建 Transformer对象
            Transformer tf = tff.newTransformer();
            //设置首行缩进
            tf.setOutputProperty(
                    "{http://xml.apache.org/xslt}indent-amount", "4");
            // 输出内容是否使用换行
            tf.setOutputProperty(OutputKeys.INDENT, "yes");

            // 创建xml文件并写入内容
            File file = new File("D:/MetaFiles/" + GetTuoFeng(tableName) + ".xml");
            tf.transform(new DOMSource(document), new StreamResult(file));

            System.out.println("生成" + GetTuoFeng(tableName) + ".xml成功");
        } catch (Exception e) {
            e.printStackTrace();
            System.out.println("生成" + GetTuoFeng(tableName) + ".xml失败");
        }
    }

最后是在main方法中进行调用啦

    public static void main(String[] args) {
        DomainMetaBuildTest bean = new DomainMetaBuildTest("tableName");
        bean.getClassStr();
    }

有些地方仍需要优化,只是简单的写了个工具类,后面会慢慢优化下。请各位老师多多指教,一个努力的小白~

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,088评论 5 459
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,715评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,361评论 0 319
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,099评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 60,987评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,063评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,486评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,175评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,440评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,518评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,305评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,190评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,550评论 3 298
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,880评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,152评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,451评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,637评论 2 335

推荐阅读更多精彩内容

  • 国家电网公司企业标准(Q/GDW)- 面向对象的用电信息数据交换协议 - 报批稿:20170802 前言: 排版 ...
    庭说阅读 10,798评论 6 13
  • ORA-00001: 违反唯一约束条件 (.) 错误说明:当在唯一索引所对应的列上键入重复值时,会触发此异常。 O...
    我想起个好名字阅读 4,961评论 0 9
  • 一. Java基础部分.................................................
    wy_sure阅读 3,774评论 0 11
  • Swift1> Swift和OC的区别1.1> Swift没有地址/指针的概念1.2> 泛型1.3> 类型严谨 对...
    cosWriter阅读 11,065评论 1 32
  • 一. XML数据交换格式 XML数据交换格式是一种自描述的数据交互格式,虽然XML数据格式不如JSON "轻便",...
    __season____阅读 2,467评论 0 7