jdbc执行sql的两种方式

package csdn1;

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

import org.junit.Test;

public class jdbc3 {
	// 执行sql,一种是Statement,一种是PrepareStatemnt
	/*
	 * 1.PrepareStatement 使用参数设置,可读性好,不易犯错(防止sql注入)
	 * 与创建Statement不同的是,需要根据sql语句创建PrepareStatement
	 * (通过设置参数,指定相应的值,而不是像Statement那样使用字符串拼接)
	 * 
	 * 2.PrepareStatement有预编译机制,性能比Statement更快
	 * 对于执行多次同一条sql语句,Statement执行需要多次把sql语句传给数据库端,数据库进行多次编译处理。
	 * 但PrepareStatement只需传一次sql语句给数据库端,数据库对?的sql进行预编译,
	 * 每次执行,只需传输参数到数据库端,1.网络传输量减小、2数据库不需要再进行编译,响应快。
	 * 
	 * 但不同sql语句需要创建多个对象
	 */

	@Test
	public void problem() {
		// sql注入问题:
		// 这里由于where后面的条件为永真,导致所有数据都被查询出来,这对于海量数据来说将会极耗内存,导致响应变慢

		jdbc3 j = new jdbc3();
		try (Connection c = j.getConnection();) {

			String name = "zl' or '1=1";// 假设这是用户的输入,虽然这种可能性小,但确实是个问题
			String sql = "select * from user where name = '" + name + "';";
			Statement cs = c.createStatement();
			ResultSet set1 = cs.executeQuery(sql);
			while (set1.next()) {
				System.out.println(set1.getString(3));
			}

			System.out.println("------------------------");

			sql = "select * from user where name = ?";
			PreparedStatement ps = c.prepareStatement(sql);
			ps.setString(1, name);
			ResultSet set2 = ps.executeQuery();
			while (set2.next()) {
				System.out.println(set2.getString(3));
			}
		} catch (SQLException e) {
			e.printStackTrace();
		}
	}

	// prepareStatement使用1
	@Test
	public void update() {
		String sql = "insert into user (name,password) values(?,?);";
		jdbc3 j = new jdbc3();
		Connection c = j.getConnection();

		try (PreparedStatement prepareStatement = c.prepareStatement(sql);) {
			// 参数设置
			prepareStatement.setString(1, "zl");
			prepareStatement.setString(2, "zl679");

			int num = prepareStatement.executeUpdate();
			System.out.println(num);
			// 补: 插入时,可获取当前的自增长id
			ResultSet keys = prepareStatement.getGeneratedKeys();// 也可以通过statement获取,效果一样
			while (keys.next()) {
				String str1 = keys.getString(1);
				String str2 = keys.getString("GENERATED_KEY");// 自增长id的名字
				System.out.println(str1 + " == " + str2);
			}
		} catch (SQLException e) {
			e.printStackTrace();
		}
	}

	// prepareStatement使用2
	@Test
	public void query() {
		String sql = "select count(*) from user;";
		jdbc3 j = new jdbc3();
		Connection c = j.getConnection();

		try (PreparedStatement prepareStatement = c.prepareStatement(sql);) {
			ResultSet set = prepareStatement.executeQuery();
			System.out.println(set);
			if (set.next()) {
				System.out.println(set.getString(1));
			}
		} catch (SQLException e) {
			e.printStackTrace();
		}
	}

