亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? querydb.java

?? core java第二卷源代碼第四章。歡迎大家下載
?? JAVA
字號:
/**
   @version 1.21 2001-07-06
   @author Cay Horstmann
*/

import java.net.*;
import java.sql.*;
import java.awt.*;
import java.awt.event.*;
import java.io.*;
import java.util.*;
import javax.swing.*;

/**
   This program demonstrates several complex database queries.
*/
public class QueryDB
{  
   public static void main(String[] args)
   {  
      JFrame frame = new QueryDBFrame();
      frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
      frame.show();
   }
}

/**
   This frame displays combo boxes for query parameters,
   a text area for command results, and buttons to launch
   a query and an update.
*/
class QueryDBFrame extends JFrame
{  
   public QueryDBFrame()
   {  
      setTitle("QueryDB");
      setSize(WIDTH, HEIGHT);
      getContentPane().setLayout(new GridBagLayout());
      GridBagConstraints gbc = new GridBagConstraints();

      authors = new JComboBox();
      authors.setEditable(false);
      authors.addItem("Any");

      publishers = new JComboBox();
      publishers.setEditable(false);
      publishers.addItem("Any");

      result = new JTextArea(4, 50);
      result.setEditable(false);

      priceChange = new JTextField(8);
      priceChange.setText("-5.00");

      try
      {  
         conn = getConnection();
         stat = conn.createStatement();

         String query = "SELECT Name FROM Authors";
         ResultSet rs = stat.executeQuery(query);
         while (rs.next())
            authors.addItem(rs.getString(1));
         rs.close();

         query = "SELECT Name FROM Publishers";
         rs = stat.executeQuery(query);
         while (rs.next())
            publishers.addItem(rs.getString(1));
         rs.close();
      }
      catch(SQLException ex)
      {  
         result.setText("");
         while (ex != null)
         {
            result.append("" + ex);
            ex = ex.getNextException();
         }
      }
      catch (IOException ex)
      {
         result.setText("" + ex);
      }

      gbc.fill = GridBagConstraints.NONE;
      gbc.weightx = 100;
      gbc.weighty = 100;
      add(authors, gbc, 0, 0, 2, 1);

      add(publishers, gbc, 2, 0, 2, 1);

      gbc.fill = GridBagConstraints.NONE;
      JButton queryButton = new JButton("Query");
      queryButton.addActionListener(new
         ActionListener()
         {
            public void actionPerformed(ActionEvent event)
            {
               executeQuery();
            }
         });
      add(queryButton, gbc, 0, 1, 1, 1);

      JButton changeButton = new JButton("Change prices");
      changeButton.addActionListener(new
         ActionListener()
         {
            public void actionPerformed(ActionEvent event)
            {
               changePrices();
            }
         });
      add(changeButton, gbc, 2, 1, 1, 1);

      gbc.fill = GridBagConstraints.HORIZONTAL;
      add(priceChange, gbc, 3, 1, 1, 1);

      gbc.fill = GridBagConstraints.BOTH;
      add(new JScrollPane(result), gbc, 0, 2, 4, 1);

      addWindowListener(new
         WindowAdapter()
         {  
            public void windowClosing(WindowEvent e)
            {  
               try
               {  
                  stat.close();
                  conn.close();
               }
               catch(SQLException ex) 
               {
                  while (ex != null)
                  {
                     ex.printStackTrace();
                     ex = ex.getNextException();
                  }
               }
            }
        });
   }

   /**
      Add a component to this frame.
      @param c the component to add
      @param gbc the grid bag constraints
      @param x the grid bax column
      @param y the grid bag row
      @param w the number of grid bag columns spanned
      @param h the number of grid bag rows spanned
   */
   private void add(Component c, GridBagConstraints gbc,
      int x, int y, int w, int h)
   {  
      gbc.gridx = x;
      gbc.gridy = y;
      gbc.gridwidth = w;
      gbc.gridheight = h;
      getContentPane().add(c, gbc);
   }

