pryjava 2008-10-15 16:27
浏览 904
已采纳

PreparedStatement中in语句的用法

请问哪位大虾用过PreparedStatement,SQL语句里包含in(?) 这个里面我要放多个数据,比如: in('first','second','third'),要怎么为参数设置值啊?

  • 写回答

2条回答 默认 最新

  • hunterli0408 2008-10-15 17:53
    关注

    Connection con = null;
    PreparedStatement pstmt = null;
    ResultSet rs = null;
    try {
    Class.forName("com.mysql.jdbc.Driver");
    con = DriverManager.getConnection(
    "jdbc:mysql://127.0.0.1:3306/firefly", "root", "200493128");

        //创建参数列表
    List<String> list = new ArrayList<String>();
    list.add("U1");
    list.add("U2");
    list.add("U3");
    
        //根据参数列表的大小生成in串
    StringBuffer buffer = new StringBuffer();
    for (int i = 0; i < list.size(); i++) {
        buffer.append("?, ");
    }
    buffer.deleteCharAt(buffer.length() - 1);
    buffer.deleteCharAt(buffer.length() - 1);
    
    pstmt = con.prepareStatement("select * from logon where id in ("
            + buffer.toString() + ")");
    
        //根据参数列表设置sql参数
    for (int i = 0; i < list.size(); i++) {
        pstmt.setString(i + 1, list.get(i));
    }
    
        //运行
    rs = pstmt.executeQuery();
    while (rs.next()) {
        System.out.println("      id : " + rs.getString("id"));
        System.out.println("password : " + rs.getString("password"));
        System.out.println("");
    }
     } finally {
    rs.close();
    pstmt.close();
    con.close();
    

    }

    也可以将“//根据参数列表的大小生成in串”和“//根据参数列表设置sql参数”合并,
    直接list直接生成最终的sql文,传入pstmt。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 有赏,i卡绘世画不出
  • ¥15 如何用stata画出文献中常见的安慰剂检验图
  • ¥15 c语言链表结构体数据插入
  • ¥40 使用MATLAB解答线性代数问题
  • ¥15 COCOS的问题COCOS的问题
  • ¥15 FPGA-SRIO初始化失败
  • ¥15 MapReduce实现倒排索引失败
  • ¥15 ZABBIX6.0L连接数据库报错,如何解决?(操作系统-centos)
  • ¥15 找一位技术过硬的游戏pj程序员
  • ¥15 matlab生成电测深三层曲线模型代码