検索

ホームページ  >  に質問  >  本文

java - preparedStatement中怎么样传如 in(?)中的参数

如下面的例子:
?中是一个列表,如'1','2','3'.
替换后应该是 in ('1','2','3'),但是我把'1','2','3'传进取却不能正确的执行取得结果,跟踪发现参数被当初一个字符串了里面的引号被转义了,变成in (''1','2','3'') ,导致结果不对,请问像sql中 in (?),preparedStatement设置参数要怎么处理?

天蓬老师天蓬老师2782日前695

全員に返信(2)返信します

  • 巴扎黑

    巴扎黑2017-04-18 10:34:48

    Java の preparedStatement を再度確認しましたpreparedStatement

    应该这样处理:

    PreparedStatement statement = connection.prepareStatement("Select * from test where field in (?)");
    Array array = statement.getConnection().createArrayOf("VARCHAR", new Object[]{"A1", "B2","C3"});
    statement.setArray(1, array);
    ResultSet rs = statement.executeQuery();

    或者:

    in(?,?,?)

    次のように処理する必要があります:🎜 リーリー 🎜または: 🎜 🎜in(?,?,?)次に複数回代入します🎜

    返事
    0
  • 高洛峰

    高洛峰2017-04-18 10:34:48

    http://fish198398.iteye.com/b...

    返事
    0
  • キャンセル返事