📄 productpopulator.java
字号:
/* * Copyright 2002 Sun Microsystems, Inc. All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * * - Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * * - Redistribution in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in * the documentation and/or other materials provided with the * distribution. * * Neither the name of Sun Microsystems, Inc. or the names of * contributors may be used to endorse or promote products derived * from this software without specific prior written permission. * * This software is provided "AS IS," without a warranty of any * kind. ALL EXPRESS OR IMPLIED CONDITIONS, REPRESENTATIONS AND * WARRANTIES, INCLUDING ANY IMPLIED WARRANTY OF MERCHANTABILITY, * FITNESS FOR A PARTICULAR PURPOSE OR NON-INFRINGEMENT, ARE HEREBY * EXCLUDED. SUN AND ITS LICENSORS SHALL NOT BE LIABLE FOR ANY DAMAGES * SUFFERED BY LICENSEE AS A RESULT OF USING, MODIFYING OR * DISTRIBUTING THE SOFTWARE OR ITS DERIVATIVES. IN NO EVENT WILL SUN * OR ITS LICENSORS BE LIABLE FOR ANY LOST REVENUE, PROFIT OR DATA, OR * FOR DIRECT, INDIRECT, SPECIAL, CONSEQUENTIAL, INCIDENTAL OR * PUNITIVE DAMAGES, HOWEVER CAUSED AND REGARDLESS OF THE THEORY OF * LIABILITY, ARISING OUT OF THE USE OF OR INABILITY TO USE SOFTWARE, * EVEN IF SUN HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. * * You acknowledge that Software is not designed, licensed or intended * for use in the design, construction, operation or maintenance of * any nuclear facility. */package com.sun.j2ee.blueprints.petstore.tools.populate;import java.util.*;import java.sql.*;import javax.xml.parsers.*;import org.xml.sax.*;import org.xml.sax.helpers.*;public class ProductPopulator { public static final String XML_PRODUCTS = "Products"; static final String XML_PRODUCT = "Product"; static final String XML_ID = "Product/@id"; public static final String XML_CATEGORY = "Product/@category"; // The INSERT statement expects parameters to be passed in the same order as below private static final String[] PARAMETER_NAMES = { XML_ID, XML_CATEGORY }; private String rootTag; private Map sqlStatements; private ProductDetailsPopulator productDetailsPopulator; public ProductPopulator(Map sqlStatements) throws PopulateException { this(XML_PRODUCTS, sqlStatements); return; } public ProductPopulator(String rootTag, Map sqlStatements) throws PopulateException { this.rootTag = rootTag; this.sqlStatements = sqlStatements; productDetailsPopulator = new ProductDetailsPopulator(XML_PRODUCT, sqlStatements); return; } public XMLFilter setup(XMLReader reader, final Connection connection) { return new XMLDBHandler(productDetailsPopulator.setup(reader, connection), rootTag, XML_PRODUCT, true) { public void update() throws PopulateException {} public void create() throws PopulateException { if (connection == null) { PopulateUtils.printSQLStatement(sqlStatements, PopulateUtils.makeSQLStatementKey(PopulateUtils.INSERT_OPERATION, "product"), PARAMETER_NAMES, this); } else { PopulateUtils.executeSQLStatement(connection, sqlStatements, PopulateUtils.makeSQLStatementKey(PopulateUtils.INSERT_OPERATION, "product"), PARAMETER_NAMES, this); } } }; } public boolean check(Connection connection) throws PopulateException { return PopulateUtils.executeSQLStatement(connection, sqlStatements, PopulateUtils.makeSQLStatementKey(PopulateUtils.CHECK_OPERATION, "product"), null, null) && productDetailsPopulator.check(connection); } public void dropTables(Connection connection) throws PopulateException { try { productDetailsPopulator.dropTables(connection); } catch (PopulateException exception) {} PopulateUtils.executeSQLStatement(connection, sqlStatements, PopulateUtils.makeSQLStatementKey(PopulateUtils.DROP_OPERATION, "product"), null, null); return; } public void createTables(Connection connection) throws PopulateException { PopulateUtils.executeSQLStatement(connection, sqlStatements, PopulateUtils.makeSQLStatementKey(PopulateUtils.CREATE_OPERATION, "product"), null, null); productDetailsPopulator.createTables(connection); return; }}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -