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天,最后终于连上了
打开配置器:
将IP ALL的TCP动态端口(默认1163)改为1433,不改也行,因为大部分人的习惯是用默认的1433,在IP2已启用选择——是,确定。
同样的方法,开启客户端的TCP/IP,端口也为1443,如图:
然后在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 运行结果:
打开SQL2008企业管理器
执行SQL语句
USE Mydb
GO
SELECT * FROM TABLE1
结果为:
说明已经成功连接SQL,并在数据库Mydb创建表TABLE1
谢谢!有哪里不正确的地方,去哪个读者指出,互相学习!!
windows7中SQL Server 2005 JDBC的连接若干问题
一、Window7中SQL 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/IP和named pipes;②选SQL Server Browser->服务->启动类型改为“自动”->应用->启动->确定。
(4)修改默认的登录验证模式(由于在安装过程中是默认按“Windows 身份验证模式”方式安装,所以sa登录是被禁用的,即使将身份验证模式更改为“SQL Server 和 Windows 身份验证模式”,sa登录仍处于禁用状态,所以需要启用sa登录帐户):
①在SQL Server Management Studio 的对象资源管理器中,安全性->登录名->右击“sa”->属性->常规->将登录名sa的密码和确认密码设为强密码->状态->登录->启用->确定;
②在SQL Server Management Studio 的对象资源管理器中,右击服务器->属性->安全性->服务器身份验证->选择“SQL Server和Windows身份验证模式”->确定->确定。
(我自己设置完四步就能连接到数据库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();
}