2 * Copyright (C) 2001, 2002 The Mir-coders group
4 * This file is part of Mir.
6 * Mir is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; either version 2 of the License, or
9 * (at your option) any later version.
11 * Mir is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
16 * You should have received a copy of the GNU General Public License
17 * along with Mir; if not, write to the Free Software
18 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
20 * In addition, as a special exception, The Mir-coders gives permission to link
21 * the code of this program with any library licensed under the Apache Software License,
22 * The Sun (tm) Java Advanced Imaging library (JAI), The Sun JIMI library
23 * (or with modified versions of the above that use the same license as the above),
24 * and distribute linked combinations including the two. You must obey the
25 * GNU General Public License in all respects for all of the code used other than
26 * the above mentioned libraries. If you modify this file, you may extend this
27 * exception to your version of the file, but you are not obligated to do so.
28 * If you do not wish to do so, delete this exception statement from your version.
31 package mircoders.storage;
33 import mir.log.LoggerWrapper;
34 import mir.storage.Database;
35 import mir.storage.DatabaseFailure;
37 import java.sql.Connection;
38 import java.sql.Statement;
40 public class DatabaseContent extends Database {
42 private static DatabaseContent instance;
44 public synchronized static DatabaseContent getInstance() {
46 if (instance == null ) {
47 instance = new DatabaseContent();
52 private DatabaseContent() throws DatabaseFailure {
56 logger = new LoggerWrapper("Database.Content");
58 entityClass = mircoders.entity.EntityContent.class;
64 * sets the database flag is_produced to unproduced
67 public void setUnproduced(String where) throws DatabaseFailure
69 Connection con=null;Statement stmt=null;
70 String sql = "update content set is_produced='0' where " + where;
71 logger.debug("set unproduced: "+where);
73 con = obtainConnection();
74 // should be a preparedStatement because is faster
75 stmt = con.createStatement();
76 executeUpdate(stmt,sql);
77 logger.debug("set unproduced: "+where);
80 _throwStorageObjectException(e, "-- set unproduced failed");
82 finally { freeConnection(con,stmt);}
85 public boolean delete(String id) throws DatabaseFailure {
86 DatabaseComment.getInstance().deleteByContentId(id);
87 DatabaseContentToTopics.getInstance().deleteByContentId(id);
88 DatabaseContentToMedia.getInstance().deleteByContentId(id);
90 return super.delete(id);
93 protected String getPrimaryKeySequence() {
94 return "media_id_seq";