java mysql where_java – 如何在JDBC中使用WHERE EXISTS函数

在过去的6-7个小时里,我一直在搜索/谷歌搜索/试验解决方案,但到目前为止还没有结果.

我有一个SQL字符串(下面),它在PHPMYADMIN中完美地工作,但在我的java执行中不起作用.在尝试执行查询时,我得到“找不到列”.

的SQLException:

java.sql.SQLException: Column 'rid' not found.

at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:1078)

at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:989)

at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:975)

at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:920)

at com.mysql.jdbc.ResultSetImpl.findColumn(ResultSetImpl.java:1167)

at com.mysql.jdbc.ResultSetImpl.getInt(ResultSetImpl.java:2851)

at net.matthewauld.racetrack.server.WrSQL.getJSONClassSpecificRiders(WrSQL.java:41)

at net.matthewauld.racetrack.server.ClientListener.parseCommand(ClientListener.java:110)

at net.matthewauld.racetrack.server.ClientListener.run(ClientListener.java:42)

SELECT * FROM `riders` WHERE EXISTS(SELECT * FROM `ridersclasses` WHERE ridersclasses.rid = riders.id AND `cid` = '6') ORDER BY `first_name` ASC

这是我执行SQL查询的java代码.

url = "jdbc:mysql://127.0.0.1:3306/racetrack2013?allowMultiQueries=true";

con = DriverManager.getConnection(url, user, password);

st = con.createStatement();

rs = st.executeQuery(query);

下面我将发布两个表的结构和一些数据示例:

RidersClasses

+---------------------------------------------------+

| ridersclasses |

+---------------------------------------------------+

| ID | RID | CID | BIKENUMBER | BIKEMODEL |

+---------------------------------------------------+

车手

+----------------------------------------------------------------------------------+

| Riders |

+----------------------------------------------------------------------------------+

| ID | first_name | last_name | address | city_id | h_phone | c_phone |

+----------------------------------------------------------------------------------+

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值