   /**
      Executes the selected query.
   */
   private void executeQuery()
   {
      ResultSet rs = null;
      try
      {  
         String author
            = (String)authors.getSelectedItem();
         String publisher
            = (String)publishers.getSelectedItem();
         if (!author.equals("Any")
            && !publisher.equals("Any"))
         {  
            if (authorPublisherQueryStmt == null)
            {  
               String authorPublisherQuery =
"SELECT Books.Price, Books.Title " +
"FROM Books, BooksAuthors, Authors, Publishers " +
"WHERE Authors.Author_Id = BooksAuthors.Author_Id AND " +
"BooksAuthors.ISBN = Books.ISBN AND " +
"Books.Publisher_Id = Publishers.Publisher_Id AND " +
"Authors.Name = ? AND " +
"Publishers.Name = ?";
               authorPublisherQueryStmt
                  = conn.prepareStatement(authorPublisherQuery);
            }
            authorPublisherQueryStmt.setString(1, author);
            authorPublisherQueryStmt.setString(2,
               publisher);
            rs = authorPublisherQueryStmt.executeQuery();
         }
         else if (!author.equals("Any")
            && publisher.equals("Any"))
         {  
            if (authorQueryStmt == null)
            {  
               String authorQuery =
"SELECT Books.Price, Books.Title " +
"FROM Books, BooksAuthors, Authors " +
"WHERE Authors.Author_Id = BooksAuthors.Author_Id AND " +
"BooksAuthors.ISBN = Books.ISBN AND " +
"Authors.Name = ?";
               authorQueryStmt
                  = conn.prepareStatement(authorQuery);
            }
            authorQueryStmt.setString(1, author);
            rs = authorQueryStmt.executeQuery();
         }
         else if (author.equals("Any")
            && !publisher.equals("Any"))
         {  
            if (publisherQueryStmt == null)
            {  
               String publisherQuery =
"SELECT Books.Price, Books.Title " +
"FROM Books, Publishers " +
"WHERE Books.Publisher_Id = Publishers.Publisher_Id AND " +
"Publishers.Name = ?";
               publisherQueryStmt
                  = conn.prepareStatement(publisherQuery);
            }
            publisherQueryStmt.setString(1, publisher);
            rs = publisherQueryStmt.executeQuery();
         }
         else
         {  
            if (allQueryStmt == null)
            {  
               String allQuery =
"SELECT Books.Price, Books.Title FROM Books";
               allQueryStmt
                  = conn.prepareStatement(allQuery);
            }
            rs = allQueryStmt.executeQuery();
         }

         result.setText("");
         while (rs.next())
         {
            result.append(rs.getString(1));
            result.append(", ");
            result.append(rs.getString(2));
            result.append("\n");
         }
         rs.close();
      }
      catch(SQLException ex)
      {
         result.setText("");
         while (ex != null)
         {
            result.append("" + ex);
            ex = ex.getNextException();
         }
      }
   }

   /**
      Executes an update statement to change prices.
   */
   public void changePrices()
   {
      String publisher
         = (String)publishers.getSelectedItem();
      if (publisher.equals("Any"))
      {
         result.setText
            ("I am sorry, but I cannot do that.");
         return;
      }
      try
      {  
         String updateStatement =
"UPDATE Books " +
"SET Price = Price + " + priceChange.getText() +
" WHERE Books.Publisher_Id = " +
"(SELECT Publisher_Id FROM Publishers WHERE Name = '" +
            publisher + "')";
         int r = stat.executeUpdate(updateStatement);
         result.setText(r + " records updated.");
      }     
      catch(SQLException ex)
      {
         result.setText("");
         while (ex != null)
         {
            result.append("" + ex);
            ex = ex.getNextException();
         }
      }
   }

