java怎么连接sql server,需要注意的几点

时间:2021-07-31 17:42:33
一、JAVA连接SQL的语句 
 
JAVA连接SQL2000语句为: 
Class.forName("sun.jdbc.odbc.JdbcOdbcDriver"); 
DriverManager.getConnection("jdbc:odbc:数据库名","数据库登录名","登录密码"); 
 
但连接SQL2005,已经改为: 
Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver"); 
DriverManager.getConnection("jdbc:sqlserver://localhost:1433; DatabaseName=数据库名","数据库登录名","登录密码"); 
 
二、JAVA连接SQL都要用到驱动程序 
 
SQL2000需要三个jar包:mssqlservice.jar,msutil.jar,msbase.jar 
SQL2005需要一个jar包:sqljdbc.jar 
所以SQL2000和2005的连接方法是不一样的, 
到微软下载"Microsoft SQL Server 2005 JDBC Driver"最新版本,现在的应该是1.2 
 
下面Microsoft SQL Server 2005 JDBC Driver的安装说明: 
1. 将 sqljdbc_<版本>_enu.exe 下载 
2. 运行 sqljdbc_<版本>_enu.exe 
3. 出现提示时,输入安装目录;建议您将此 zip 文件解压缩到 %ProgramFiles% 中的默认目录下: 
Microsoft SQL Server 2005 JDBC Driver 
4.在环境变量*PATH后加上C:\Program Files\Microsoft SQL Server 2005 JDBC Driver\sqljdbc_1.2\enu\sqljdbc.jar(这是1.2版的,其它版本按实际修改......) 
 
但上面只解决了驱动程序的问题..... 
 
三、另外有时候会出现"SQL SERVER 2005使用sa 登录失败-提示该用户与可信 SQL Server 连接无关联"或除sa外的用户登录失败的问题. 
 
解决方法如下: 
 
1.打开SQL Server Management Studio 
2.右键点击服务器,选择Properties(属性),点击Security(安全性), 
将server authentication服务器身份认证从windows authentication mode(windows身份认证模式) 
修改为Sql Server and Windows Authentication mode(SQL server和windows身份认证模式). 
3.回到SQL Server Management Studio服务器那,在服务器下双击打开security(安全性) -- logins(登录名) ,右键选中sa,选择properties(属性),点击Status(状态),在设置中将Login(登录)设置为Enabled(启用)。(忘记sa密码的可在常规修改密码) 
 
四、设置SQL Server服务器 
1、打开SQL Server Configuration Manager”,双击“SQL Server 2005网络配置”,点击“MSSQLSERVER 的协议” 
2、如果“TCP/IP”没有启用,右键单击选择“启动”。 
3、双击“TCP/IP”进入属性设置,在“IP 地址”里,可以配置“IPAll”中的“TCP 端口”,默认为1433,将IP地址中的“已启用”设为“是”。 
4、重新启动SQL Server 
5、运行正常。
 
 
 
package pkg;
 
import java.sql.*;
 
public class Test {
    public static void main(String args[]) {
        String driverName = "com.microsoft.sqlserver.jdbc.SQLServerDriver"; // 加载JDBC驱动
        String dbURL = "jdbc:sqlserver://localhost:1433;integratedSecurity=true;DatabaseName=test"; // 连接服务器和数据库sample
        Connection dbConn;
        try {
            Class.forName(driverName);
            dbConn = DriverManager.getConnection(dbURL);
            System.out.println("Connection Successful!"); // 如果连接成功
                                                            // 控制台输出Connection
            // Successful!
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}