批量删除(1课时)

批量删除

相关测试用例:

如果id为整数

public class DelTest {
   @Test
   public void test1(){
       String[] ids={"1","2","4"};
       //(1,2,3)
       //第一步把ids转成字符串
       System.out.println(Arrays.toString(ids).replace("[", "(").replace("]", ")"));
   }
}

如果id为字符串

public static void main(String[] args) {
        //String[] ids ---->('id1','id2','id3')
        String[] ids={"id1","id2","id3"};
        StringBuffer ids_str = new StringBuffer();
        for(int i=0;i<ids.length;i++){
            ids_str.append("\'");
            ids_str.append(ids[i]);
            ids_str.append("\',");
        }
        String sql = "delete from tab_user where id in(" + ids_str.substring(0, ids_str.length()-1) + ")";
        System.out.println(sql);
    }

jsp页form

 <form action="${pageContext.request.contextPath }/delServlet">
    <input type="checkbox" name="chkall" id="chkall"
        onclick="selectAll(this)" />全选
    <table width="100%" border="1" align="center" bordercolor="#dadada">
        <tr align="center">
            <td width="44" height="25" valign="middle">选择</td>
            <td width="98" height="25" valign="middle">账号</td>
            <td width="132" height="25" valign="middle">email</td>
            <td width="132" height="25" valign="middle">身份证号</td>
            <td width="132" height="25" valign="middle">权限</td>
            <td width="132" height="25" valign="middle">操作</td>
        </tr>
        <!-- 循环显示每个用户的信息 用jstl-->
        <c:forEach items="${userList}" var="user" varStatus="status">
            <tr align="center">
                <td width="44" height="25" valign="middle"><input
                    type="checkbox" name="chkone" value="${user.id }"
                    onclick="chkOne(this)" /></td>
                <td width="98" height="25" valign="middle">${user.userName }</td>
                <td width="132" height="25" valign="middle">${user.email }</td>
                <td width="132" height="25" valign="middle">${user.idCard }</td>
                <td width="132" height="25" valign="middle">${user.power }</td>
                <td width="132" height="25" valign="middle"><a href="#">修改</a></td>
            </tr>
        </c:forEach>
        <input type="button" value="删除" onclick="del();">
        </form>

js

function del() {
    var result = confirm("您确定要删除吗?");
    if (result == true) {
        document.forms[0].submit();
    }

}

servlet

 protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
    //第一步 获取页面选中的ID
    String[] ids=request.getParameterValues("chkone");
    //至少选中一个
    if(ids!=null&&ids.length>0){
        //调用删除方法执行删除
        IUserService service=new UserServiceImpl();
        int count=service.delete(ids);
        
        if(count>0) {
            //删除成功
            request.setAttribute("resultMsg", "操作成功");
        }
    }else{
        //给客户端一个响应
        request.setAttribute("resultMsg", "操作失败");
    }
    request.getRequestDispatcher("/findAllUserServlet").forward(request, response);
}

service略

dao --id为整型

@Override
public int delete(String[] ids) {
    // delete from t where id in(1,2,3);
    int count=0;
    conn=DBUtil.getConnection();
    try {
        StringBuffer sql=new StringBuffer("delete from t_user where user_id in ");
        sql.append(Arrays.toString(ids).replace("[", "(").replace("]", ")"));
        ps=conn.prepareStatement(sql.toString());
        count=ps.executeUpdate();
    } catch (Exception e) {
        e.printStackTrace();
    }
    DBUtil.closeConnection(rs, ps, conn);
    return count;
}

dao --id为字符串型

public int delAll(String[] ids) {
        int j=0;
        StringBuffer ids_str = new StringBuffer();
        for(int i=0;i<ids.length;i++){
            ids_str.append("\'");
            ids_str.append(ids[i]);
            ids_str.append("\',");
        }
        String sql = "delete from tab_user where id in(" + ids_str.substring(0, ids_str.length()-1) + ")";
        //获取连接
        Connection conn = DBUtils.getConnection();
        PreparedStatement pst = null;
        try {
            pst=conn.prepareStatement(sql);
            //执行语句(查询有结果集 (insert update delete---成功的条数))
            j=pst.executeUpdate();
        } catch (SQLException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        return j;
    }
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 218,607评论 6 507
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,239评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,960评论 0 355
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,750评论 1 294
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,764评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,604评论 1 305
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,347评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,253评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,702评论 1 315
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,893评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,015评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,734评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,352评论 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,934评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,052评论 1 270
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,216评论 3 371
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,969评论 2 355

推荐阅读更多精彩内容

  • 一. Java基础部分.................................................
    wy_sure阅读 3,811评论 0 11
  • JSP总结(经典) day1 JSP 定义: 1)Java Server Page, Java EE 组件,本...
    java日记阅读 3,449评论 0 13
  • 1.abstract class 和interface 有什么区别? 抽象类可以有构造方法 接口不行 抽象类可以有...
    sunnysans阅读 856评论 0 1
  • 文档版本说明v1.0 基础版本v1.1 补充规范,增加规范等级 一、代码流程规范 (一) java代码处理 【强制...
    tonyZj阅读 966评论 0 2
  • 今天早上给家里做了清洁,感觉房间焕然一新,整个心情也变得清爽了。 下午去华岩寺见了一个朋友,跟她聊了很多,也谈了最...
    一粒麦田阅读 139评论 0 0