详解一个JDBC实例 小金鱼挂件的编织
创始人
2024-04-16 01:01:21
0

JDBC实例前提

1.SQL Server 2000 任意版本     //本人用的是企业版

2.SQL Server 2000 sp3升级包

你可以在这里下载http://www.bossed.com.cn/download/detailcp.asp?id=74

3.SQL Server 2000 jdbc 驱动   //这个就需要自己找了!

4.jdk1.4 //以下的例子是该版本

在以上条件满足的情况下,作以下事情

1.建立新数据库名为:jspdev ,并在其中建立一个名为userinfo的表

包括以下几列(Sno,Sname,Sage,Ssex,Sclass) 

2.开始编写你自己的连接数据库的类(我这里是借鉴他人的版权不归我所有),你也可以用自己的方法

  1. import java.sql.*;  
  2. class Testj{  
  3.      public static void main(String args[])  
  4.      {    
  5.          String RL = "jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=TESTDB";  
  6.          String user ="jack";//这里替换成你自已的数据库用户名  
  7.          String password = "jack";//这里替换成你自已的数据库用户密码  
  8.          String sqlStr = "select * from test_student";  
  9.  
  10.          try{     //这里的异常处理语句是必需的.否则不能通过编译!      
  11.              Class.forName("com.microsoft.jdbc.sqlserver.SQLServerDriver");  
  12.              System.out.println( "类实例化成功!" );  
  13.              System.out.println("slkdjf");  
  14.              Connection con = DriverManager.getConnection(RL,user,password);  
  15.              System.out.println( "创建连接对像成功!" );  
  16.  
  17.              Statement st = con.createStatement();  
  18.              System.out.println( "创建Statement成功!" );  
  19.  
  20.              ResultSet rs = st.executeQuery( sqlStr );  
  21.              System.out.println( "操作数据表成功!" );  
  22.              System.out.println( "----------------!" );  
  23.  
  24.              while(rs.next())  
  25.              {  
  26.                  System.out.print(rs.getInt("Sno") + "     ");  
  27.                  System.out.print(rs.getString("Sname") + "     ");  
  28.                  System.out.print(rs.getInt("Sage") + "     ");  
  29.                  System.out.print(rs.getString("Ssex") + "     ");  
  30.                  System.out.println(rs.getString("Sclass"));  
  31.              }  
  32.              rs.close();  
  33.              st.close();  
  34.              con.close();  
  35.          }  
  36.          catch(Exception err){  
  37.              err.printStackTrace(System.out);  
  38.          }  
  39.      }  

下面进行调试:

javac Testj.java

java Testj

如果JDBC实例正确输出应该是:

类实例化成功!

slkdjf

创建连接对像成功!

创建Statement成功!

操作数据表成功!

----------------!

2000     海拔               21     男     12       

  

注意:这里有几点要说明

1.路径问题:

你必须配置你的classpath路径否则他在编译时会报错   

  1. java.lang.ClassNotFoundException: com.microsoft.jdbc.sqlserver.SQLServerDriver  
  2.         at java.net.URLClassLoader$1.run(URLClassLoader.java:199)  
  3.         at java.security.AccessController.doPrivileged(Native Method)  
  4.         at java.net.URLClassLoader.findClass(URLClassLoader.java:187)  
  5.         at java.lang.ClassLoader.loadClass(ClassLoader.java:289)  
  6.         at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:274)  
  7.         at java.lang.ClassLoader.loadClass(ClassLoader.java:235)  
  8.         at java.lang.ClassLoader.loadClassInternal(ClassLoader.java:302)  
  9.         at java.lang.Class.forName0(Native Method)  
  10.         at java.lang.Class.forName(Class.java:141)  
  11.         at Test.main(Test.java:11)  

你的路径应该是这样配置:你可以在在安装jdbc驱动后看那里的帮助文档(是英文的);

  1. //这里指在xp系统下  
  2. classpath = .;G:\Microsoft SQL Server 2000 \Driver for JDBC\lib\msbase.jar;  
  3.                G:\Microsoft SQL Server 2000 \Driver for JDBC\lib\mssqlserver.jar;  
  4.                G:\Microsoft SQL Server 2000 \Driver for JDBC\lib\msutil.jar; 

