JDBC applet : Applet « Swing JFC « Java






JDBC applet

   
/* From http://java.sun.com/docs/books/tutorial/index.html */
/*
 * Copyright (c) 2006 Sun Microsystems, Inc. All Rights Reserved.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions are met:
 *
 * -Redistribution of source code must retain the above copyright notice, this
 *  list of conditions and the following disclaimer.
 *
 * -Redistribution in binary form must reproduce the above copyright notice,
 *  this list of conditions and the following disclaimer in the documentation
 *  and/or other materials provided with the distribution.
 *
 * Neither the name of Sun Microsystems, Inc. or the names of contributors may
 * be used to endorse or promote products derived from this software without
 * specific prior written permission.
 *
 * This software is provided "AS IS," without a warranty of any kind. ALL
 * EXPRESS OR IMPLIED CONDITIONS, REPRESENTATIONS AND WARRANTIES, INCLUDING
 * ANY IMPLIED WARRANTY OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE
 * OR NON-INFRINGEMENT, ARE HEREBY EXCLUDED. SUN MIDROSYSTEMS, INC. ("SUN")
 * AND ITS LICENSORS SHALL NOT BE LIABLE FOR ANY DAMAGES SUFFERED BY LICENSEE
 * AS A RESULT OF USING, MODIFYING OR DISTRIBUTING THIS SOFTWARE OR ITS
 * DERIVATIVES. IN NO EVENT WILL SUN OR ITS LICENSORS BE LIABLE FOR ANY LOST
 * REVENUE, PROFIT OR DATA, OR FOR DIRECT, INDIRECT, SPECIAL, CONSEQUENTIAL,
 * INCIDENTAL OR PUNITIVE DAMAGES, HOWEVER CAUSED AND REGARDLESS OF THE THEORY
 * OF LIABILITY, ARISING OUT OF THE USE OF OR INABILITY TO USE THIS SOFTWARE,
 * EVEN IF SUN HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.
 *
 * You acknowledge that this software is not designed, licensed or intended
 * for use in the design, construction, operation or maintenance of any
 * nuclear facility.
 */
/**
 * This is a demonstration JDBC applet. It displays some simple standard output
 * from the Coffee database.
 */

import java.applet.Applet;
import java.awt.Graphics;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.Vector;

public class OutputApplet extends Applet implements Runnable {
  private Thread worker;

  private Vector queryResults;

  private String message = "Initializing";

  public synchronized void start() {
    // Every time "start" is called we create a worker thread to
    // re-evaluate the database query.
    if (worker == null) {
      message = "Connecting to database";
      worker = new Thread(this);
      worker.start();
    }
  }

  /**
   * The "run" method is called from the worker thread. Notice that because
   * this method is doing potentially slow databases accesses we avoid making
   * it a synchronized method.
   */

  public void run() {
    String url = "jdbc:mySubprotocol:myDataSource";
    String query = "select COF_NAME, PRICE from COFFEES";

    try {
      Class.forName("myDriver.ClassName");
    } catch (Exception ex) {
      setError("Can't find Database driver class: " + ex);
      return;
    }

    try {
      Vector results = new Vector();
      Connection con = DriverManager.getConnection(url, "myLogin",
          "myPassword");
      Statement stmt = con.createStatement();
      ResultSet rs = stmt.executeQuery(query);
      while (rs.next()) {
        String s = rs.getString("COF_NAME");
        float f = rs.getFloat("PRICE");
        String text = s + "     " + f;
        results.addElement(text);
      }

      stmt.close();
      con.close();

      setResults(results);

    } catch (SQLException ex) {
      setError("SQLException: " + ex);
    }
  }

  /**
   * The "paint" method is called by AWT when it wants us to display our
   * current state on the screen.
   */

  public synchronized void paint(Graphics g) {
    // If there are no results available, display the current message.
    if (queryResults == null) {
      g.drawString(message, 5, 50);
      return;
    }

    // Display the results.
    g.drawString("Prices of coffee per pound:  ", 5, 10);
    int y = 30;
    java.util.Enumeration e = queryResults.elements();
    while (e.hasMoreElements()) {
      String text = (String) e.nextElement();
      g.drawString(text, 5, y);
      y = y + 15;
    }
  }

  /**
   * This private method is used to record an error message for later display.
   */

  private synchronized void setError(String mess) {
    queryResults = null;
    message = mess;
    worker = null;
    // And ask AWT to repaint this applet.
    repaint();
  }

  /**
   * This private method is used to record the results of a query, for later
   * display.
   */

  private synchronized void setResults(Vector results) {
    queryResults = results;
    worker = null;
    // And ask AWT to repaint this applet.
    repaint();
  }
}
           
         
    
    
  








Related examples in the same category

1.Icon Demo Applet
2.Socket Applet
3.Applet Socket Quote
4.Applet Print
5.Applet System Properties
6.Applet Sound
7.Show Document
8.Applet communication (talk to each other)
9.Get Applets
10.An application and an appletAn application and an applet
11.Applet and Swing ComponentsApplet and Swing Components
12.Icon behavior in JbuttonsIcon behavior in Jbuttons
13.Signed Applet
14.Load resource in Applet
15.Scribble AppletScribble Applet
16.Toggle buttonToggle button
17.Bouncing CircleBouncing Circle
18.Applet Menu Bar Demo
19.Applet clock demoApplet clock demo
20.Applet event testerApplet event tester
21.Applet with parameters
22.First applet
23.AppletViewer - a simple Applet Viewer program
24.A simple loan calculator appletA simple loan calculator applet
25.URLButton -- a Button-like object that jumps to a URL
26.Get list of APPLET tags in one HTML file
27.Demonstration of Applet Methods
28.Demonstrates getParameterInfo() and getAppletInfo()
29.Walking Text Demo
30.Java Applets Can Run CGI's (on some browsers)
31.Demo Choice Applet
32.Demo Applet: Connect to Legacy System
33.ShowDocApplet: try out showDocument()
34.Bookmarks
35.Java Wave Applet Demo
36.Slide Puzzle
37.A class to allow use of the ncsa ISMAP format in java applets
38.Image Loader Applet
39.Thread Race Applet
40.Applet: Print from an Applet
41.Calling methods of an Applet from JavaScript code
42.Read an applet parameters
43.Change an applet background color
44.Passing Parameters to Java Applet
45.Display message in browser status bar
46.Your own Applet runtime environment
47.This applet is a simple button that plays an audio clip when pushed
48.EventQueue.invokeLater and JApplet
49.An applet component that draws a bar chart
50.This applet displays a greeting from the authors