Jdbc連Sybase數(shù)據(jù)庫的幾種方法
發(fā)表時間:2024-05-24 來源:明輝站整理相關軟件相關文章人氣:
[摘要]1.單用一個JSP文件測試SYBASE jconnect-5_2 JDBC數(shù)據(jù)庫接口: <%@ page contentType="text/html;charset=GB2312" %><%@ page import="java.sql.*&quo...
1.單用一個JSP文件測試SYBASE jconnect-5_2 JDBC數(shù)據(jù)庫接口: <%@ page contentType="text/html;charset=GB2312" %><%@ page import="java.sql.*" %><HTML><HEAD><TITLE> JSP測試SYBASE jconnect-5_2 JDBC數(shù)據(jù)庫接口 </TITLE><META NAME="Generator" CONTENT="EditPlus2.11"><META NAME="Author" CONTENT="naxin"></HEAD><BODY><center>JSP測試SYBASE jconnect-5_2 JDBC數(shù)據(jù)庫接口</center><BR><BR><table border=3 align=center ><%Class.forName("com.sybase.jdbc2.jdbc.SybDriver");String url ="jdbc:sybase:Tds:localhost:2638"; Connection conn= DriverManager.getConnection(url, "dba","sql"); Statement stmt=conn.createStatement(); String sql="select emp_lname,dept_id,street,city,state from employee order by emp_lname"; ResultSet rs=stmt.executeQuery(sql); while(rs.next()) {out.print("<TR><TD>"+rs.getString("emp_lname")+"</TD>");out.print("<TD>"+rs.getString("dept_id")+"</TD>");out.print("<TD>"+rs.getString("street")+"</TD>");out.print("<TD>"+rs.getString("city")+"</TD>");out.print("<TD>"+rs.getString("state")+"</TD></TR>");}%> </table><BR><HR><%out.print("數(shù)據(jù)庫操作成功,恭喜你");%> <%rs.close(); stmt.close(); conn.close(); %> </BODY></HTML>
|
2.再用JSP和Java Bean的方法: JSP Code:<%@ page contentType="text/html;charset=GB2312" %><%@ page import="java.sql.*" %><HTML><HEAD><TITLE> </TITLE><META NAME="Generator" CONTENT="EditPlus2.11"><META NAME="Author" CONTENT="naxin"></HEAD><BODY><jsp:useBean id="sybase" scope="page" class="test.sybconn" /><%ResultSet rs=sybase.Query("select * from tjck_dh"); while(rs.next()) {out.print(" "+rs.getString("name")+" ");out.print(rs.getString("card_no")+" ");out.print(rs.getString("amount")+" ");out.print(rs.getString("home_call")+" ");out.print(rs.getString("office_call")+" <br>");}rs.close(); %><HR>Bean的代碼:package test;import java.sql.*;public class sybconn {// String sDBDriver = "com.sybase.jdbc2.jdbc.SybDriver"; String sConnStr = "jdbc:sybase:Tds:localhost:2638";// String user="dba";// String passwd="sql";Connection conn = null;ResultSet rs = null;public ResultSet Query(String sql) throws SQLException,Exception {Class.forName("com.sybase.jdbc2.jdbc.SybDriver").newInstance();conn = DriverManager.getConnection(sConnStr,"dba","sql");Statement stmt = conn.createStatement();rs = stmt.executeQuery(sql);return rs;}}
|
3.利用JDBC(SYBAE jconnect-5_2)查詢Sybase ASA7.0中數(shù)據(jù)的圖形化Java程序范例:
//// 一個簡單的利用JDBC(SYBAE jconnect-5_2)查詢Sybase ASA7.0中數(shù)據(jù)的圖形化Java程序范例// 執(zhí)行的SQL語句是" select * from employee " ,可以改成自己所需的.// 運行方式為: c:\> java JDBCTest //import java.awt.*; import java.sql.*; // 在使用JDBC之前,必須引入JAVA的SQL包class JDBCTest extends Frame {TextArea myTextArea;public JDBCTest () {//設定程序的顯示界面super("一個簡單的利用JDBC(jconnect-5_2)查詢Sybase ASA7.0中數(shù)據(jù)的圖形化Java程序范例");setLayout(new FlowLayout());myTextArea = new TextArea(30,80);add(myTextArea);resize(500,500);show();myTextArea.appendText("數(shù)據(jù)庫查詢中,請等待......\n");}void displayResults(ResultSet results) throws SQLException {//首先得到查詢結果的信息ResultSetMetaData resultsMetaData = results.getMetaData();int cols = resultsMetaData.getColumnCount();//將等待信息清除myTextArea.setText("");//顯示結果while(results.next()) {for(int i=1;i<=cols;i++) {if(i>1)myTextArea.appendText("\t");try{myTextArea.appendText(results.getString(i));}// 捕獲空值時產(chǎn)生的異常catch(NullPointerException e){}}myTextArea.appendText("\n");}}public boolean handleEvent(Event evt) {if (evt.id == Event.WINDOW_DESTROY) {System.exit(0);return true;}return super.handleEvent(evt);}public static void main(String argv[]) throws SQLException,Exception {//設定查詢字串String queryString = "select * from employee";JDBCTest myJDBCTest = new JDBCTest();//加載驅(qū)動程序Class.forName("com.sybase.jdbc2.jdbc.SybDriver").newInstance();//建立連接,localhost為主機名,dba為用戶名,sql為密碼Connection myConn = DriverManager.getConnection("jdbc:sybase:Tds:localhost:2638","dba","sql");Statement myStmt = myConn.createStatement();//執(zhí)行查詢ResultSet myResults = myStmt.executeQuery(queryString);myJDBCTest.displayResults(myResults);//關閉所有打開的資源myResults.close();myStmt.close();myConn.close();}}