中易网

一条SQL在plsql中执行没问题,用jdbc连接数据库执行就报无效的关系运算符怎么回事

答案:2  悬赏:80  
解决时间 2021-03-03 08:03
一条SQL在plsql中执行没问题,用jdbc连接数据库执行就报无效的关系运算符怎么回事
最佳答案
可能是某条查询语句,在不同数据库,返回的数据不一样导致的吧。

建议你把具体的报错信息及SQL语句贴出来看看。
全部回答
1、创建 statement 对象 建立了到特定数据库的连接之后,就可用该连接发送 sql 语句。statement 对象用 connection 的方法 createstatement 创建,如下列代码段中所示: connection con = drivermanager.getconnection(url, "sunny", ""); 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 对象用于将 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 资源,有助于避免潜在的内存问题。
我要举报
如以上问答内容为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
大家都在看
给老机子配个低端显卡 技嘉GT210 512M 蓝宝石
星星工作室地址有知道的么?有点事想过去
1楼 买了一张联通卡,因为我的手机好像不支持
掏宝怎么退货,卖家把地址改为了海外海外,求
重庆科技学院虎溪校区-冶金科技大楼怎么去啊
熊氏服饰在哪里啊,我有事要去这个地方
离婚证领了两个月,男方想要回彩礼钱,我要还他
老婆一直骂我、骂的我都快疯了、我该怎么办
OIT是什么意思?
百鲜果园襄阳江山北路店这个地址在什么地方,
初学者适合吸什么类型的雪茄
三菱V73发动以后发动机故障灯隐隐闪烁,起步
考研报班有用吗,听说政治得报个班比较好
现在的美国能打得过前苏联吗
精灵兔韩版童装地址在哪,我要去那里办事
推荐资讯
一物体匀速下落时,机械能怎么变化如题
诺基亚930怎样查MAC地址
以前都很少说粗口 然后突然爆粗骂一个以前玩
邻食港湾休闲食品新兴·骏景园店在哪里啊,我
奥迪A4l35tfsi发动机是混动的吗?
unity 3d js 比如a点是玩家的transform,如何
从浙江诸暨到浙江台州需要多少时间车费
碗碗香面皮地址在什么地方,想过去办事
未来之星幼儿园在什么地方啊,我要过去处理事
梦见无头巨龟
什么东西不是乐器,但是乐器的辅助品,放着的时
西安文理学院2013年学校及专业代码?大神们帮
手机登qq时,显示手机磁盘不足,清理后重新登
刺客的套装怎么选啊?