JDBC连接SQL Server2008 R2



JAVA连接SQL2008SQL2000有很大的不同
 
1.
首先要去Microsoft官网下载sqljdbc2.0驱动——Microsoft SQL Server JDBC Driver 2.0.exe,很小大概就4M,解压后里面有2Jar包,sqljdbc4.jarsqljdbc.jar,这两个都一样,只是针对你的JDK的版本的不同,如果你是JDK6.0直接导入sqljdbc4.jar,以下版本的导入sqljdbc.jar,如果怕麻烦的,两个都导进去也行。
 
2.
包导完了,现在启动SQL配置器,SQL2000的默认端口是1433,所以只要开启端口就能连得上,但08的端口据说是动态的,具体的本人也不清楚,就是因为这个端口我也被整了2天,最后终于连上了
 
打开配置器:
        【原创】JDBC连接SQL Server2008 R2 - Seans Bolg - sean_zwx的博客
IP ALLTCP动态端口(默认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
 
谢谢!有哪里不正确的地方,去哪个读者指出,互相学习!!

 

 

 

 

 

 

 

 

 

 

 

 


windows7SQL Server 2005 JDBC的连接若干问题

一、Window7SQL Server Management Studio windows集成不能登陆;

首先我们应该在SQL Server Management Studio 上右击选择以管理员身份运行一般即可解决。

二、当sql2005 windows集成验证时,在Myeclipse或者Eclipse中用JDBC数据库连接被拒问题;

JDBC连接只需要下载一个驱动,完后在eclipse里配置一下JRE就可以使用了; (1)关闭防火墙。

(2)配置TCP端口:开始->所有程序->Microsoft SQL Server 2005->配置工具->SQLServer配置管理器->SQL Server 2005 网络配置->MSSQLSERVER协议;启用“TCP/IP”;双击“TCP/IP”->“IP 地址”->“IPAll”->“TCP 端口项添加默认的“1433”

(3)外围应用配置:Microsoft SQL Server 2005->配置工具->SQL Server外围应用配置器->服务和连接的外围应用配置器-> ①SQLEXPRESS->Database Engine->远程连接->本地连接和远程连接->同时使用TCP/IPnamed pipesSQL Server Browser->服务->启动类型改为自动”->应用->启动->确定。

(4)修改默认的登录验证模式(由于在安装过程中是默认按“Windows 身份验证模式方式安装,所以sa登录是被禁用的,即使将身份验证模式更改为“SQL Server Windows 身份验证模式sa登录仍处于禁用状态,所以需要启用sa登录帐户)

SQL Server Management Studio 的对象资源管理器中,安全性->登录名->右击“sa”->属性->常规->将登录名sa的密码和确认密码设为强密码->状态->登录->启用->确定;

SQL Server Management Studio 的对象资源管理器中,右击服务器->属性->安全性->服务器身份验证->选择“SQL ServerWindows身份验证模式”->确定->确定。

(我自己设置完四步就能连接到数据库2005

(5)SQL Server Management Studio Express中新建一个数据库(例如“ShopSystem”,如果测试程序带有数据库文件也可不用新建而直接附加到当前SQL Server数据库服务器);在SQLServer Management Studio 的对象资源管理器中右击服务器->重新启动->是。

(6)运行下载的JDBC文件“sqljdbc_1.2.2828.100_chs.exe”,解压到“C:\Program Files”文件夹中;将Classpath设置为包含sqljdbc.jar文件(也可加到系统环境变量中):在任务栏右下角右击“Apache Tomcat”图标(如果没有些图标,可先开始->所有程序->Apache Tomcat 5.0->MonitorTomcat”)->Configure...->Java->“JavaClasspath:”项的后面新增“;C:\Program Files\Microsoft SQLServer 2005 JDBC Driver\sqljdbc_1.2\chs\sqljdbc.jar”,然后“StopService->Start Service”重启Tomcat

(7)将测试程序复制到计算机硬盘上的Tomcat安装目录下的“webapps/ROOT”文件夹下,并去掉所有文件的只读属性;用文本编辑器修改测试程序中sa的密码等:

Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver");

StringstrConn="jdbc:sqlserver://localhost:1433;DatabaseName=ShopSystem";

String strUser="sa"; String strPassword="sasasa";

conn=DriverManager.getConnection(strConn,strUser,strPassword);

注意前面两行与SQL Server 2000是不一样的,密码必须与(4)中设置的相同。

sql2000中数据库连接测试代码:

try{

String driverClass ="com.microsoft.sqlserver.jdbc.SQLServerDriver";
String url ="jdbc:microsoft
sqlserver://127.0.0.1:1433;DatabaseName=yf";yf--数据库名称)

Class.forName(driverClass);
Connection conn = DriverManager.getConnection(url,"sa","");


Statement stmt = conn.createStatement();
ResultSet rs = stmt.executeQuery("select * from userInf");
while(rs.next())
{
out.println("
用户名:"+rs.getString(1)+"密码:"+rs.getString(2));
}
rs.close();
stmt.close();
conn.close();
}
catch(Exception e)
{
e.printStackTrace();
}

 

你可能感兴趣的:(jdbc)