org.mskcc.cbio.cgds.dao.DaoProteinArrayData.java Source code

Java tutorial

Introduction

Here is the source code for org.mskcc.cbio.cgds.dao.DaoProteinArrayData.java

Source

/** Copyright (c) 2012 Memorial Sloan-Kettering Cancer Center.
**
** This library is free software; you can redistribute it and/or modify it
** under the terms of the GNU Lesser General Public License as published
** by the Free Software Foundation; either version 2.1 of the License, or
** any later version.
**
** This library is distributed in the hope that it will be useful, but
** WITHOUT ANY WARRANTY, WITHOUT EVEN THE IMPLIED WARRANTY OF
** MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE.  The software and
** documentation provided hereunder is on an "as is" basis, and
** Memorial Sloan-Kettering Cancer Center 
** has no obligations to provide maintenance, support,
** updates, enhancements or modifications.  In no event shall
** Memorial Sloan-Kettering Cancer Center
** be liable to any party for direct, indirect, special,
** incidental or consequential damages, including lost profits, arising
** out of the use of this software and its documentation, even if
** Memorial Sloan-Kettering Cancer Center 
** has been advised of the possibility of such damage.  See
** the GNU Lesser General Public License for more details.
**
** You should have received a copy of the GNU Lesser General Public License
** along with this library; if not, write to the Free Software Foundation,
** Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.
**/

package org.mskcc.cbio.cgds.dao;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.Collection;
import java.util.Collections;
import org.apache.commons.lang.StringUtils;
import org.mskcc.cbio.cgds.model.ProteinArrayData;

/**
 *
 * @author jj
 */
public class DaoProteinArrayData {
    private static DaoProteinArrayData daoProteinArrayData;

    /**
     * Private Constructor to enforce Singleton Pattern.
     */
    private DaoProteinArrayData() {
    }

    /**
     * Gets Global Singleton Instance.
     *
     * @return DaoProteinArrayData Singleton.
     * @throws DaoException Database Error.
     */
    public static DaoProteinArrayData getInstance() throws DaoException {
        if (daoProteinArrayData == null) {
            daoProteinArrayData = new DaoProteinArrayData();
        }

        return daoProteinArrayData;
    }

    /**
     * Adds a new ProteinArrayData Record to the Database.
     *
     * @param pad ProteinArrayData Object.
     * @return number of records successfully added.
     * @throws DaoException Database Error.
     */
    public int addProteinArrayData(ProteinArrayData pad) throws DaoException {
        if (getProteinArrayData(pad.getCancerStudyId(), pad.getArrayId(), pad.getCaseId()) != null) {
            System.err.println("RPPA data of " + pad.getArrayId() + " for case " + pad.getCaseId()
                    + " in cancer study " + pad.getCancerStudyId() + " has already been added.");
            return 0;
        }

        Connection con = null;
        PreparedStatement pstmt = null;
        ResultSet rs = null;
        try {
            con = JdbcUtil.getDbConnection(DaoProteinArrayData.class);
            pstmt = con.prepareStatement(
                    "INSERT INTO protein_array_data (`PROTEIN_ARRAY_ID`,`CANCER_STUDY_ID`,`CASE_ID`,`ABUNDANCE`) "
                            + "VALUES (?,?,?,?)");
            pstmt.setString(1, pad.getArrayId());
            pstmt.setInt(2, pad.getCancerStudyId());
            pstmt.setString(3, pad.getCaseId());
            pstmt.setDouble(4, pad.getAbundance());
            int rows = pstmt.executeUpdate();
            return rows;
        } catch (SQLException e) {
            throw new DaoException(e);
        } finally {
            JdbcUtil.closeAll(DaoProteinArrayData.class, con, pstmt, rs);
        }
    }

    public ProteinArrayData getProteinArrayData(int cancerStudyId, String arrayId, String caseId)
            throws DaoException {
        ArrayList<ProteinArrayData> list = getProteinArrayData(cancerStudyId, arrayId,
                Collections.singleton(caseId));
        if (list.isEmpty()) {
            return null;
        }

        return list.get(0);
    }

