午夜剧场伦理_日本一道高清_国产又黄又硬_91黄色网战_女同久久另类69精品国产_妹妹的朋友在线

您的位置:首頁技術(shù)文章
文章詳情頁

SQL Server2000+JDBC常見問題及解決

瀏覽:191日期:2024-07-05 15:27:19

SQL Server 2000 是當今網(wǎng)絡(luò)編程中使用的比較多的一個數(shù)據(jù)庫系統(tǒng),java是目前最流行的編程語言,在編程中涉及的比較多也比較重要的就是數(shù)據(jù)庫問題,java自身提供了對各類主流數(shù)據(jù)庫系統(tǒng)的支持,通過java.sql 庫,提供了統(tǒng)一的接口,使得可以在java環(huán)境下不必對程序作大規(guī)模的修改,只要更改相應(yīng)的驅(qū)動程序,即可實現(xiàn)對各類數(shù)據(jù)庫的操作,從而提高軟件的生存周期和降低軟件的開發(fā)成本和維護費用,在這種情況下SQL Server 2000 和java 的融合問題就顯得比較重要了,本文簡要地闡述一下SQL Server 2000 和jdk的融合問題。

系統(tǒng)需求:

 數(shù)據(jù)庫:SQL Server 2000 sp3 驅(qū)動程序:SQL Server driver for jdbc  java版本:jdk1.2以上

1:我們首先使用jdbc-odbc橋來實現(xiàn)數(shù)據(jù)庫的連接,這個相對簡單。首先使用SQL Server 企業(yè)管理其建立一個數(shù)據(jù)庫test,并建立一個簡單的表 first_table

建立odbc數(shù)據(jù)源 ,各步驟采用默認操作即可

編寫一個簡單的測試程序,該程序主要實現(xiàn)數(shù)據(jù)庫的連接,以及一個簡單的sql操作 ,代碼如下:

/***********************************************/*/*DbTest.java/*/******************************************* */

import java.sql.*;

public class DbTest {

 Connection con; Statement sta; ResultSet rs;

 String driver; String url; String user; String pwd; public DbTest() {driver = 'sun.jdbc.odbc.JdbcOdbcDriver';url = 'jdbc:odbc:store_manager';user = 'share';pwd = 'share';init(); } public void init() {try{ Class.forName(driver); System.out.println('driver is ok'); con = DriverManager.getConnection(url,user,pwd); System.out.println('conection is ok'); sta = con.createStatement(); rs = sta.executeQuery('select * from room'); while(rs.next())System.out.println(rs.getInt('roomNum')); }catch(Exception e){ e.printStackTrace();} }

 public static void main(String args [])//自己替換[] {new DbTest(); }};

運行結(jié)果如下:

driver is okconection is ok100110021003100410051006Press any key to continue...

順利通過測試

2、我們這次不通過odbc橋來操作數(shù)據(jù)庫,我們采用SQL Server driver 來實現(xiàn)對SQL Server數(shù)據(jù)庫的操作, 這將是我們這篇文章的重點,因為jdbc-odbc橋是一種常見的操作windows系統(tǒng)數(shù)據(jù)庫的常用方法,但它存在的缺點很多,所以現(xiàn)在很多開發(fā)者都側(cè)重于使用sqlserver driver來操作,在這里我們通過一步步的調(diào)試,來加深讀者對這種連接的理解

在通常的理解下,只要我們裝了sqlserver driver for jdbc 我們便可進行數(shù)據(jù)庫編程,事實則不然,首先我們看下邊的代碼:

/***********************************************/*/*DbTest.java/*http://www.mypchelp.cn/******************************************* */

import java.sql.*;

public class DbTest {

 Connection con; Statement sta; ResultSet rs;

 String driver; String url; String user; String pwd; public DbTest() {driver = 'com.microsoft.jdbc.sqlserver.SQLServerDriver';;url = 'jdbc:microsoft:sqlserver://localhost:1433;DatabaseName =StoreManager';user = 'sa';pwd = 'potsmart10';init(); } public void init() {try{ Class.forName(driver); System.out.println('driver is ok'); con = DriverManager.getConnection(url,user,pwd); System.out.println('conection is ok'); sta = con.createStatement(); rs = sta.executeQuery('select * from room'); while(rs.next()) System.out.println(rs.getInt('roomNum')); }catch(Exception e){ e.printStackTrace();} }

