如何使用 JDBC 连接到 SQL Server 2008 数据库?

Posted

技术标签:

【中文标题】如何使用 JDBC 连接到 SQL Server 2008 数据库?【英文标题】:How do I connect to a SQL Server 2008 database using JDBC? 【发布时间】:2011-01-27 22:57:37 【问题描述】:

我在本地 PC 上安装了 MSSQL 2008,我的 Java 应用程序需要连接到 MSSQL 数据库。我是 MSSQL 的新手,我希望在为我的 Java 应用程序创建用户登录和通过 JDBC 获得连接方面获得一些帮助。到目前为止,我尝试为我的应用程序创建用户登录名并使用以下连接字符串,但我根本不工作。任何帮助和提示将不胜感激。

jdbc:jtds:sqlserver://127.0.0.1:1433/dotcms 
username="shuxer"  password="itarator"

【问题讨论】:

尝试使用Hibernate。如果您还没有听说过,现在是look at this tool 的好时机。广泛传播的对象关系映射 (ORM) 库。 请提供您尝试连接的代码,同时向我们提供您遇到的异常或错误 【参考方案1】:

试试这个。

导入 java.sql.Connection;

导入 java.sql.DriverManager;

导入 java.sql.ResultSet;

导入 java.sql.Statement;

公共类 SQLUtil

public void dbConnect(String db_connect_string,String db_userid, 字符串 db_password)

试试

     Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver");
     Connection conn = DriverManager.getConnection(db_connect_string,
              db_userid, db_password);
     System.out.println("connected");
     Statement statement = conn.createStatement();
     String queryString = "select * from cpl";
     ResultSet rs = statement.executeQuery(queryString);
     while (rs.next()) 
        System.out.println(rs.getString(1));
     
   catch (Exception e) 
     e.printStackTrace();
      

public static void main(String[] args)

SQLUtil connServer = new SQLUtil();

connServer.dbConnect("jdbc:sqlserver://192.168.10.97:1433;databaseName=myDB", “萨”, “0123”);

【讨论】:

【参考方案2】:

连接到 SQL Server 的简单 Java 程序。

注意:您需要将 sqljdbc.jar 添加到构建路径中

// localhost : 本地计算机充当服务器

// 1433 : SQL 默认端口号

// 用户名:sa

//密码:使用密码,安装SQL server management studio时使用,我这里是'root'

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;

    public class Conn 
        public static void main(String[] args) throws InstantiationException, IllegalAccessException, ClassNotFoundException 

            Connection conn=null;
            try 
                Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver").newInstance();
                conn = DriverManager.getConnection("jdbc:sqlserver://localhost:1433;databaseName=company", "sa", "root");

                if(conn!=null)
                    System.out.println("Database Successfully connected");

             catch (SQLException e) 
                e.printStackTrace();
            

        
    

【讨论】:

【参考方案3】:

你可以尝试配置SQL server:

    第 1 步:打开 SQL server 20xx 配置管理器 步骤 2:单击 SQL 服务器配置中的 Protocols for SQL..。然后,右键单击 TCP/IP,选择属性 步骤 3:单击选项卡 IP 地址,编辑所有 TCP。端口是 1433

注意:所有 TCP 端口都是 1433 最后,重启服务器。

【讨论】:

【参考方案4】:

使用JDBC主要有两种方式——使用Windows认证和SQL认证。 SQL 身份验证可能是最简单的。你可以做的是:

String userName = "username";
String password = "password";

String url = "jdbc:sqlserver://MYPC\\SQLEXPRESS;databaseName=MYDB";

Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver");
Connection conn = DriverManager.getConnection(url, userName, password);

将 sqljdbc4.jar 添加到构建路径之后。

对于 Window 身份验证,您可以执行以下操作:

String url = "jdbc:sqlserver://MYPC\\SQLEXPRESS;databaseName=MYDB;integratedSecurity=true";
Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver");
Connection conn = DriverManager.getConnection(url);

然后将 sqljdbc_auth.dll 的路径添加为 VM 参数(在构建路径中仍然需要 sqljdbc4.jar)。

如果您需要更多详细信息,请查看here 了解如何使用 jTDS 和 JDBC 从 Java 连接到 SQL Server 的简短分步指南。希望对您有所帮助!

【讨论】:

请注意jar文件应该放在类路径中【参考方案5】:

您可以使用this:

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement;

public class ConnectMSSQLServer

   public void dbConnect(String db_connect_string,
            String db_userid,
            String db_password)
   
      try 
         Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver");
         Connection conn = DriverManager.getConnection(db_connect_string,
                  db_userid, db_password);
         System.out.println("connected");
         Statement statement = conn.createStatement();
         String queryString = "select * from sysobjects where type='u'";
         ResultSet rs = statement.executeQuery(queryString);
         while (rs.next()) 
            System.out.println(rs.getString(1));
         
       catch (Exception e) 
         e.printStackTrace();
      
   

   public static void main(String[] args)
   
      ConnectMSSQLServer connServer = new ConnectMSSQLServer();
      connServer.dbConnect("jdbc:sqlserver://<hostname>", "<user>",
               "<password>");
   

【讨论】:

【参考方案6】:

我也在使用 mssql server 2008 和 jtds。在我的情况下,我使用以下连接字符串并且它可以工作。

Class.forName( "net.sourceforge.jtds.jdbc.Driver" );
Connection con = DriverManager.getConnection( "jdbc:jtds:sqlserver://<your server ip     
address>:1433/zacmpf", userName, password );
Statement stmt = con.createStatement();

【讨论】:

【参考方案7】:

如果您在连接时遇到问题,很可能是您尚未在端口 1433 上启用 TCP/IP 侦听器。快速的“netstat -an”命令会告诉您它是否正在侦听。默认情况下,SQL Server 安装后不会启用此功能。

此外,您需要在“sa”帐户上设置密码并启用“sa”帐户(如果您打算使用该帐户进行连接)。

显然,这也意味着您需要在您的 MSSQL 节点上启用“混合模式身份验证”。

【讨论】:

【参考方案8】:

尝试这样使用:jdbc:jtds:sqlserver://127.0.0.1/dotcms;实例=实例名称

不知道你用的是哪个版本的mssql,如果是express版,默认实例是sqlexpress

不要忘记检查 SQL Server Browser 服务是否正在运行。

【讨论】:

以上是关于如何使用 JDBC 连接到 SQL Server 2008 数据库?的主要内容,如果未能解决你的问题,请参考以下文章

如何使用库 jTDS JDBC 驱动程序将 android 应用程序连接到 sql server 2012

无法将 jdbc 连接到 sql server 2008 r2

无法使用 JDBC 在 android 中连接到 sql server 2008

连接到 SQL Server 实例 AWS Glue

使用 jdbc Java、Android 应用程序连接到 SQL Server 数据库

我无法使用带有 Android Studio 的 JDBC 连接到 SQL Server Express