    public ArrayList<ProteinArrayData> getProteinArrayData(int cancerStudyId, String arrayId,
            Collection<String> caseIds) throws DaoException {
        return getProteinArrayData(cancerStudyId, Collections.singleton(arrayId), caseIds);
    }

    /**
     * Gets the ProteinArrayData with the Specified array ID.
     *
     * @param arrayIds protein array ID.
     * @return map of array id to a list of protein array data.
     * @throws DaoException Database Error.
     */
    public ArrayList<ProteinArrayData> getProteinArrayData(int cancerStudyId, Collection<String> arrayIds)
            throws DaoException {
        return getProteinArrayData(cancerStudyId, arrayIds, null);
    }

    /**
     * Gets the ProteinArrayData with the Specified array ID for specific cases.
     *
     * @param arrayIds protein array ID.
     * @return map of array id to a list of protein array data.
     * @throws DaoException Database Error.
     */
    public ArrayList<ProteinArrayData> getProteinArrayData(int cancerStudyId, Collection<String> arrayIds,
            Collection<String> caseIds) throws DaoException {
        Connection con = null;
        PreparedStatement pstmt = null;
        ResultSet rs = null;
        try {
            con = JdbcUtil.getDbConnection(DaoProteinArrayData.class);
            if (caseIds == null) {
                pstmt = con
                        .prepareStatement("SELECT * FROM protein_array_data WHERE CANCER_STUDY_ID='" + cancerStudyId
                                + "' AND PROTEIN_ARRAY_ID IN ('" + StringUtils.join(arrayIds, "','") + "')");
            } else {
                pstmt = con.prepareStatement("SELECT * FROM protein_array_data WHERE CANCER_STUDY_ID='"
                        + cancerStudyId + "' AND PROTEIN_ARRAY_ID IN ('" + StringUtils.join(arrayIds, "','") + "')"
                        + " AND CASE_ID IN ('" + StringUtils.join(caseIds, "','") + "')");
            }
            rs = pstmt.executeQuery();
            return extractData(rs);
        } catch (SQLException e) {
            throw new DaoException(e);
        } finally {
            JdbcUtil.closeAll(DaoProteinArrayData.class, con, pstmt, rs);
        }
    }

    /**
     * Gets all Protein array data in the Database.
     *
     * @return ArrayList of ProteinArrayDataes.
     * @throws DaoException Database Error.
     */
    public ArrayList<ProteinArrayData> getAllProteinArrayData() throws DaoException {
        Connection con = null;
        PreparedStatement pstmt = null;
        ResultSet rs = null;
        try {
            con = JdbcUtil.getDbConnection(DaoProteinArrayData.class);
            pstmt = con.prepareStatement("SELECT * FROM protein_array_data");
            rs = pstmt.executeQuery();
            return extractData(rs);
        } catch (SQLException e) {
            throw new DaoException(e);
        } finally {
            JdbcUtil.closeAll(DaoProteinArrayData.class, con, pstmt, rs);
        }
    }

    private ArrayList<ProteinArrayData> extractData(ResultSet rs) throws SQLException {
        ArrayList<ProteinArrayData> list = new ArrayList<ProteinArrayData>();
        while (rs.next()) {
            ProteinArrayData pai = new ProteinArrayData(rs.getInt("CANCER_STUDY_ID"),
                    rs.getString("PROTEIN_ARRAY_ID"), rs.getString("CASE_ID"), rs.getDouble("ABUNDANCE"));
            list.add(pai);
        }
        return list;
    }

    /**
     * Deletes all protein array data Records in the Database.
     *
     * @throws DaoException Database Error.
     */
    public void deleteAllRecords() throws DaoException {
        Connection con = null;
        PreparedStatement pstmt = null;
        ResultSet rs = null;
        try {
            con = JdbcUtil.getDbConnection(DaoProteinArrayData.class);
            pstmt = con.prepareStatement("TRUNCATE TABLE protein_array_data");
            pstmt.executeUpdate();
        } catch (SQLException e) {
            throw new DaoException(e);
        } finally {
            JdbcUtil.closeAll(DaoProteinArrayData.class, con, pstmt, rs);
        }
    }
}