 public static void main(String args [])//自己替換[] {new DbTest(); }};

這段代碼跟上變得代碼是一樣的,差別在于驅(qū)動,還有url,這是在使用sqlserver driver for jdbc 中遇到的困惑。按道理講,上邊這段代碼應(yīng)該沒錯,可首先我們來看一下,如果SQL Server服務(wù)器沒有升級到sp3(在使用jdbc時,如果系統(tǒng)是xp或者2003務(wù)必要把sqlserver 升級到sp3,往上到處都有下的),我們看看運行結(jié)果

driver is okjava.sql.SQLException: [Microsoft][SQLServer 2000 Driver for JDBC]Error establishing socket.at com.microsoft.jdbc.base.BaseExceptions.createException(Unknown Source)at com.microsoft.jdbc.base.BaseExceptions.getException(Unknown Source)at com.microsoft.jdbc.base.BaseExceptions.getException(Unknown Source)at com.microsoft.jdbc.sqlserver.tds.TDSConnection.<init>(Unknown Source)

at com.microsoft.jdbc.sqlserver.SQLServerImplConnection.open(Unknown Source)at com.microsoft.jdbc.base.BaseConnection.getNewImplConnection(Unknown Source)at com.microsoft.jdbc.base.BaseConnection.open(Unknown Source)at com.microsoft.jdbc.base.BaseDriver.connect(Unknown Source)at java.sql.DriverManager.getConnection(DriverManager.java:523)at java.sql.DriverManager.getConnection(DriverManager.java:171)at DbTest.init(DbTest.java:32)at DbTest.<init>(DbTest.java:25)at DbTest.main(DbTest.java:46)Press any key to continue...

出現(xiàn)上邊錯誤的主要原因是默認的數(shù)據(jù)庫服務(wù)器端口 1433沒有打開,無法直接連接 。

如果升級到sp3則這個問題可以結(jié)決,我們再來看看升級之后,程序運行的結(jié)果

driver is okconection is okjava.sql.SQLException: [Microsoft][SQLServer 2000 Driver for JDBC][SQLServer]對象名 'room' 無效。at com.microsoft.jdbc.base.BaseExceptions.createException(Unknown Source)at com.microsoft.jdbc.base.BaseExceptions.getException(Unknown Source)at com.microsoft.jdbc.sqlserver.tds.TDSRequest.processErrorToken(UnknownSource)at com.microsoft.jdbc.sqlserver.tds.TDSRequest.processReplyToken(UnknownSource)at com.microsoft.jdbc.sqlserver.tds.TDSExecuteRequest.processReplyToken(Unknown Source)at com.microsoft.jdbc.sqlserver.tds.TDSRequest.processReply(Unknown Source)at com.microsoft.jdbc.sqlserver.SQLServerImplStatement.getNextResultType(Unknown Source)at com.microsoft.jdbc.base.BaseStatement.commonTransitionToState(UnknownSource)at com.microsoft.jdbc.base.BaseStatement.postImplExecute(Unknown Source)

at com.microsoft.jdbc.base.BaseStatement.commonExecute(Unknown Source)at com.microsoft.jdbc.base.BaseStatement.executeQueryInternal(Unknown Source)at com.microsoft.jdbc.base.BaseStatement.executeQuery(Unknown Source)at DbTest.init(DbTest.java:35)at DbTest.<init>(DbTest.java:25)at DbTest.main(DbTest.java:46)Press any key to continue...

在這兒,用戶已經(jīng)登陸上去,但是卻不能訪問里邊的數(shù)據(jù)表,出現(xiàn)這個問題的原因在于sa用戶為系統(tǒng)用戶,它雖然能夠登陸數(shù)據(jù)庫,但是storeManager數(shù)據(jù)庫里邊卻沒有這個用戶的訪問權(quán)限,所以,我們現(xiàn)在為這個數(shù)據(jù)庫重新建立一個用戶share ,建立過程如下:在storeManager數(shù)據(jù)庫中選重用戶 ---〉新建用戶 -- 〉名稱選擇(這一步中有兩個關(guān)鍵點 1:身份驗證選sql身份驗證,默認數(shù)據(jù)庫選StoreManager)-〉建立新教色share ,此時更改程序,將用戶登陸名和密碼修改一下,重新運行程序

driver is okconection is ok100110021003100410051006Press any key to continue...

這次順利通過測試

總結(jié):

SQL Server和jdbc 的融合問題,關(guān)鍵涉及到sp3補丁(端口開放)還有用戶問題,解決這兩個問題之后,剩余的便是sqlserver 操作問題了,還有一點在遠程操作的時候,要把sqlserver 組設(shè)置一下,在安全性里邊亦將身份驗證更改為SQL Server 驗證即可。

標簽: JDBC
主站蜘蛛池模板: 日本视频在线观看免费 | 最近日韩中文字幕中文 | 国产sm在线观看 | 欧美一区2区 | 在线视频 中文字幕 | 四虎永久免费在线观看 | 欧美色婷婷 | 成人在线观看一区二区 | 色无极影院亚洲 | 欧美日韩综合视频 | 色网站免费看 | 久久久久久久久亚洲 | 亚洲高清网站 | 狠狠操中文字幕 | 国产精品另类 | 很黄很色| 久一在线 | 北条麻妃99精品青青久久 | 午夜激情免费 | 欧美一级影院 | 欧美巨大荫蒂茸毛毛人妖 | 在线观看免费黄色小视频 | 超碰人人av | 国产91高清 | 亚洲色图88 | 国产黑丝91| 自拍视频一区 | 亚洲自啪 | 性高潮久久久久久久 | 日韩av自拍| 日韩在线视 | 亚洲欧美精品在线 | 欧美激情片在线观看 | 高清成人在线 | 国产一区二区视频网站 | 国产一区二区三区影院 | 夜夜狠狠擅视频 | 五月天综合在线 | 一道本在线观看视频 | 欧美专区第一页 | 综合网久久 |