   /**
      Gets a connection from the properties specified
      in the file database.properties
      @return the database connection
   */
   public static Connection getConnection()
      throws SQLException, IOException
   {  
      Properties props = new Properties();
      FileInputStream in 
         = new FileInputStream("database.properties");
      props.load(in);
      in.close();

      String drivers = props.getProperty("jdbc.drivers");
      if (drivers != null)
         System.setProperty("jdbc.drivers", drivers);
      String url = props.getProperty("jdbc.url");
      String username = props.getProperty("jdbc.username");
      String password = props.getProperty("jdbc.password");

      return
         DriverManager.getConnection(url, username, password);
   }

   public static final int WIDTH = 400;
   public static final int HEIGHT = 400;  
  
   private JComboBox authors;
   private JComboBox publishers;
   private JTextField priceChange;
   private JTextArea result;
   private Connection conn;
   private Statement stat;
   private PreparedStatement authorQueryStmt;
   private PreparedStatement authorPublisherQueryStmt;
   private PreparedStatement publisherQueryStmt;
   private PreparedStatement allQueryStmt;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩欧美视频在线| 一区二区三区自拍| 亚洲免费av在线| 狂野欧美性猛交blacked| 一本色道亚洲精品aⅴ| 精品电影一区二区三区| 亚洲一卡二卡三卡四卡五卡| 国产成人av电影| 精品国产乱码久久久久久牛牛| 亚洲美女免费在线| 国产风韵犹存在线视精品| 欧美精品九九99久久| 一区二区三区免费网站| www.成人网.com| 国产欧美视频一区二区三区| 久久99精品国产麻豆婷婷洗澡| 在线免费av一区| 亚洲日韩欧美一区二区在线| 国产美女精品一区二区三区| 精品国免费一区二区三区| 婷婷成人激情在线网| 欧美三级韩国三级日本三斤 | 91精品久久久久久久91蜜桃| 亚洲精品视频在线观看网站| 成人国产电影网| 国产拍欧美日韩视频二区| 九九精品一区二区| 日韩一区二区免费视频| 视频一区二区三区中文字幕| 欧美日韩亚洲综合一区二区三区 | 欧美体内she精视频| 亚洲欧洲99久久| 北岛玲一区二区三区四区| 国产精品你懂的| 成年人网站91| 中文字幕在线观看一区| 99精品视频在线播放观看| 综合在线观看色| 色狠狠av一区二区三区| 亚洲国产aⅴ天堂久久| 欧美精品自拍偷拍动漫精品| 日韩精品成人一区二区在线| 日韩精品一区二区三区蜜臀| 精品系列免费在线观看| 久久精品日韩一区二区三区| 成人动漫一区二区三区| 综合在线观看色| 欧美视频在线观看一区二区| 天堂久久一区二区三区| 日韩欧美另类在线| 成人一区在线观看| 亚洲精品va在线观看| 日本韩国一区二区| 免费在线一区观看| 国产女同性恋一区二区| 99re热这里只有精品视频| 一区二区免费看| 制服丝袜日韩国产| 高清在线不卡av| 亚洲自拍偷拍图区| 日韩亚洲国产中文字幕欧美| 国产白丝网站精品污在线入口 | 久久色视频免费观看| 高清成人免费视频| 亚洲黄色片在线观看| 欧美挠脚心视频网站| 国产精品99久久久久久宅男| 亚洲视频在线观看三级| 欧美二区三区的天堂| 精品中文字幕一区二区| 中文字幕中文乱码欧美一区二区| 日本乱人伦aⅴ精品| 精品无码三级在线观看视频| 亚洲免费毛片网站| 国产亚洲一区字幕| 欧美在线观看视频一区二区三区| 久久精品国产亚洲高清剧情介绍| 日韩理论片一区二区| 欧美成人乱码一区二区三区| 在线一区二区视频| 国产精品一区三区| 日本中文一区二区三区| 亚洲欧美在线高清| 久久久久久久久99精品| 欧美乱妇23p| 色综合 综合色| 国产成人日日夜夜| 日本亚洲欧美天堂免费| 一区二区三区蜜桃| 国产精品久99| 日本一区二区三区视频视频| 日韩欧美激情四射| 欧美日韩精品福利| 在线看一区二区| 91色在线porny| 粉嫩高潮美女一区二区三区 | 精品福利一区二区三区| 欧美丝袜丝交足nylons图片| 成人av午夜电影| 国产一区二区免费在线| 日韩福利电影在线观看| 亚洲一区影音先锋| 亚洲精品视频在线看| 日韩一区在线免费观看| 国产欧美一区二区三区网站| 精品99999| 日韩精品在线一区二区| 日韩一级免费一区| 欧美一级高清片在线观看| 欧美精品一卡两卡| 欧美精品成人一区二区三区四区| 欧美在线免费播放| 欧美性感一类影片在线播放| 91国模大尺度私拍在线视频| 91黄视频在线观看| 欧美性受极品xxxx喷水| 欧洲激情一区二区| 欧美日韩成人综合天天影院| 欧美午夜精品一区| 欧美三级午夜理伦三级中视频| 在线视频一区二区三| 欧美日韩亚洲不卡| 欧美日韩国产成人在线91| 6080日韩午夜伦伦午夜伦| 日韩欧美一二三四区| 久久综合久久久久88| 中文字幕av一区 二区| 最近中文字幕一区二区三区| 一区二区在线看| 午夜久久久久久久久久一区二区| 琪琪久久久久日韩精品| 国产乱一区二区| av不卡一区二区三区| 欧美视频在线播放| 欧美成人国产一区二区| 久久久久高清精品| 亚洲欧美偷拍卡通变态| 性欧美疯狂xxxxbbbb| 久草中文综合在线| 日本韩国精品在线| 欧美日韩精品三区| 久久这里只有精品视频网| 国产精品三级视频| 亚洲成人久久影院| 精品一区二区免费视频| av中文字幕亚洲| 在线观看91av| 国产亚洲精品福利| 亚洲第一成人在线| 国产.欧美.日韩| 欧美丝袜丝nylons| 欧美国产激情二区三区| 国产专区欧美精品| 国产成人鲁色资源国产91色综| 欧洲精品一区二区| 国产亚洲欧洲一区高清在线观看| 一区二区三区中文在线观看| 久久精品久久精品| 91免费版在线| 日韩精品一区二区三区在线| 自拍偷拍亚洲激情| 狠狠色丁香婷婷综合| 91理论电影在线观看| 久久网站热最新地址| 亚洲影院久久精品| 成人不卡免费av| 精品卡一卡二卡三卡四在线| 亚洲一二三专区| 成人成人成人在线视频| 精品国产露脸精彩对白| 亚洲一区二区三区视频在线 | 国产精品一区二区黑丝| 欧美在线观看一区| 国产清纯美女被跳蛋高潮一区二区久久w | 色偷偷久久人人79超碰人人澡| 欧美成人精品3d动漫h| 亚洲午夜免费电影| 99国产精品视频免费观看| 精品国产精品网麻豆系列 | 欧美一级艳片视频免费观看| 亚洲视频在线一区观看| 成人一区二区三区视频在线观看| 日韩精品中文字幕一区二区三区| 亚洲第一二三四区| 在线免费精品视频| 怡红院av一区二区三区| 99久久99久久综合| 日本一区二区高清| 国产精品一区二区久激情瑜伽 | 国产福利电影一区二区三区| 日韩精品一区在线| 蜜桃视频在线一区| 日韩欧美亚洲一区二区| 免费久久99精品国产| 日韩欧美国产一区二区三区 | 91精品办公室少妇高潮对白| 亚洲免费资源在线播放| 色哟哟在线观看一区二区三区| 亚洲欧美一区二区三区国产精品| 成人不卡免费av|