详解一个JDBC实例

开发 后端
本文将介绍一个JDBC实例,包括建立新数据库名以及编写你自己的连接数据库的类。希望这些内容能对大家有所作用。

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

import java.sql.*;  
class Testj{  
     public static void main(String args[])  
     {    
         String RL = "jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=TESTDB";  
         String user ="jack";//这里替换成你自已的数据库用户名  
         String password = "jack";//这里替换成你自已的数据库用户密码  
         String sqlStr = "select * from test_student";  
 
         try{     //这里的异常处理语句是必需的.否则不能通过编译!      
             Class.forName("com.microsoft.jdbc.sqlserver.SQLServerDriver");  
             System.out.println( "类实例化成功!" );  
             System.out.println("slkdjf");  
             Connection con = DriverManager.getConnection(RL,user,password);  
             System.out.println( "创建连接对像成功!" );  
 
             Statement st = con.createStatement();  
             System.out.println( "创建Statement成功!" );  
 
             ResultSet rs = st.executeQuery( sqlStr );  
             System.out.println( "操作数据表成功!" );  
             System.out.println( "----------------!" );  
 
             while(rs.next())  
             {  
                 System.out.print(rs.getInt("Sno") + "     ");  
                 System.out.print(rs.getString("Sname") + "     ");  
                 System.out.print(rs.getInt("Sage") + "     ");  
                 System.out.print(rs.getString("Ssex") + "     ");  
                 System.out.println(rs.getString("Sclass"));  
             }  
             rs.close();  
             st.close();  
             con.close();  
         }  
         catch(Exception err){  
             err.printStackTrace(System.out);  
         }  
     }  

  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.
  • 11.
  • 12.
  • 13.
  • 14.
  • 15.
  • 16.
  • 17.
  • 18.
  • 19.
  • 20.
  • 21.
  • 22.
  • 23.
  • 24.
  • 25.
  • 26.
  • 27.
  • 28.
  • 29.
  • 30.
  • 31.
  • 32.
  • 33.
  • 34.
  • 35.
  • 36.
  • 37.
  • 38.
  • 39.
  • 40.

下面进行调试:

javac Testj.java

java Testj

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

类实例化成功!

slkdjf

创建连接对像成功!

创建Statement成功!

操作数据表成功!

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

2000     海拔               21     男     12       

  

注意:这里有几点要说明

1.路径问题:

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

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

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

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

可千万不要写错哟!

2.sp3补丁包问题:

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

java.sql.SQLException: [Microsoft][SQLServer 2000 Driver for JDBC]Error establis  
ng 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.(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(Unknown Source)  
       at java.sql.DriverManager.getConnection(Unknown Source)  
       at Test.main(Test.java:14)  
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.
  • 11.
  • 12.
  • 13.

3.权限问题   

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

类实例化成功!

slkdjf  
java.sql.SQLException: [Microsoft][SQLServer 2000 Driver for JDBC][SQLServer]用户 'jack' 登录失败。  
原因: 未与信任 SQL Server 连接相关联。  
     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(Unknown Source)  
     at com.microsoft.jdbc.sqlserver.tds.TDSRequest.processReplyToken(Unknown Source)  
     at com.microsoft.jdbc.sqlserver.tds.TDSLoginRequest.processReplyToken(Unknown Source)  
     at com.microsoft.jdbc.sqlserver.tds.TDSRequest.processReply(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:512)  
     at java.sql.DriverManager.getConnection(DriverManager.java:171)  
     at Testj.main(Testj.java:14) 
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.
  • 11.
  • 12.
  • 13.
  • 14.
  • 15.
  • 16.

原困是未设置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驱动的四种类型
责任编辑:彭凡 来源: cnbeta
相关推荐

2009-06-08 17:56:00

SpringJDBC事务

2010-02-06 14:52:15

ibmdw敏捷测试

2009-07-14 16:02:42

JDBC例子

2009-07-21 14:55:30

2024-06-12 10:18:33

2011-09-08 13:41:53

Widget

2011-09-16 10:00:56

C++

2009-07-17 17:07:17

JDBC教程

2011-05-25 15:34:17

jQueryJSON

2009-12-21 16:31:15

静态路由设置

2009-07-30 18:18:27

C#时间计算

2009-08-18 17:19:33

C#事件模型

2009-06-19 13:59:41

Java反射机制

2013-12-17 10:39:24

命令top

2009-07-20 13:58:07

MySQL JDBC驱

2009-09-24 15:53:00

Hibernate J

2010-06-28 14:13:18

SQL Server实

2014-02-17 17:47:16

前端后端架构

2011-06-09 09:31:40

Qt 实例

2011-07-19 09:46:00

Oracle数据库递归查询
点赞
收藏

51CTO技术栈公众号