当前位置: 首页 > news >正文

成都建设网站那家好苏州网上挂号预约平台12320

成都建设网站那家好,苏州网上挂号预约平台12320,龙口网站制作公司,如何评价一个网站做的是否好在 Java 数据库编程中,Statement 是用于执行 SQL 语句的接口,允许程序与数据库进行交互。本文将详细介绍 Statement 的基本概念、常见用法以及 PreparedStatement 和 CallableStatement 等相关接口。 1. Statement 基本介绍 Statement 接口继承了 AutoC…

在 Java 数据库编程中,Statement 是用于执行 SQL 语句的接口,允许程序与数据库进行交互。本文将详细介绍 Statement 的基本概念、常见用法以及 PreparedStatementCallableStatement 等相关接口。

1. Statement 基本介绍

Statement 接口继承了 AutoCloseableWrapper 接口,使其具备自动关闭和封装功能。

  • AutoCloseable:提供 close() 方法,确保 Statement 在不再使用时释放资源。

  • Wrapper:提供 isWrapperFor(Class<?>)unwrap(Class<T>) 方法,允许 Statement 作为其他数据库 API 的封装。

        此外,Statement 还包含多个重要属性,如 cursorNamepoolableconnection 等。

Statement 是 JDBC 提供的用于执行 SQL 语句的接口,主要特点如下:

  1. 适用于执行静态 SQL 语句,每次执行都需要编译。

  2. 通过 executeQuery() 执行查询语句,返回 ResultSet

  3. 通过 executeUpdate() 执行更新语句,返回影响的行数。

  4. 存在 SQL 注入风险,建议使用 PreparedStatement 代替。

2. Statement 的基本用法

package JDBC;import java.io.FileInputStream;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement;
import java.util.Properties;
import java.util.Scanner;//JDBC注入机制演示public class Statement_ {public static void main(String[] args) throws Exception {//        Class.forName("com.mysql.jdbc.Driver");Scanner scanner = new Scanner(System.in);System.out.println("Enter SQL nameusr statement");String username =scanner.nextLine();System.out.println("Enter SQL pwd statement");String pwd =scanner.nextLine();Properties properties = new Properties();properties.load(new FileInputStream("src\\JDBC\\mysql.properties"));String url = (String) properties.get("url");String user =(String) properties.get("user");String password =(String) properties.get("password");String driver =(String) properties.get("driver");
//        实例化Class.forName(driver);Connection connection = DriverManager.getConnection(url, user, password);//        得到statementStatement statement = connection.createStatement();//        组织查询语句String sql = "select * from sql_injection where NAME='"+username+"'and  pwd = '"+pwd+"';" ;System.out.printf(sql+"\n");ResultSet resultSet = statement.executeQuery(sql);if (resultSet.next()) {System.out.println("查询成功");}else {System.out.println("查询失败");}//        关闭连接,安全操作resultSet.close();statement.close();connection.close();}
}

 2.1 主要方法

  • execute(String sql): 执行 SQL 语句,返回 boolean,如果执行的是查询语句,返回 true,否则返回 false

  • executeQuery(String sql): 仅用于 SELECT 语句,返回 ResultSet

  • executeUpdate(String sql): 仅用于 INSERTUPDATEDELETE 语句,返回受影响的行数。

  • addBatch(String sql): 添加 SQL 语句到批处理命令中。

  • executeBatch(): 执行批处理命令,返回每条 SQL 语句影响的行数。

  • clearBatch(): 清除已添加的批处理命令。

  • setQueryTimeout(int seconds): 设置查询超时时间。

  • getMoreResults(): 检查是否存在多个 ResultSet

  • close(): 关闭 Statement,释放资源。

2.2 执行更新操作

可以使用 executeUpdate() 进行 INSERTUPDATEDELETE 操作,例如:

Statement stmt = conn.createStatement();
int rowsAffected = stmt.executeUpdate("UPDATE users SET age = 30 WHERE id = 1");
System.out.println("更新影响的行数: " + rowsAffected);

3. Statement 的问题与优化

3.1 SQL 注入风险

使用 Statement 直接拼接 SQL 语句可能会导致 SQL 注入攻击,例如:

USE mydatabase;
SHOW DATABASES;SHOW TABLES;
CREATE TABLE sql_injection  ( -- 管理表NAME VARCHAR(32) NOT NULL UNIQUE,pwd VARCHAR(32) NOT NULL DEFAULT ''
)CHARACTER SET utf8;DROP TABLE sql_injection;
DESC sql_injection;INSERT INTO sql_injection VALUES( 'wangya' ,'1314520'
);SELECT * FROM sql_injection;SELECT *  FROM  sql_injectionWHERE NAME='wangya' AND pwd='1314520';-- sql 注入演示
-- 用户输入密码为: 1' or
-- 输入密码为:or '1'= '1
SELECT *  FROM  sql_injectionWHERE NAME='1' OR' or AND pwd='OR '1'= '1';SELECT *  FROM  sql_injectionWHERE NAME='wangya' OR pwd='1314520'  OR '1'='1' ;

以上代码可能被攻击者利用,绕过密码验证。

总结

Statement 是 Java 数据库操作的基本接口,但由于其存在 SQL 注入风险,在实际开发中推荐使用 PreparedStatement。此外,CallableStatement 适用于调用存储过程,提高数据库访问效率。了解并正确使用这些接口,可以提升数据库操作的安全性和性能。

http://www.dtcms.com/a/610598.html

相关文章:

  • 国外公共空间设计网站临沂网站关键字优化
  • 电子商务网站建设需要多少钱公司内部网站建设的意义
  • 前端开发案例(不定期更新)
  • AcWing 3595:二叉排序树 ← BST
  • Linux内核资源管理机制深度剖析:从IO端口申请到释放的完整生命周期
  • 网站主机是什么意思公网怎么做网站
  • 内存结构/运行时数据区
  • ls、cd等命令均无法使用的问题解决
  • c语言编译器教学 | 深入理解C语言编译器原理与使用技巧
  • 网站开发教案深圳网站建设公司大全
  • 怎么降低网站的跳出率设置wordpress数据库用户名
  • 对基因列表中批量的基因进行GO和KEGG注释
  • 关于网站建设项目创业计划书广告软文案例
  • 代备案网站新手建站论坛
  • 宝塔FTP的进阶应用——通过cpolar内网穿透实现远程文件协同管理
  • C# 中使用 Influxdb 1.x(三)
  • 【第1章·第4节】逻辑阵列操作与应用举例
  • 百度网站下拉排名网站线上运营
  • 西宁网站制作多少钱什么是电商行业
  • 蓝光3D扫描仪在汽车模具质量控制中的应用:提升金属与注塑模具的尺寸检测效率
  • 免费自建商城网站楼盘推荐排行榜
  • VCU上下电流程学习(二)
  • 课程网站建设的目的意义做自己的网站怎么赚钱
  • Ts基础(一)—— 类型
  • ASC学习笔记0010:效果被应用时的委托
  • 深圳深圳建设网站wordpress网盘主题
  • 北京齐力众信网站建设自己怎么制作网站
  • 想找一家公司设计网站wordpress链接设置方法
  • LeetCode 424 - 替换后的最长重复字符
  • 数据结构--9:反射、枚举以及lambda表达式(了解即可)