[JDBC]PreparedStatement替代Statement

一.增

复制代码
    @Test
    public void testInsert() throws Exception {
        try(Connection con = ConnectDB();
            Scanner input = new Scanner(System.in)){

            System.out.print("请输入姓名:");
            String ename = input.next();//李四

            System.out.print("请输入薪资:");
            double salary = input.nextDouble();//15000

            System.out.print("请输入出生日期:");
            String birthday = input.next();//1990-1-1

            System.out.print("请输入性别:");
            char gender = input.next().charAt(0);//男
//        String gender = input.next();

            System.out.print("请输入手机号码:");
            String tel = input.next();//13578595685

            System.out.print("请输入邮箱:");
            String email = input.next();//zhangsan@atguigu.com

            //编写sql
            String sql = "insert into t_employee(ename,salary,birthday,gender,tel,email,hiredate) " +
                    "values(?,?,?,?,?,?,curdate())";

            //告诉数据库执行 INSERT 操作后,返回自动生成的主键值(比如自增 ID)
            PreparedStatement preparedStatement = con.prepareStatement(sql, Statement.RETURN_GENERATED_KEYS);
            //需要填写?对应的值
            preparedStatement.setObject(1, ename);
            preparedStatement.setObject(2, salary);
            preparedStatement.setObject(3, birthday);
            preparedStatement.setObject(4, gender + "");//char变为String类型
            preparedStatement.setObject(5, tel);
            preparedStatement.setObject(6, email);

            int len = preparedStatement.executeUpdate();
            if(len > 0){
                System.out.println("添加成功! len = " +  len);
            }else{
                System.out.println("添加失败!");
            }
            preparedStatement.close();
        }
    }

一个关于PeparedStatement的insert的错误

二.删

复制代码
@Test
public void testDelete() throws Exception {
    String sql = "delete from t_employee where eid = ?";
    try(Connection con = ConnectDB();
        PreparedStatement ps = con.prepareStatement(sql, Statement.RETURN_GENERATED_KEYS);){
        ps.setInt(1,32);
        int len = ps.executeUpdate();
        if(len > 0){
            System.out.println("删除成功! len = " + len);
        }else{
            System.out.println("删除失败!");
        }
    }
    catch (Exception e){
        e.printStackTrace();
    }
}

三.改

复制代码
@Test
public void testUpdate() throws Exception {
    try(Connection con = ConnectDB();
    PreparedStatement ps = con.prepareStatement("update t_employee set ename = ? where eid = ?");
    Scanner input = new Scanner(System.in)){

        System.out.println("请输入要修改的姓名:");
        String ename = input.next();
        System.out.println("请输入要修改的员工ID:");
        int eid = input.nextInt();
        ps.setString(1,ename);
        ps.setInt(2, eid);

        int len = ps.executeUpdate();
        if(len > 0){
            System.out.println("修改成功! len = " + len);
        }else{
            System.out.println("修改失败!");
        }

    }catch(Exception e){
        e.printStackTrace();
    }
}
相关推荐
rKWP8gKv75 分钟前
单例模式在Java中的7种实现:从懒汉式到静态内部类
java·开发语言·单例模式
努力努力再努力wz12 分钟前
【MySQL进阶系列】一文打通事务机制:从锁、Undo Log 到 MVCC 与隔离级别
c语言·数据结构·数据库·c++·mysql·算法·github
PaperData29 分钟前
2000-2025年《中国县域统计年鉴》pdf+excel版(附赠面板数据)
数据库·人工智能·数据分析·pdf·经管
冷小鱼35 分钟前
从关系模型(SQL)基石到AI与信创时代的智能查询语言
数据库·sql
庞轩px43 分钟前
致远互联实习复盘:一条SQL替代300次循环查询,组织架构选择器从5秒降到300毫秒
java·sql·mysql·mybatis·实习经历·n+1问题·join联表查询
vooy pktc44 分钟前
Spring Security 官网文档学习
java·学习·spring
LLON erva1 小时前
Redis-配置文件
数据库·redis·oracle
童话ing1 小时前
【Redis】026 互联网大厂 Redis 面试高频题
数据库·redis·面试
钰衡大师1 小时前
Activiti 7 工作流技术文档
java·数据库·spring boot
Treh UNFO1 小时前
nginx的重定向
大数据·数据库·nginx