| 1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
 | package example;
import java.io.*;
import java.sql.*;
import java.text.*;
/**
 *
 * $Id: basic.java,v 1.7 2001/01/31 09:23:45 peter Exp $
 *
 * This example tests the basic components of the JDBC driver, and shows
 * how even the simplest of queries can be implemented.
 *
 * To use this example, you need a database to be in existence. This example
 * will create a table called basic.
 *
 * Note: This will only work with post 7.0 drivers.
 *
 */
public class basic
{
  Connection db;	// The connection to the database
  Statement  st;	// Our statement to run queries with
  public basic(String args[]) throws ClassNotFoundException, FileNotFoundException, IOException, SQLException
  {
    String url = args[0];
    String usr = args[1];
    String pwd = args[2];
    // Load the driver
    Class.forName("org.postgresql.Driver");
    // Connect to database
    System.out.println("Connecting to Database URL = " + url);
    db = DriverManager.getConnection(url, usr, pwd);
    System.out.println("Connected...Now creating a statement");
    st = db.createStatement();
    // Clean up the database (in case we failed earlier) then initialise
    cleanup();
    // Now run tests using JDBC methods
    doexample();
    // Clean up the database
    cleanup();
    // Finally close the database
    System.out.println("Now closing the connection");
    st.close();
    db.close();
    //throw postgresql.Driver.notImplemented();
  }
  /**
   * This drops the table (if it existed). No errors are reported.
   */
  public void cleanup()
  {
    try {
      st.executeUpdate("drop table basic");
    } catch(Exception ex) {
      // We ignore any errors here
    }
  }
  /**
   * This performs the example
   */
  public void doexample() throws SQLException
  {
    System.out.println("\nRunning tests:");
    // First we need a table to store data in
    st.executeUpdate("create table basic (a int2, b int2)");
    // Now insert some data, using the Statement
    st.executeUpdate("insert into basic values (1,1)");
    st.executeUpdate("insert into basic values (2,1)");
    st.executeUpdate("insert into basic values (3,1)");
    // This shows how to get the oid of a just inserted row
    // updated for 7.1
    st.executeUpdate("insert into basic values (4,1)");
    int insertedOID = ((org.postgresql.Statement)st).getInsertedOID();
    System.out.println("Inserted row with oid "+insertedOID);
    // Now change the value of b from 1 to 8
    st.executeUpdate("update basic set b=8");
    System.out.println("Updated "+st.getUpdateCount()+" rows");
    // Now delete 2 rows
    st.executeUpdate("delete from basic where a<3");
    System.out.println("deleted "+st.getUpdateCount()+" rows");
    // For large inserts, a PreparedStatement is more efficient, because it
    // supports the idea of precompiling the SQL statement, and to store
    // directly, a Java object into any column. PostgreSQL doesnt support
    // precompiling, but does support setting a column to the value of a
    // Java object (like Date, String, etc).
    //
    // Also, this is the only way of writing dates in a datestyle independent
    // manner. (DateStyles are PostgreSQL's way of handling different methods
    // of representing dates in the Date data type.)
    PreparedStatement ps = db.prepareStatement("insert into basic values (?,?)");
    for(int i=2;i<5;i++) {
      ps.setInt(1,4);		// "column a" = 5
      ps.setInt(2,i);		// "column b" = i
      ps.executeUpdate();	// executeUpdate because insert returns no data
    }
    ps.close();			// Always close when we are done with it
    // Finally perform a query on the table
    System.out.println("performing a query");
    ResultSet rs = st.executeQuery("select a, b from basic");
    if(rs!=null) {
      // Now we run through the result set, printing out the result.
      // Note, we must call .next() before attempting to read any results
      while(rs.next()) {
	int a = rs.getInt("a");	// This shows how to get the value by name
	int b = rs.getInt(2);	// This shows how to get the value by column
	System.out.println("  a="+a+" b="+b);
      }
      rs.close();	// again, you must close the result when done
    }
    // Now run the query again, showing a more efficient way of getting the
    // result if you don't know what column number a value is in
    System.out.println("performing another query");
    rs = st.executeQuery("select * from basic where b>1");
    if(rs!=null) {
      // First find out the column numbers.
      //
      // It's best to do this here, as calling the methods with the column
      // numbers actually performs this call each time they are called. This
      // really speeds things up on large queries.
      //
      int col_a = rs.findColumn("a");
      int col_b = rs.findColumn("b");
      // Now we run through the result set, printing out the result.
      // Again, we must call .next() before attempting to read any results
      while(rs.next()) {
	int a = rs.getInt(col_a); // This shows how to get the value by name
	int b = rs.getInt(col_b); // This shows how to get the value by column
	System.out.println("  a="+a+" b="+b);
      }
      rs.close();	// again, you must close the result when done
    }
    // Now test maxrows by setting it to 3 rows
    st.setMaxRows(3);
    System.out.println("performing a query limited to "+st.getMaxRows());
    rs = st.executeQuery("select a, b from basic");
    while(rs.next()) {
      int a = rs.getInt("a");	// This shows how to get the value by name
      int b = rs.getInt(2);	// This shows how to get the value by column
      System.out.println("  a="+a+" b="+b);
    }
    rs.close();	// again, you must close the result when done
    // The last thing to do is to drop the table. This is done in the
    // cleanup() method.
  }
  /**
   * Display some instructions on how to run the example
   */
  public static void instructions()
  {
    System.out.println("\nThis example tests the basic components of the JDBC driver, demonstrating\nhow to build simple queries in java.\n");
    System.out.println("Useage:\n java example.basic jdbc:postgresql:database user password [debug]\n\nThe debug field can be anything. It's presence will enable DriverManager's\ndebug trace. Unless you want to see screens of items, don't put anything in\nhere.");
    System.exit(1);
  }
  /**
   * This little lot starts the test
   */
  public static void main(String args[])
  {
    System.out.println("PostgreSQL basic test v6.3 rev 1\n");
    if(args.length<3)
      instructions();
    // This line outputs debug information to stderr. To enable this, simply
    // add an extra parameter to the command line
    if(args.length>3)
      DriverManager.setLogStream(System.err);
    // Now run the tests
    try {
      basic test = new basic(args);
    } catch(Exception ex) {
      System.err.println("Exception caught.\n"+ex);
      ex.printStackTrace();
    }
  }
}
 |