pryjava 2008-10-15 08:27
浏览 912
已采纳

PreparedStatement中in语句的用法

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

  • 写回答

2条回答 默认 最新

  • hunterli0408 2008-10-15 09: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 爱快路由器端口更改错误导致无法访问
  • ¥20 安装catkin时遇到了如下问题请问该如何解决呢
  • ¥15 VAE模型如何输出结果
  • ¥15 编译python程序为pyd文件报错:{"source code string cannot contain null bytes"
  • ¥20 关于#r语言#的问题:广义加行模型拟合曲线后如何求拐点
  • ¥15 fluent设置了自动保存后,会有几个时间点不保存
  • ¥20 激光照射到四象线探测器,通过液晶屏显示X、Y值
  • ¥50 数据库开发问题求解答
  • ¥15 安装anaconda时报错
  • ¥15 小程序有个导出到插件方式,我是在分包下引入的插件,这个export的路径对吗,我看官方文档上写的是相对路径
手机看
程序员都在用的中文IT技术交流社区

程序员都在用的中文IT技术交流社区

专业的中文 IT 技术社区,与千万技术人共成长

专业的中文 IT 技术社区,与千万技术人共成长

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

客服 返回
顶部