[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();
    }
}
相关推荐
日月云棠2 天前
各版本JDK对比:JDK 25 特性详解
java
用户8307196840822 天前
Spring Boot 项目中日期处理的最佳实践
java·spring boot
JavaGuide2 天前
Claude Opus 4.6 真的用不起了!我换成了国产 M2.5,实测真香!!
java·spring·ai·claude code
IT探险家2 天前
Java 基本数据类型:8 种原始类型 + 数组 + 6 个新手必踩的坑
java
花花无缺2 天前
搞懂new 关键字(构造函数)和 .builder() 模式(建造者模式)创建对象
java
用户908324602732 天前
Spring Boot + MyBatis-Plus 多租户实战:从数据隔离到权限控制的完整方案
java·后端
桦说编程2 天前
实战分析 ConcurrentHashMap.computeIfAbsent 的锁冲突问题
java·后端·性能优化
爱可生开源社区2 天前
2026 年,优秀的 DBA 需要具备哪些素质?
数据库·人工智能·dba
程序员清风2 天前
用了三年AI,我总结出高效使用AI的3个习惯!
java·后端·面试
beata2 天前
Java基础-13: Java反射机制详解:原理、使用与实战示例
java·后端