PreparedStatement 和 null 的问题

狐狸大仙 2003-10-21 01:09:01
sql = "select * from abcd where ? ";
PreparedStatement pstmt = conn.prepareStatement(sql);
setString(1,"name is null");

这样为什么不行呀?
如果要实现该怎么做?

当然在必要的时候,还要求能够
setString(1,"name = " + name);
...全文
251 10 打赏 收藏 转发到动态 举报
写回复
用AI写文章
10 条回复
切换为时间正序
请发表友善的回复…
发表回复
狐狸大仙 2003-10-21
  • 打赏
  • 举报
回复
问题,还没有解决。
不过马上给分。
iamwls 2003-10-21
  • 打赏
  • 举报
回复
sql = "select * from abcd where name = ?,aaa = ? ";
PreparedStatement pstmt = conn.prepareStatement(sql);
ps.setString(1,"NameYourSearch"); or ps.setNull(1,Types.STRING);
ps.setString(2,"aaa"); or ps.setNull(1,Types.STRING);
liad 2003-10-21
  • 打赏
  • 举报
回复
Types.VARCHAR

???
狐狸大仙 2003-10-21
  • 打赏
  • 举报
回复
我没有看到STRING,只有CHAR
我数据库里的数据类型是 VARCHAR2(15)
那我这里第二个参数应该写什么呀?
qiangchen 2003-10-21
  • 打赏
  • 举报
回复
ChDw(米) 正确,第二个参数表示是string 类型的!值为 null 整句sql 意思为:select * from abcd where name is null
狐狸大仙 2003-10-21
  • 打赏
  • 举报
回复
我看了一下 Types. 里没有STRING ,但是有CHAR。
能否具体讲解一下 setNull 的第二个参数是什么意思?
clapton 2003-10-21
  • 打赏
  • 举报
回复
ChDw正解
pleonheart 2003-10-21
  • 打赏
  • 举报
回复
你的sql写的不对,where 后面的条件是什么呢?
select * from abcd where name=?
ChDw 2003-10-21
  • 打赏
  • 举报
回复
sql = "select * from abcd where name = ? ";
PreparedStatement pstmt = conn.prepareStatement(sql);
ps.setString(1,"NameYourSearch"); or ps.setNull(1,Types.STRING);
truezerg 2003-10-21
  • 打赏
  • 举报
回复
你写的是什么啊? 看不懂你的意思

62,612

社区成员

发帖
与我相关
我的任务
社区描述
Java 2 Standard Edition
社区管理员
  • Java SE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