	/**
	 * 获取连接
	 * 
	 * @return
	 */
	public Connection getConnection() {
		try {
			Class.forName("com.mysql.jdbc.Driver");
		} catch (ClassNotFoundException e) {
			e.printStackTrace();
		}

		String url = "jdbc:mysql://localhost:3306/mydbs2";
		Connection connection = null;
		try {
			connection = DriverManager.getConnection(url, "root", "root");
		} catch (SQLException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
		return connection;
	}
}
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JDBC(Java Database Connectivity, Java 数 据 库 连 接)是 一 种可用于执行 SQL 语句的 Java API(Application Programming Interface, 应用程序设计接口)。它由一些 Java 语言编写的类和接口组成。JDBC 为数据库应用开发人员、数据库前台开发人员提供了一种标准的应用程序设计接口, 使开发人员可以用纯 Java 语言编写完整的数据库应用程序。JDBC 通过调用其接口提供方法提供了 Java 应用程序与各种数据库服务器之间的连接服务, 它支持 ANSI SQL- 92 标准, 实现了从 Java 程序内调用标准的 SQL 命令对数据库进行查询、插入、删除和更新等操作, 并确保数据事务的正常进行。JDBC API 主要用来连接数据库并通过 SQL 语句操作数据库。它可以执行一般的 SQL 语句、动态 SQL 语句及带 IN 和 OUT参数的存储过程。通过使用 JDBC 简化了开发数据库应用的复杂度, 加快了开发速度。开发人员可以很方便地将 SQL 语句传送给几乎任何一种数据库。而且 JDBC 支持所有的操作系统, 使得 Java 应用程序不再需要为每个应用程序编写额外的驱动。2.JDBC 的体系结构JDBC 是实现 Java 应用程序与各种不同数据库对话的一种机制。JDBC 由两部分与数据库独立的 API 组成, 一部分是面向程序开发人员的 JDBC API, 另一部分是面向底层的 JDBC Driv-er API。JDBC 提供了一个通用的 JDBC Driver Manger, 用来管理各种数据库软件商提供JDBC 驱动程序, 从而访问其数据库。此外, 对没有提供相应 JDBC 驱动程序的数据库系统, 开发了特殊的驱动程序: JDBC- ODBC 桥, 该驱动程序支持 JDBC 通过现有的 ODBC 驱动程序访问其数据库系统。JDBC 的基本层次结构由 Java 程序、JDBC 驱动程序管理器、驱动程序和数据库四部分组成
### 回答1: 在 JDBC 中,可以使用 PreparedStatement 对象同时执行多条 SQL 查询语句。具体步骤如下: 1. 创建 PreparedStatement 对象。 2. 编写多条 SQL 查询语句,每条语句用分号(;)隔开,并将它们组合成一个字符串。 3. 使用 PreparedStatement 对象的 execute() 或 executeQuery() 方法执行查询语句。 4. 处理查询结果。 下面是一个示例代码: ```java // 假设我们要查询两个表的数据 String sql = "SELECT * FROM table1; SELECT * FROM table2;"; PreparedStatement ps = conn.prepareStatement(sql); boolean hasResult = ps.execute(); while (hasResult) { ResultSet rs = ps.getResultSet(); // 处理查询结果 while (rs.next()) { // 处理每一条记录 } hasResult = ps.getMoreResults(); } ``` 在上面的代码中,我们首先创建了一个 PreparedStatement 对象 ps,然后将两条 SQL 查询语句组合成一个字符串并赋值给 sql 变量。接着,我们使用 ps.execute() 方法执行查询语句,该方法返回一个 boolean 值,指示查询语句是否有结果集。如果有结果集,则使用 ps.getResultSet() 方法获取结果集,并使用 ResultSet 对象处理查询结果。最后,使用 ps.getMoreResults() 方法判断是否还有下一条查询语句,如果有,则继续处理下一条语句的结果集。 ### 回答2: JDBC的PreparedStatement是一种用于执行多条SQL查询语句的机制。它允许我们预先定义SQL语句并在执行提供参数值。 使用PreparedStatement可以避免SQL注入攻击,并且可以提高性能。 首先,我们需要创建一个PreparedStatement对象。这可以通过Connection对象的prepareStatement方法来完成。例如: PreparedStatement statement = connection.prepareStatement("SELECT * FROM students WHERE age > ?"); 在这个例子中,我们创建了一个PreparedStatement对象来执行查询年龄大于指定值的学生的SQL语句。 接下来,我们可以使用setXXX方法来设置参数值。XXX代表参数的数据类型。例如,如果我们要设置age参数的值为18,可以使用: statement.setInt(1, 18); 注意,参数的索引是从1开始的。 然后,我们可以使用executeQuery方法执行查询语句,并获取结果集: ResultSet resultSet = statement.executeQuery(); 最后,我们可以使用ResultSet对象来遍历查询结果并进行相应的操作。例如: while (resultSet.next()) { String name = resultSet.getString("name"); int age = resultSet.getInt("age"); // 进行操作 } 最后,我们需要关闭PreparedStatement对象和相关资源: resultSet.close(); statement.close(); 使用PreparedStatement可以有效地执行多条SQL查询语句,并且保护我们的应用程序免受SQL注入攻击。 ### 回答3: JDBC是Java数据库连接的标准API,用于连接和操作关系型数据库。在JDBC中,我们可以使用PreparedStatement执行多条SQL查询语句。 PreparedStatement是一种预编译的语句,它可以在执行之前进行编译和参数绑定,避免了SQL注入的风险,并且提高了数据库操作的性能。 首先,我们需要获取一个PreparedStatement对象,可以通过Connection的prepareStatement方法来创建。例如: ``` String sql = "SELECT * FROM table_name WHERE column_name = ?"; PreparedStatement statement = connection.prepareStatement(sql); ``` 在创建PreparedStatement对象之后,我们可以使用setXxx方法来设置参数,该方法的参数为SQL语句中的占位符的索引和对应的值。例如: ``` statement.setInt(1, 123); ``` 在设置完参数之后,我们可以使用executeQuery方法执行查询语句,并获取结果集。例如: ``` ResultSet resultSet = statement.executeQuery(); ``` 对于多条SQL查询语句,我们可以简单地使用多个PreparedStatement对象来执行。例如: ``` String sql1 = "SELECT * FROM table1 WHERE column1 = ?"; PreparedStatement statement1 = connection.prepareStatement(sql1); // 设置参数 ResultSet resultSet1 = statement1.executeQuery(); String sql2 = "SELECT * FROM table2 WHERE column2 = ?"; PreparedStatement statement2 = connection.prepareStatement(sql2); // 设置参数 ResultSet resultSet2 = statement2.executeQuery(); ``` 最后,我们可以通过遍历结果集来获取每一条查询语句的结果,进行进一步的处理和展示。 通过使用PreparedStatement,我们可以方便地执行多条SQL查询语句,并且保证了安全性和性能。希望这个回答能对您有所帮助。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值