mdxqueryservlet.java

来自「数据仓库展示程序」· Java 代码 · 共 224 行

JAVA
224
字号
/*
// $Id: //open/mondrian/src/main/mondrian/web/servlet/MDXQueryServlet.java#19 $
// This software is subject to the terms of the Common Public License
// Agreement, available at the following URL:
// http://www.opensource.org/licenses/cpl.html.
// Copyright (C) 2002-2005 Kana Software, Inc. and others.
// All Rights Reserved.
// You must accept the terms of that agreement to use this software.
//
// Sean McCullough, 13 February, 2002, 10:25 PM
*/

package mondrian.web.servlet;

import mondrian.olap.*;
import mondrian.web.taglib.ResultCache;
import org.eigenbase.xom.StringEscaper;

import javax.servlet.ServletConfig;
import javax.servlet.ServletException;
import javax.servlet.http.*;
import java.io.IOException;
import java.util.Enumeration;

/**
 * <code>MDXQueryServlet</code> is a servlet which receives MDX queries,
 * executes them, and formats the results in an HTML table.
 *
 * @author  Sean McCullough
 * @since 13 February, 2002
 * @version $Id: //open/mondrian/src/main/mondrian/web/servlet/MDXQueryServlet.java#19 $
 */
public class MDXQueryServlet extends HttpServlet {
    private String connectString;

    /** Initializes the servlet.
     */
    public void init(ServletConfig config) throws ServletException {
        super.init(config);
        connectString = config.getInitParameter("connectString");
        Enumeration initParameterNames = config.getInitParameterNames();
        while (initParameterNames.hasMoreElements()) {
            String name = (String) initParameterNames.nextElement();
            String value = config.getInitParameter(name);
            MondrianProperties.instance().setProperty(name, value);
        }
    }

    /** Destroys the servlet.
     */
    public void destroy() {

    }

    /** Processes requests for both HTTP <code>GET</code> and <code>POST</code> methods.
     * @param request servlet request
     * @param response servlet response
     */
    protected void processRequest(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, java.io.IOException {
        String queryName = request.getParameter("query");
        request.setAttribute("query", queryName);
        if (queryName != null) {
            processTransform(request,response);
            return;
        }
        String queryString = request.getParameter("queryString");
        request.setAttribute("queryString", queryString);
        mondrian.olap.Connection mdxConnection = null;
        StringBuffer html = new StringBuffer();

        //execute the query
        try {
            mdxConnection = DriverManager.getConnection(connectString, getServletContext(), false);
            Query q = mdxConnection.parseQuery(queryString);
            Result result = mdxConnection.execute(q);
            Position slicers[] = result.getSlicerAxis().positions;
            html.append("<table class='resulttable' cellspacing=1 border=0>");
            html.append(Util.nl);

            Position[] columns = result.getAxes()[0].positions;
            Position[] rows = null;
            if( result.getAxes().length == 2 )
                rows = result.getAxes()[1].positions;

            int columnWidth = columns[0].members.length;
            int rowWidth = 0;
            if( result.getAxes().length == 2 )
                    rowWidth = result.getAxes()[1].positions[0].members.length;

            for (int j=0; j<columnWidth; j++) {
                html.append("<tr>");

                // if it has more than 1 dimension
                if (j == 0 && result.getAxes().length > 1) {
                    // Print the top-left cell, and fill it with slicer members.
                    html.append("<td nowrap class='slicer' rowspan='" +
                            columnWidth + "' colspan='" + rowWidth + "'>");
                    for (int i=0; i<slicers.length; i++) {
                        Position position = slicers[i];
                        for (int k = 0; k < position.members.length; k++) {
                            if (k > 0) {
                                html.append("<br/>");
                            }
                            Member member = position.members[k];
                            html.append(member.getUniqueName());
                        }
                    }
                    html.append("&nbsp;</td>" + Util.nl);
                }

                // Print the column headings.
                for (int i=0; i<columns.length; i++) {
                    Member member = columns[i].members[j];
                    int width = 1;
                    while ((i + 1) < columns.length &&
                            columns[i + 1].members[j] == member) {
                        i++;
                        width++;
                    }
                    html.append("<td nowrap class='columnheading' colspan='" +
                            width + "'>" + member.getUniqueName() + "</td>");
                }
                html.append("</tr>" + Util.nl);
            }
            //if is two axes, show
            if (result.getAxes().length > 1) {
                for (int i=0; i<rows.length; i++) {
                    html.append("<tr>");
                    final Position row = rows[i];
                    for (int j = 0; j < row.members.length; j++) {
                        Member member = row.members[j];
                        html.append("<td nowrap class='rowheading'>" +
                                member.getUniqueName() + "</td>");
                    }
                    for (int j=0; j<columns.length; j++) {
                        showCell(html,result.getCell(new int[]{j,i}));
                    }
                    html.append("</tr>");
                }
            } else {
                html.append("<tr>");
                for (int i=0; i<columns.length; i++) {
                    showCell(html,result.getCell(new int[]{i}));
                }
                html.append("</tr>");
            }
            html.append("</table>");
        } catch (Throwable e) {
            final String[] strings = Util.convertStackToString(e);
            html.append("Error:<pre><blockquote>");
            for (int i = 0; i < strings.length; i++) {
                StringEscaper.htmlEscaper.appendEscapedString(strings[i], html);
            }
            html.append("</blockquote></pre>");
        } finally {
            if (mdxConnection != null) {
                mdxConnection.close();
            }
        }

        request.setAttribute("result", html.toString());
        response.setHeader("Content-Type", "text/html");
        getServletContext().getRequestDispatcher("/adhoc.jsp").include(request, response);
    }

    private void showCell( StringBuffer out, Cell cell) {
        out.append("<td class='cell'>" + cell.getFormattedValue() + "</td>");
    }
    private void processTransform(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {
        String queryName = request.getParameter("query");
        ResultCache rc = ResultCache.getInstance(request.getSession(), getServletContext(), queryName);
        Query query = rc.getQuery();
        query = query.safeClone();
        rc.setDirty();
        String operation = request.getParameter("operation");
        if (operation.equals("expand")) {
            String memberName = request.getParameter("member");
            boolean fail = true;
            Member member = query.getSchemaReader(true).getMemberByUniqueName(
                    Util.explode(memberName), fail);
            if (true) {
                throw new UnsupportedOperationException(
                        "query.toggleDrillState(member) has been de-supported");
            }
        } else {
            throw Util.newInternal("unkown operation '" + operation + "'");
        }
        rc.setQuery(query);
        String redirect = request.getParameter("redirect");
        if (redirect == null) {
            redirect = "/adhoc.jsp";
        }
        response.setHeader("Content-Type", "text/html");
        getServletContext().getRequestDispatcher(redirect).include(request, response);
    }

    /** Handles the HTTP <code>GET</code> method.
     * @param request servlet request
     * @param response servlet response
     */
    protected void doGet(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, java.io.IOException {
        processRequest(request, response);
    }

    /** Handles the HTTP <code>POST</code> method.
     * @param request servlet request
     * @param response servlet response
     */
    protected void doPost(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, java.io.IOException {
        processRequest(request, response);
    }

    /** Returns a short description of the servlet.
     */
    public String getServletInfo() {
        return "Process an MDX query and return the result formatted as an HTML table";
    }

}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?