reintroduced StringUtil.regexpReplace
[mir.git] / source / mir / storage / RecordInserter.java
1 /*\r
2  * Copyright (C) 2001-2006 The Mir-coders group\r
3  *\r
4  * This file is part of Mir.\r
5  *\r
6  * Mir is free software; you can redistribute it and/or modify\r
7  * it under the terms of the GNU General Public License as published by\r
8  * the Free Software Foundation; either version 2 of the License, or\r
9  * (at your option) any later version.\r
10  *\r
11  * Mir is distributed in the hope that it will be useful,\r
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of\r
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\r
14  * GNU General Public License for more details.\r
15  *\r
16  * You should have received a copy of the GNU General Public License\r
17  * along with Mir; if not, write to the Free Software\r
18  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA\r
19  *\r
20  * In addition, as a special exception, The Mir-coders gives permission to link\r
21  * the code of this program with  any library licensed under the Apache Software License,\r
22  * and distribute linked combinations including the two.  You must obey the\r
23  * GNU General Public License in all respects for all of the code used other than\r
24  * the above mentioned libraries.  If you modify this file, you may extend this\r
25  * exception to your version of the file, but you are not obligated to do so.\r
26  * If you do not wish to do so, delete this exception statement from your version.\r
27  */\r
28 package mir.storage;\r
29 \r
30 import java.sql.Connection;\r
31 import java.sql.PreparedStatement;\r
32 import java.sql.ResultSet;\r
33 import java.util.Date;\r
34 \r
35 /**\r
36  * Class to generate insert statements\r
37  */\r
38 public class RecordInserter extends StatementGenerator {\r
39 \r
40   public RecordInserter(String aTableName, String aSequenceName) {\r
41     tableName = aTableName;\r
42     sequenceName = aSequenceName;\r
43   }\r
44 \r
45   /**\r
46    * Assigns a value to a string typed field\r
47    */\r
48   public void assignString(String aFieldName, String aValue) {\r
49     assignObject(aFieldName, aValue);\r
50   }\r
51 \r
52   /**\r
53    * Assigns a value to a date/time typed field\r
54    */\r
55   public void assignDate(String aFieldName, Date aDate) {\r
56     assignObject(aFieldName, new java.sql.Date(aDate.getTime()));\r
57   }\r
58 \r
59   public void assignVerbatim(String aFieldName, String aText) {\r
60     if (firstAssignment) {\r
61       appendQuery("insert into " + tableName + "(");\r
62       firstAssignment = false;\r
63     }\r
64     else {\r
65       appendQuery(",");\r
66       values.append(",");\r
67     }\r
68 \r
69     values.append(aText);\r
70 \r
71     appendQuery(aFieldName);\r
72   }\r
73 \r
74   /**\r
75    * Executes the statement. Returns the id of the insterted record.\r
76    */\r
77   public String execute(Connection aConnection) throws DatabaseFailure {\r
78     appendQuery(")");\r
79     appendQuery(CRLF);\r
80     appendQuery("values (");\r
81     appendQuery(values.toString());\r
82     appendQuery(")");\r
83 \r
84     try {\r
85       int modified = executeWithModifiedCount(aConnection);\r
86       if (modified!=1) {\r
87         throw new Exception("modified count != 1 after insert");\r
88       }\r
89 \r
90       PreparedStatement statement = aConnection.prepareStatement("select currval('" + sequenceName + "')");\r
91       ResultSet rs = statement.executeQuery();\r
92       rs.next();\r
93       return rs.getString(1);\r
94     }\r
95     catch (Throwable e) {\r
96       throw new DatabaseFailure(e);\r
97     }\r
98   }\r
99 \r
100   private void assignObject(String aFieldName, Object anObject) {\r
101     appendParameter(anObject);\r
102 \r
103     assignVerbatim(aFieldName, "?");\r
104   }\r
105 \r
106   private String tableName;\r
107   private static final String CRLF = "\n\r";\r
108   private boolean firstAssignment = true;\r
109   private String sequenceName;\r
110   private StringBuffer values = new StringBuffer();\r
111 }