iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >PreparedStatement的setObject作用是什么
  • 435
分享到

PreparedStatement的setObject作用是什么

2023-07-05 18:07:34 435人浏览 泡泡鱼
摘要

这篇文章主要介绍了PreparedStatement的setObject作用是什么的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇PreparedStatement的setObject作用是什么文章都会有所收获,

这篇文章主要介绍了PreparedStatement的setObject作用是什么的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇PreparedStatement的setObject作用是什么文章都会有所收获,下面我们一起来看看吧。

    PreparedStatement的setObject作用

    在了解setObject作用前讲解一下PreparedStatement这个接口,然后循序渐进从setXxx()方法讲解到setObject。

    PreparedStatement

    java.sql包中的PreparedStatement接口继承了Statement接口,PreparedStatement对象可以防止sql注入,而Statement不能防止sql注入,所以实际开发的时候千万不要使用Statement。

    SQL注入:

    比如我的SQL语句为:

    select * from user where username =' zhangsan' username ' and passWord ='password ' ;

    其中传入的参数为:username(用户名) 和 password(密码)。

    恶意注入之前的含意是查询user表的所有字段,匹配条件是username和password跟数据表的某条数据完全匹配使得条件成立,换言之就是用户名和密码必须都为正确的才可以查询到数据。

    恶意注入方式一:输入 username: 随意 password: ’ or ‘1’='1

    select * from user where username ='xxxxx' and password ='xxx' or '1'='1';

    and 优先级 执行 高于 or

    恶意注入方式二、在SQL添加 – 是mysql的注释 用户名框:输入 zhangsan’ 空格–空格 password 随意输入即可

    select * from user where username ='zhangsan' -- ' and password ='' ;

    注意:以上的 zhangsan’ 空格–空格 中的zhangsan是数据库存在的

    setObject

    setObject就是给JDBC的SQL语句的占位符赋值的,即是下面的“?”

    预编译的SQL:参数使用?作为占位符

    注意:sql的参数使用?作为占位符。 如:

    select * from user where username = ? and password = ?;

    获取执行sql语句的对象 PreparedStatement Connection.prepareStatement(String sql)

    给?赋值:(Xxx代表参数类型)

    • 方法: setXxx(参数1,参数2)

    • 参数1:?的位置编号 从1 开始

    • 参数2:?的值

    例如:

    setString(1,"one")就是定义参数类型为String类型,然后给第一个?位置上赋值为one。

    select * from user where username = 'one' and password = ?;

    setInt(2,2)就是定义参数类型为Int类型,然后给第二个?的位置上赋值为2。

    select * from user where username = 'one' and password = 2;

    注意:setString定义为String类型就只能传String类型,也就是说定义什么类型就要传入什么类型。

    重点来了

    PreparedStatement的setObject的作用和setString的作用是一样的!

    setObject的第一个参数是?的位置编号,第二个参数是Object类型,因为所有的类型默认继承object,这个时候参数就没有类型限制,你可以传入String类型或者Int类型…不需要手动设置传参类型。

    例如:

    setObject(1,"one")就是给第一个?位置上赋值为String类型的"one"。

    select * from user where username = 'one' and password = ?;

    setObject(2,2)就是给第二个?的位置上赋值为Int类型的2。

    select * from user where username = 'one' and password = 2;

    JDBC关于PreparedStatement.setObject的一些细节

    JDBC中PreparedStatement.setObject(index,Object)方法,

    index从1开始

    在插入时间格式的字段时,此处的Object格式必须是java.sql.Date的对象

    oracle表中date格式可以表示年月日时分秒

    从表中取出对象封装到JavaBean对象中,字段类型可以直接为java.util.Date 

    关于“PreparedStatement的setObject作用是什么”这篇文章的内容就介绍到这里,感谢各位的阅读!相信大家对“PreparedStatement的setObject作用是什么”知识都有一定的了解,大家如果还想学习更多知识,欢迎关注编程网精选频道。

    --结束END--

    本文标题: PreparedStatement的setObject作用是什么

    本文链接: https://www.lsjlt.com/news/354365.html(转载时请注明来源链接)

    有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

    本篇文章演示代码以及资料文档资料下载

    下载Word文档到电脑,方便收藏和打印~

    下载Word文档
    猜你喜欢
    • PreparedStatement的setObject作用是什么
      这篇文章主要介绍了PreparedStatement的setObject作用是什么的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇PreparedStatement的setObject作用是什么文章都会有所收获,...
      99+
      2023-07-05
    • JDBC中的PreparedStatement是什么
      JDBC中的PreparedStatement是一种数据库预编译的SQL语句对象。它继承自Statement接口,用于执行带有参数的...
      99+
      2023-10-10
      JDBC
    • JDBC中的PreparedStatement是什么?
      PreparedStatement接口扩展了Statement接口,它代表一个可以多次执行的预编译SQL语句。它接受参数化 SQL 查询,并且您可以向此查询传递 0 个或多个参数。最初此语句使用占位符 “” 而不是参数,稍后您可以传递参数使...
      99+
      2023-10-22
    • JDBC的基本操作与Statement和PreparedStateMent使用区别是什么
      本文小编为大家详细介绍“JDBC的基本操作与Statement和PreparedStateMent使用区别是什么”,内容详细,步骤清晰,细节处理妥当,希望这篇“JDBC的基本操作与Statement和PreparedStateMent使用区...
      99+
      2023-07-05
    • redis的作用是什么
      这篇文章主要介绍了redis的作用是什么,具有一定借鉴价值,需要的朋友可以参考下。希望大家阅读完这篇文章后大有收获。下面让小编带着大家一起了解一下。Redis是开源免费的,用C语言编写的,遵循BSD协议,是...
      99+
      2024-04-02
    • navicat的作用是什么
      这篇文章给大家分享的是有关navicat的作用是什么的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。  Navicat是一套快速、可靠并价格相当便宜的数据库管理工具,专为简化数据库...
      99+
      2024-04-02
    • SELinux的作用是什么
      这篇文章主要介绍了SELinux的作用是什么的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇SELinux的作用是什么文章都会有所收获,下面我们一起来看看吧。 ...
      99+
      2023-02-13
      selinux
    • linux的作用是什么
      本文小编为大家详细介绍“linux的作用是什么”,内容详细,步骤清晰,细节处理妥当,希望这篇“linux的作用是什么”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。 ...
      99+
      2023-03-09
      linux
    • nodejs的作用是什么
      nodejs的作用是什么?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。1、nodejs简介node 是一个基于 V8 引擎的 Javascript 运行环境,它...
      99+
      2023-06-14
    • TorchServe的作用是什么
      TorchServe是一个用于部署和管理PyTorch模型的开源模型服务器框架。它提供了一个简单且高效的方式来将训练好的PyTorc...
      99+
      2024-04-02
    • gitee的作用是什么
      这篇“gitee的作用是什么”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“gitee的作用是什么”文章吧。一、Gitee的起...
      99+
      2023-07-05
    • webservice的作用是什么
      Webservice是一种可以在网络上进行交互的软件系统,通过使用标准化的协议和格式,使不同的应用程序能够互相通信和共享数据。它的作...
      99+
      2023-09-21
      webservice
    • jsp的作用是什么
      JSP(Java Server Pages)是一种用于开发动态Web应用程序的Java技术。主要作用是将Java代码嵌入到HTML页...
      99+
      2023-05-22
      jsp的作用 jsp
    • Promise.allSettled的作用是什么
      本篇内容介绍了“Promise.allSettled的作用是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所...
      99+
      2024-04-02
    • DOCTYPE的作用是什么
      这篇文章主要为大家展示了“DOCTYPE的作用是什么”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“DOCTYPE的作用是什么”这篇文章吧。 面试官:我们现在...
      99+
      2024-04-02
    • offsetwidth的作用是什么
      offsetWidth是一个DOM属性,用于获取一个元素的宽度,包括元素的内容、内边距和边框的宽度。具体作用如下:1. 获取元素的实...
      99+
      2023-09-11
      offsetwidth
    • stringstream的作用是什么
      stringstream是一个用于处理字符串的类,它允许将字符串作为流进行操作。它可以将字符串分解为各种类型的数据,并将其存储在对应...
      99+
      2023-09-15
      stringstream
    • Express的作用是什么
      这期内容当中小编将会给大家带来有关Express的作用是什么,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。1、express :一个轻量级的 Node Web 服务端框架,同样是一个人气超高的项...
      99+
      2023-06-14
    • Vue.use的作用是什么
      本篇内容介绍了“Vue.use的作用是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!在使用 Eleme...
      99+
      2024-04-02
    • HTML的作用是什么
      这篇文章主要介绍了HTML的作用是什么,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。   html是一个超文本标签语言,超文本意味着,它什...
      99+
      2024-04-02
    软考高级职称资格查询
    编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
    • 官方手机版

    • 微信公众号

    • 商务合作