JDBC连接SQL Server2008 R2

来源:互联网 发布:广州百度seo 编辑:程序博客网 时间:2024/05/13 14:00

2010-06-18 15:57:44|  分类: 数据库技术|字号 订阅

JAVA连接SQL2008与SQL2000有很大的不同,在这里通过笔者的亲身经历详细给出
 
1.首先要去Microsoft官网下载sqljdbc2.0驱动——Microsoft SQL Server JDBC Driver 2.0.exe,很小大概就4M,解压后里面有2个Jar包,sqljdbc4.jar和sqljdbc.jar,这两个都一样,只是针对你的JDK的版本的不同,如果你是JDK6.0直接导入sqljdbc4.jar,以下版本的导入sqljdbc.jar,如果怕麻烦的,两个都导进去也行。
 
2.包导完了,现在启动SQL配置器,SQL2000的默认端口是1433,所以只要开启端口就能连得上,但08的端口据说是动态的,具体的本人也不清楚,就是因为这个端口我也被整了2天,最后终于连上了
 打开配置器:
        【原创】JDBC连接SQL Server2008 R2 - Seans Bolg - sean_zwx的博客
将IP ALL的TCP动态端口(默认1163)改为1433,不改也行,因为大部分人的习惯是用默认的1433,在IP2已启用选择——是,确定。
同样的方法,开启客户端的TCP/IP,端口也为1443,如图:
【原创】JDBC连接SQL Server2008 R2 - Seans Bolg - sean_zwx的博客
然后在DOS命令中输入测试 telnet 127.0.0.1 1433,
如果结果只有一个光标在闪动,那么就说明127.0.0.1 1433端口已经打开。
如果出现连接主机端口1433没打开,久要换端口。
 
现在进入正题
启动MyEclipse 8.5——创建JAVA项目——记住导入sqljdbc4.jar
代码如下
 
我们用SQL验证的sa登录(前提要打开混合模式登录这里不在赘述)
 
import java.sql.*;
public class javaConSQL
{
 public static void main(String[] args) 
 {
  String JDriver="com.microsoft.sqlserver.jdbc.SQLServerDriver";//SQL数据库引擎
  String connectDB="jdbc:sqlserver://127.0.0.1:1433;DatabaseName=Mydb";//数据源
  
  try
  {
   Class.forName(JDriver);//加载数据库引擎,返回给定字符串名的类
  }catch(ClassNotFoundException e)
  {
   //e.printStackTrace();
   System.out.println("加载数据库引擎失败");
   System.exit(0);
  }     
  System.out.println("数据库驱动成功");
  
  try
  {
   String user="sa";
   String password="sql2008";
   Connection con=DriverManager.getConnection(connectDB,user,password);//连接数据库对象
   System.out.println("连接数据库成功");
   Statement stmt=con.createStatement();//创建SQL命令对象
   
   //创建表
   System.out.println("开始创建表");
   String query="create table TABLE1(ID NCHAR(2),NAME NCHAR(10))";//创建表SQL语句
   stmt.executeUpdate(query);//执行SQL命令对象
   System.out.println("表创建成功");
      
   //输入数据
   System.out.println("开始插入数据");
   String a1="INSERT INTO TABLE1 VALUES('1','旭哥')";//插入数据SQL语句
   String a2="INSERT INTO TABLE1 VALUES('2','伟哥')";
   String a3="INSERT INTO TABLE1 VALUES('3','张哥')";
   stmt.executeUpdate(a1);//执行SQL命令对象
   stmt.executeUpdate(a2);   
   stmt.executeUpdate(a3);
   System.out.println("插入数据成功");
   
   //读取数据
   System.out.println("开始读取数据");
   ResultSet rs=stmt.executeQuery("SELECT * FROM TABLE1");//返回SQL语句查询结果集(集合)
   //循环输出每一条记录
   while(rs.next())
   {
    //输出每个字段
    System.out.println(rs.getString("ID")+"\t"+rs.getString("NAME"));
   }
   System.out.println("读取完毕");
   
   //关闭连接
   stmt.close();//关闭命令对象连接
   con.close();//关闭数据库连接
  }
  catch(SQLException e)
  {
   e.printStackTrace();
   //System.out.println("数据库连接错误");
   System.exit(0);
  }
 }
}
MyEclipse8.5 运行结果:
【原创】JDBC连接SQL Server2008 R2 - Seans Bolg - sean_zwx的博客
 
打开SQL2008企业管理器
执行SQL语句
USE Mydb
GO
  SELECT * FROM TABLE1
 
结果为:【原创】JDBC连接SQL Server2008 R2 - Seans Bolg - sean_zwx的博客
 
 
说明已经成功连接SQL,并在数据库Mydb创建表TABLE1
 
谢谢!有哪里不正确的地方,去哪个读者指出,互相学习!!
 
原创粉丝点击