java连接sqlserver数据库教程,Java-进阶:多线程1

sec.setDaemon(true);
thr.setDaemon(true);
//启动
sec.start();
thr.start();
//之后发现sec和thr是守护线程,就会中断

  • 中断线程public void interrupt():让一个线程控制另外一个线程(有条件的:受阻),可以利用该方法终止另一个线程的运行

1. 如果线程在调用 Object 类的 wait()、wait(long) 或 wait(long, int) 方法,或者该类的 join()、join(long)、join(long, int)、sleep(long) 或 sleep(long, int) 等阻塞方法处于阻塞状态,它还将收到一个 InterruptedException
2. 中断一个不处于活动状态的线程不需要任何作用。 
中断一个不处于阻塞状态的线程,没有其他任何效果

public class Test {
public static void main(String[] args) {
FiveThread fiveThread = new FiveThread();
fiveThread.start();
//在主线程中,终止fiveThread,休眠状态
fiveThread.interrupt();
}
}

// 睡5秒之后,再让该线程输出一句话
class FiveThread extends Thread{
@Override
public void run() {
try {
//假如申请了很多的系统资源
TimeUnit.SECONDS.sleep(5);
System.out.println(“FiveThread 睡醒了”);
} catch (InterruptedException e) {
e.printStackTrace();
//异常的意义:即使我的线程被异常终止,我也可以保证资源的正常释放
}
}
}

//会抛出 java.lang.InterruptedException: sleep interrupted

4. JAVA程序的运行原理

  • Java命令会启动 JVM,即启动了一个进程,该进程会启动一个主线程,然后主线程调用某个类的 main方法,所以 main方法 都是运行在主线程里
  • jvm 启动后,必然有一个执行路径(线程)从 main方法开始的,一直执行到 main方法结束,这个线程在Java中称之为主线程
  • 当程序的主线程执行时,如果遇到了循环而导致程序在指定位置停留时间过长,则无法马上执行下面的程序,需要等待循环结束后能够执行
  • 方法在哪个线程中被调用,它就运行在哪个线程中
  • JVM 是一个多线程程序,每个Java 进程都分配一个 JVM 实例

public class ThreadDemo {
public static void main(String[] args) {
//利用垃圾回收器来证明
while(true) {
//这里虽然一直在堆空间中,创建数组对象,
// 但是始终没有耗尽堆空间,就是因为垃圾回收器,
// 在另外一个线程中,帮我们回收垃圾,所以才不会耗尽heap内存
// 从而证明,jvm是线程的
int[] ints = new int[1024];
ints = null;
}
}
}


二、Thread 类

