首页 > 解决方案 > 变量计数器不会随着添加新的预订对象而增加

问题描述

// 预订实体类

公开课预订{

    private int distance;
    private static int bookingId = 1000;
    private int cabId;
    private int customerId;
    private int billingAmount;


    public Booking() {

        bookingId++;
        System.out.println(bookingId);

    }

}

// 预订服务类,我在这里设置所有参数。

公共课 BookCab {

    public Booking bookCab(int distance, int customerId){
        Booking book = new Booking();


        CabDao cabDao = new CabDaoImpl();

        book.setDistance(distance);
        book.setCustomerId(customerId);

        book.setCabId(cabDao.getCabId()); //retrieving cab data from database

        if(distance>10) {book.setBillingAmount(305 + (distance-10)*25);}
        else if (distance <10 & distance>5) {

            book.setBillingAmount(180 + (distance-5)*25);
        }
        else if (distance <5 & distance>1) {

            book.setBillingAmount(100 + (distance-1)*20);
        }
        else    book.setBillingAmount(100);

        return book;
    }

}

// 这是访问数据库的 DAO 实现。

公共类 BookingDaoImpl 实现 BookingDao {

Connection connection = null;
PreparedStatement ptmt = null;
ResultSet resultSet = null;

public BookingDaoImpl() {};

private Connection getConnection() throws SQLException {
    Connection conn;
    conn = DbUtil.getInstance().getConnection();
    return conn;
}

public void addBooking(Booking booking) {

    try {
        String queryString = "INSERT INTO Booking(bookingId, customerId, cabId, distance, chargingAmount) VALUES(?,?,?,?,?)";
        connection = getConnection();
        ptmt = connection.prepareStatement(queryString);
        ptmt.setInt(1, booking.getBookingId());
        ptmt.setInt(2, booking.getCustomerId());
        ptmt.setInt(3, booking.getCabId());
        ptmt.setInt(4, booking.getDistance());
        ptmt.setInt(5, booking.getBillingAmount());
        ptmt.executeUpdate();
        System.out.println("Data Added Successfully");
    } catch (SQLException e) {
        e.printStackTrace();
    } finally {
        try {
            if (ptmt != null)
                ptmt.close();
            if (connection != null)
                connection.close();
        } catch (SQLException e) {
            e.printStackTrace();
        } catch (Exception e) {
            e.printStackTrace();
        }

    }
}

}

// 驱动类

公共类主视图 {

public static void main(String[] args) {

    BookCab bookCab = new BookCab();

    BookingDao bookingDao = new BookingDaoImpl();
    bookingDao.addBooking(bookCab.bookCab(16, 691744));


}

}

/* 输出

    1001
    Data Added Successfully

    1001
    Data Added Successfully

    1001
    Data Added Successfully

*/

    Counter is not working  
    booking id is not increamenting

我已经尝试在增加后立即打印计数器,但在那里也一样。

标签: javastaticcounterdao

解决方案


您只Booking在您的main(或者,确切地说,您创建一个BookCab实例并调用bookCab.bookCab(16, 691744)创建一个Booking实例)中创建一个实例,这意味着它应该打印 1001。

如果您多次运行该应用程序(根据您的输出,我假设您这样做了),Booking该类将在每次执行时加载并初始化,因此它将计数器重置回 1000。

如果您希望该static变量的值在应用程序的执行中存在,则必须将其保存在某个文件或数据库表中,并在Booking初始化类时加载它。

PS,您可能希望将当前bookingId值存储在某个实例变量中,以便每个Booking实例都与一个唯一bookingId值相关联。


推荐阅读