可千万不要写错哟!

2.sp3补丁包问题:

如果你在编译时出现下列问题 那么你需要下载并安装sp3补丁包

  1. java.sql.SQLException: [Microsoft][SQLServer 2000 Driver for JDBC]Error establis  
  2. ng socket.  
  3.        at com.microsoft.jdbc.base.BaseExceptions.createException(Unknown Source)  
  4.        at com.microsoft.jdbc.base.BaseExceptions.getException(Unknown Source)  
  5.        at com.microsoft.jdbc.base.BaseExceptions.getException(Unknown Source)  
  6.        at com.microsoft.jdbc.sqlserver.tds.TDSConnection.(Unknown Source)  
  7.        at com.microsoft.jdbc.sqlserver.SQLServerImplConnection.open(Unknown Source)  
  8.        at com.microsoft.jdbc.base.BaseConnection.getNewImplConnection(Unknown Source)  
  9.        at com.microsoft.jdbc.base.BaseConnection.open(Unknown Source)  
  10.        at com.microsoft.jdbc.base.BaseDriver.connect(Unknown Source)  
  11.        at java.sql.DriverManager.getConnection(Unknown Source)  
  12.        at java.sql.DriverManager.getConnection(Unknown Source)  
  13.        at Test.main(Test.java:14)  

3.权限问题   

如果你出现类似这样的问题

类实例化成功!

  1. slkdjf  
  2. java.sql.SQLException: [Microsoft][SQLServer 2000 Driver for JDBC][SQLServer]用户 'jack' 登录失败。  
  3. 原因: 未与信任 SQL Server 连接相关联。  
  4.      at com.microsoft.jdbc.base.BaseExceptions.createException(Unknown Source)  
  5.      at com.microsoft.jdbc.base.BaseExceptions.getException(Unknown Source)  
  6.      at com.microsoft.jdbc.sqlserver.tds.TDSRequest.processErrorToken(Unknown Source)  
  7.      at com.microsoft.jdbc.sqlserver.tds.TDSRequest.processReplyToken(Unknown Source)  
  8.      at com.microsoft.jdbc.sqlserver.tds.TDSLoginRequest.processReplyToken(Unknown Source)  
  9.      at com.microsoft.jdbc.sqlserver.tds.TDSRequest.processReply(Unknown Source)  
  10.      at com.microsoft.jdbc.sqlserver.SQLServerImplConnection.open(Unknown Source)  
  11.      at com.microsoft.jdbc.base.BaseConnection.getNewImplConnection(Unknown Source)  
  12.      at com.microsoft.jdbc.base.BaseConnection.open(Unknown Source)  
  13.      at com.microsoft.jdbc.base.BaseDriver.connect(Unknown Source)  
  14.      at java.sql.DriverManager.getConnection(DriverManager.java:512)  
  15.      at java.sql.DriverManager.getConnection(DriverManager.java:171)  
  16.      at Testj.main(Testj.java:14) 

原困是未设置SQL Server登录认证模式为混合认证模式,因为SQL Server默认安装后认证模式为WINDOWS认证模式,从而导致出错。

JDBC实例问题解决方法:启动SQLSERVER企业管理器,选择要进行认证模式设置的服务器。右击该服务器,在弹出菜单中选择属性,SQL Server将弹出属性对话框在属性对话框中选择安全性选项,在身份验证处选择“SQL Server和Windows”,然后确定。

【编辑推荐】

  1. 使用JDBC的五个精华功能
  2. Tomcat5+MySQL JDBC连接池配置
  3. 在Weblogic中实现JDBC的功能
  4. 详解JDBC与Hibernate区别
  5. JDBC连接MySQL数据库关键四步
  6. 详解JDBC驱动的四种类型

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...
《非诚勿扰》红人闫凤娇被曝厕所... 【51CTO.com 综合消息360安全专家提醒说,“闫凤娇”、“非诚勿扰”已经被黑客盯上成为了“木...
2012年第四季度互联网状况报... [[71653]]  北京时间4月25日消息,据国外媒体报道,全球知名的云平台公司Akamai Te...