1. 概述

  • Thread是程序中的执行线程。Java 虚拟机允许应用程序并发地
  • 25
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Java连接SQL Server数据库教程如下: 1. 下载并安装SQL Server JDBC驱动程序。 2. 在Java代码中导入SQL Server JDBC驱动程序。 3. 使用Java代码创建一个连接对象,指定连接字符串、用户名和密码。 4. 使用连接对象创建一个Statement对象,用于执行SQL语句。 5. 使用Statement对象执行SQL语句,例如查询数据或插入数据。 6. 处理查询结果或插入结果。 7. 关闭Statement对象和连接对象。 具体的代码实现可以参考以下示例: ``` import java.sql.*; public class SQLServerConnection { public static void main(String[] args) { try { // 加载SQL Server JDBC驱动程序 Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver"); // 创建连接字符串 String url = "jdbc:sqlserver://localhost:1433;databaseName=mydatabase"; // 创建连接对象 Connection conn = DriverManager.getConnection(url, "username", "password"); // 创建Statement对象 Statement stmt = conn.createStatement(); // 执行SQL语句 ResultSet rs = stmt.executeQuery("SELECT * FROM mytable"); // 处理查询结果 while (rs.next()) { String name = rs.getString("name"); int age = rs.getInt("age"); System.out.println("Name: " + name + ", Age: " + age); } // 关闭ResultSet对象、Statement对象和Connection对象 rs.close(); stmt.close(); conn.close(); } catch (Exception e) { e.printStackTrace(); } } } ``` 其中,url变量指定了连接字符串,包括SQL Server的主机名、端口号和数据库名称。conn变量是连接对象,stmt变量是Statement对象,rs变量是查询结果集。在处理查询结果时,可以使用ResultSet对象的getXXX()方法获取每一列的值。最后,需要关闭ResultSet对象、Statement对象和Connection对象,以释放资源。 ### 回答2: 在Java连接SQL Server数据库,一般使用JDBC API行操作。下面是连接SQL Server数据库的步骤。 1. 导入数据库驱动 首先要将SQL Server的驱动程序导入到项目中,可以从官网下载或从maven仓库中获取。下载后将jar包导入到项目的lib目录下,或者将其添加到项目的类路径中。 2. 加载驱动程序 使用Class.forName()方法加载SQL Server的驱动程序。将其放入try-catch块中以捕获异常。 3. 创建数据库连接 使用DriverManager.getConnection(url, username, password)方法创建数据库连接,其中url为数据库连接字符串,username和password为登录数据库的用户名和密码。具体连接字符串可以参考SQL Server的官方文档给出的示例。 4. 创建Statement对象 创建Statement对象,可以执行SQL语句并返回查询结果。 5. 执行SQL操作 执行SQL操作,可以使用Statement的executeQuery()方法执行查询操作,使用executeUpdate()方法执行更新操作。如果需要执行带有参数的SQL语句,则可以使用PreparedStatement。 6. 关闭资源 最后要记得关闭数据库连接、Statement对象等资源,以及捕获异常并行处理。 示例代码: ``` // 导入数据库驱动 import com.microsoft.sqlserver.jdbc.SQLServerDriver; // 加载驱动程序 Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver"); // 创建数据库连接 String url = "jdbc:sqlserver://localhost:1433;DatabaseName=testdb"; String username = "sa"; String password = "123456"; Connection conn = DriverManager.getConnection(url, username, password); // 创建Statement对象 Statement stmt = conn.createStatement(); // 执行SQL查询语句 String sql = "select * from users"; ResultSet rs = stmt.executeQuery(sql); // 输出查询结果 while (rs.next()) { System.out.println(rs.getInt("id") + "\t" + rs.getString("name")); } // 关闭资源 rs.close(); stmt.close(); conn.close(); ``` 以上是连接SQL Server数据库教程,希望能对Java开发者有所帮助。 ### 回答3: Java是目前世界上应用最广泛的计算机编程语言,而SQL Server又是一个很常用的关系型数据库系统。在实际工作或学习中,我们经常需要通过Java连接SQL Server数据库行数据的增删改查等操作。本文将介绍Java连接SQL Server数据库教程Java连接SQL Server数据库需要通过JDBC驱动程序来实现。Microsoft SQL Server JDBC驱动程序可以通过Microsoft官网下载。下载完成之后,需要将JDBC驱动程序的jar包文件添加到项目的classpath中。 首先,需要在Java代码中引入java.sql包和javax.sql包。然后,需要初始化JDBC驱动程序。可以通过以下方式来加载数据库驱动程序: ```java try { Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver"); } catch (ClassNotFoundException e) { e.printStackTrace(); } ``` 这里使用了Java的反射机制来动态加载驱动程序。其中,com.microsoft.sqlserver.jdbc.SQLServerDriver是SQL Server JDBC驱动程序的完整类名。 接下来,需要获取数据库连接对象。可以通过以下方式来获取数据库连接对象: ```java String url = "jdbc:sqlserver://localhost:1433;DatabaseName=mydatabase"; String username = "myusername"; String password = "mypassword"; Connection conn = DriverManager.getConnection(url, username, password); ``` 这里的url、username和password分别表示连接数据库的URL、用户名和密码。127.0.0.1表示本机IP,mydatabase表示要连接数据库名称,myusername和mypassword分别表示数据库登录用户名和密码。 获取到数据库连接对象之后,就可以通过该对象来行SQL语句的执行和结果集的处理。例如,可以通过以下方式来查询数据表中的数据: ```java Statement stmt = conn.createStatement(); String sql = "SELECT * FROM mytable"; ResultSet rs = stmt.executeQuery(sql); while(rs.next()) { String column1 = rs.getString("column1"); int column2 = rs.getInt("column2"); // do something with column1 and column2 } ``` 这里使用Statement对象来执行SQL语句,使用ResultSet对象来处理查询结果集。通过ResultSet对象的next()方法可以逐行获取查询结果。getString()和getInt()方法则可以根据列名称或索引来获取具体的列值。 除了查询,Java连接SQL Server数据库还可以行插入、删除和更新等操作。例如,可以通过以下方式来插入数据: ```java String sql = "INSERT INTO mytable (column1, column2) VALUES ('value1', 2)"; Statement stmt = conn.createStatement(); int rows = stmt.executeUpdate(sql); ``` 这里使用Statement对象的executeUpdate()方法来执行SQL语句。同样,可以使用该方法来行删除和更新操作。 最后,需要注意的是,在使用完连接对象之后,必须及时关闭连接,以释放数据库资源。可以通过以下方式来关闭连接: ```java if (conn != null) { try { conn.close(); // 关闭连接 } catch (SQLException e) { e.printStackTrace(); } } ``` 以上就是Java连接SQL Server数据库的基本教程。掌握了这些基本的语法和用法,就可以在Java中轻松实现对SQL Server数据库的增删改查等各种操作了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值