唇劫. 2022-04-28 13:51 采纳率: 73.7%
浏览 52
已结题

java,JDBC,添加不成功,咋写啊

/这是Dao包/
public class MobileDao {
/*根据品牌名称查询品牌是否存在,存在返回true,否则返回false
@param brand
@return */

public boolean findByBrand(String brand){
    boolean b=true;
    Connection con=null;
    PreparedStatement sta=null;
    ResultSet rs=null;
    con= DBUtil3.getCon();
    String sql="SELECT * FROM mobile WHERE brand=?";
    try {
        sta=con.prepareStatement(sql);
        sta.setString(1,"brand");
        rs=sta.executeQuery();
        if (rs.next()){
            b=true;
        }
    } catch (SQLException e) {
        e.printStackTrace();
    }finally {
        DBUtil3.closes(rs,sta,con);
    }
    return b;
}


/*
  新增品牌信息,如果成功返回true,否则返回false
  @param
 @return
 */
public boolean add(Mobile mobile){
    boolean b=true;
    String sql="insert into mobile values(?,?,?)";
    DBUtil3.update(sql,mobile.getBrand(),mobile.getManufacturer(),mobile.getProduce());
    return b;
}

}

/这是测试类/
public class MobileTest {
static Scanner sc = new Scanner(System.in);
static MobileDao mobileDao = new MobileDao();

public static void main(String[] args) {
    all();
}
private static void all() {
    System.out.println("**********手机品牌管理**********");
    System.out.println("品牌名称:");
    String brand = sc.nextLine();
    while (brand.equals("")){
        System.out.println("品牌名称必须输入:");
        brand = sc.nextLine();
    }
    System.out.println("广商名称:");
    String manufacturer=sc.nextLine();
    while (manufacturer.equals("")){
        System.out.println("厂商名称必须输入:");
        manufacturer=sc.nextLine();
    }
    System.out.println("产地:");
    String produce = sc.nextLine();
    while (produce.equals("")){
        System.out.println("产地必须输入");
        produce=sc.nextLine();
    }
    boolean b=mobileDao.findByBrand(brand);
    if (!b){
        Mobile mobile=new Mobile(brand,manufacturer,produce);
        mobileDao.add(mobile);
        System.out.println("添加成功");
    }else{
        System.out.println("该手机品牌已存在,不能添加");

    }
}

}

  • 写回答

7条回答 默认 最新

  • 溪风沐雪 2022-04-28 14:22
    关注

    findByBrand方法内的b恒为true,所以直接就进else了,应该先赋值为false,后边根据查询结果改变b的值再返回

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

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 4月29日
  • 已采纳回答 4月29日
  • 创建了问题 4月28日

悬赏问题

  • ¥15 uniapp的websocket和c++的websocket服务器通讯 发送的数据和接受的数据表现形式不一样
  • ¥15 pyspark配置中的错误
  • ¥15 html word表格
  • ¥15 kali安装包如何解决,请给明确方案和步骤
  • ¥15 DEA软件进行企业创新效率的计算
  • ¥15 树莓派驱动42步进电机
  • ¥20 bevfusion mit可视化遇到的问题
  • ¥15 如何获得《人工智能工程技术人员》认证?
  • ¥100 悬赏破解EFS加密,速度
  • ¥30 用MATLAB画随t变化的函数图像,式中包含了累加求和,出现报错,不知道怎么办了,请解释一下