jdbc连接sql server报错

jdbc连接sql server报错:通过端口 1433 连接到主机 localhost 的 TCP/IP 连接失败。错误:“Connection refused: connect。请验证连接属性,并检查 SQL Server 的实例正在主机上运行,且在此端口接受 TCP/IP 连接,还要确保防火墙没有阻止到此端口的 TCP 连接。”。
import java.sql.*;

public class CDB {

static String t;
 static int p;
 static String url="jdbc:sqlserver://localhost:1433;DatabaseName=Test";
 static String user="sa";
 static String password="1029384756..";

public String getText() {
	return t;
}

public void setText(String t) {
	this.t = t;
}

public int getPassword() {
	return p;
}

public void setPassword(int p) {
	this.p = p;
}

public CDB(String t,int p) {
	this.setText(t);
	this.setPassword(p);

}


public void dataDecide()  {
if(dataCheck(t,p) ){
	new Later("登录数据库成功");
	}
	else {
		      UI ui=new UI();

		}
}




public boolean dataCheck(String t1,int p1) {
	
	 ResultSet rs = null;
   Connection conn=null;
	PreparedStatement statement=null;
	
	 boolean fire=true;
	try {
	Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver");
     conn=DriverManager.getConnection(url, user, password);
    
  String sql="select * from login where user=?  or   password=? ";
    statement = conn.prepareStatement(sql);
    statement.setString(1, t1);
    statement.setInt(2, p1);
     rs = statement.executeQuery();
      if(rs.next()) {
     	 fire=true;
      }else {
     	 fire=false;
      }
     
}catch(Exception e) {
	e.printStackTrace();
		
}
		finally {
	try {
		rs.close();
		statement.close();
		conn.close();
	}catch (Exception e1) {
		e1.printStackTrace();
	}
}

	return fire;
}  

public void insert(String t, int p) {

try {
Connection conn=null;
PreparedStatement statement=null;

 Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver");
 
 
  conn=DriverManager.getConnection(url, user, password);
 String sql="insert into login([user] ,password) values(?,?) ";
 statement = conn.prepareStatement(sql);
 statement.setString(1, t);
 statement.setInt(2, p);
 int cnt=statement.executeUpdate();
 
 
	String message=cnt>0?"注册成功":"注册不成功";
	System.out.println(message);
 new Later(message);

}catch(SQLException e) {
e.printStackTrace();
}catch (ClassNotFoundException e) {

e.printStackTrace();

}

}


}	

今天做了一个sql server 的jdbc连接,竟然报错了后来百度找到原来是sql server的默认协议没有打开
打开计算机在服务里
打开配置器

看看TCP/IP是不是启动,没有启动点击启动


然后右击“TCP/IP”选择“属性”(或双击“TCP/IP”),选择“IP地址”选项卡,最下面有个“IPALL”:看看端口是否是1433,如果不是就改为1433,点击确认 
后来运行果然连接数据库成功。

还有的就是PreparedStatement的setXxx(int index,Object val)设置占位符的值,其中index的值从1开始

执行SQl语句:excuteQuery()或者excuteUpdate()就可以完成查询或者数据的更新.【注意】:此时函数的参数位置不需要传入SQL语句,注意同使用Statement的update函数的差别需要带参数。



1.创建 Statement 对象

建立了到特定数据库的连接之后,就可用该连接发送 SQL 语句。Statement 对象用 Connection 的方法 createStatement 创建,如下列代码段中所示:

Connection con = DriverManager.getConnection(url, user,password);
Statement stmt = con.createStatement();

为了执行 Statement 对象,被发送到数据库的 SQL 语句将被作为参数提供给 Statement 的方法:

ResultSet rs = stmt.executeQuery("SELECT a, b, c FROM Table2");

2、使用 Statement 对象执行语句

Statement 接口提供了三种执行 SQL 语句的方法:executeQuery、executeUpdate 和 execute。使用哪一个方法由 SQL 语句所产生的内容决定。

方法 executeQuery 用于产生单个结果集的语句,例如 SELECT 语句。

方法 executeUpdate 用于执行 INSERT、UPDATE 或 DELETE 语句以及 SQL DDL(数据定义语言)语句,例如 CREATE TABLE 和 DROP TABLE。INSERT、UPDATE 或 DELETE 语句的效果是修改表中零行或多行中的一列或多列。executeUpdate 的返回值是一个整数,指示受影响的行数(即更新计数)。对于 CREATE TABLE 或 DROP TABLE 等不操作行的语句,executeUpdate 的返回值总为零。

方法 execute 用于执行返回多个结果集、多个更新计数或二者组合的语句。因为多数程序员不会需要该高级功能,所以本概述后面将在单独一节中对其进行介绍。

执行语句的所有方法都将关闭所调用的 Statement 对象的当前打开结果集(如果存在)。这意味着在重新执行 Statement 对象之前,需要完成对当前 ResultSet 对象的处理。

应注意,继承了 Statement 接口中所有方法的 PreparedStatement 接口都有自己的 executeQuery、executeUpdate 和 execute 方法。Statement 对象本身不包含 SQL 语句,因而必须给 Statement.execute 方法提供 SQL 语句作为参数。PreparedStatement 对象并 不将 SQL 语句作为参数提供给这些方法,因为它们已经包含预编译 SQL 语句。CallableStatement 对象继承这些方法的 PreparedStatement 形式。对于这些方法的 PreparedStatement 或 CallableStatement 版本,使用查询参数将抛出 SQLException。

3、语句完成

当连接处于自动提交模式时,其中所执 行的语句在完成时将自动提交或还原。语句在已执行且所有结果返回时,即认为已完成。对于返回一个结果集的 executeQuery 方法,在检索完 ResultSet 对象的所有行时该语句完成。对于方法 executeUpdate,当它执行时语句即完成。但在少数调用方法 execute 的情况中,在检索所有结果集或它生成的更新计数之后语句才完成。
statement-相关概述
Statement 对象用于将 SQL 语句发送到数据库中。实际上有三种 Statement 对象,它们都作为在给定连接上执行 SQL 语句的包容器:Statement、PreparedStatement(它从 Statement 继承而来)和 CallableStatement(它从 PreparedStatement 继承而来)。它们都专用于发送特定类型的 SQL 语句: Statement 对象用于执行不带参数的简单 SQL 语句;PreparedStatement 对象用于执行带或不带 IN 参数的预编译 SQL 语句;CallableStatement 对象用于执行对数据库已存储过程的调用。


Statement 接口提供了执行语句和获取结果的基本方法。PreparedStatement 接口添加了处理 IN 参数的方法;而 CallableStatement 添加了处理 OUT 参数的方法。

有些 DBMS 将已存储过程中的每条语句视为独立的语句;而另外一些则将整个过程视为一个复合语句。在启用自动提交时,这种差别就变得非常重要,因为它影响什么时候调用 commit 方法。在前一种情况中,每条语句单独提交;在后一种情况中,所有语句同时提交。

4、关闭 Statement 对象

Statement 对象将由 Java 垃圾收集程序自动关闭。而作为一种好的编程风格,应在不需要 Statement 对象时显式地关闭它们。这将立即释放 DBMS 资源,有助于避免潜在的内存问题。


你可能感兴趣的:(数据库,sqlserver,jdbc的连接出错)