栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

JAVA项目-基于控制台和数据库实现的房屋管理系统

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

JAVA项目-基于控制台和数据库实现的房屋管理系统

功能

1、新增房源;
2、查找房屋;
3、删除房屋;
4、删除房屋信息;
5、房屋列表;
6、登录;
7、退出;

数据库8.0以上,功能完善~代码简洁明了!
项目源码链接

运行截图




在这里插入图片描述

部分源码

房屋类:存储房屋基本信息

package entity;


public class House {
    //编号  房主  电话  地址  月租  状态(已出租/未出租) 简介
    private int id;
    private String name;
    private String phone;
    private String address;
    private double rent;
    private String state;
    private String introduce;
    public House(int id, String name, String phone, String address, double rent, String state, String introduce) {
        this.id = id;
        this.name = name;
        this.phone = phone;
        this.address = address;
        this.rent = rent;
        this.state = state;
        this.introduce =introduce;
    }

    public House() {

    }

    public int getId() {
        return id;
    }
    public void setId(int id) {
        this.id = id;
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public String getPhone() {
        return phone;
    }
    public void setPhone(String phone) {
        this.phone = phone;
    }
    public String getAddress() {
        return address;
    }
    public void setAddress(String address) {
        this.address = address;
    }
    public double getRent() {
        return rent;
    }
    public void setRent(double rent) {
        this.rent = rent;
    }
    public String getState() {
        return state;
    }
    public void setState(String state) {
        this.state = state;
    }

    public String getIntroduce() {
        return introduce;
    }

    public void setIntroduce(String introduce) {
        this.introduce = introduce;
    }

    @Override
    public String toString() {
        return  id
                +"t" +name
                +"tt" +phone
                +"t" +address
                +"tt"+rent
                +"tt"+state
                +"tt"+introduce;
    }
}

房屋业务层:处理房屋的基本操作

package controller;

import entity.House;
import impl.HouseDaoImpl;
import tool.Utility;
import java.util.List;


public class HouseSevice {
    private List houses;//保存house对象

    public List list(){
        HouseDaoImpl houseDao = new HouseDaoImpl();
        List houses = houseDao.selectAll();
        return houses;//因为重写了tostring
    }
    //添加房屋信息
    public boolean add(House house){
        HouseDaoImpl houseDao = new HouseDaoImpl();
        int t = houseDao.add(house);
        if (t == 1){
            return true;
        }
        return false;

    }
    //删除房屋
    public boolean del(int Id){
        HouseDaoImpl houseDao = new HouseDaoImpl();
        int b = houseDao.delete(Id);
        if(b==1){
            return true;
        }else {
            return false;
        }
    }
    //查找房屋
    public House Find(int id){
        HouseDaoImpl houseDao = new HouseDaoImpl();
        House house = houseDao.query(id);
        return house;
    }


    //修改房屋信息
    public int updata(int up){
        int t = 0;
        HouseDaoImpl houseDao = new HouseDaoImpl();
        House house=Find(up);
        if(house==null){
            System.out.println("该房屋不存在");
        }else {
            System.out.print("姓名:("+house.getName()+"):");
            String name= Utility.readString(8,"");//用户如果直接回车代表不修改,默认值为""
            if(!name.equals("")){
                house.setName(name);//将用户输入的name覆盖原来的name
            }
            System.out.print("手机号:("+house.getPhone()+"):");
            String phone= Utility.readString(11,"");//用户如果直接回车代表不修改,默认值为0
            if(!phone.equals("")){
                house.setPhone(phone);//将用户输入的name覆盖原来的name
            }
            System.out.print("地址:("+house.getAddress()+"):");
            String address= Utility.readString(8,"");
            if(!address.equals("")){
                house.setAddress(address);
            }
            System.out.print("月租:("+house.getRent()+"):");
            double rent= Utility.readDouble();
            if(!(rent==0)){
                house.setRent(rent);
            }
            System.out.print("状态:("+house.getState()+"):");
            String state= Utility.readString(8,"");
            if(!state.equals("")){
                house.setState(state);//
            }
            System.out.print("简介:("+house.getIntroduce()+"):");
            String introduce= Utility.readString(8,"");
            if(!introduce.equals("")){
                house.setState(introduce);//
            }
            t = houseDao.update(house);
        }
        return t;
    }
}

房屋数据库处理

package impl;

import dao.DBConnection;
import dao.HouseDao;
import entity.House;
import entity.User;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;

public class HouseDaoImpl implements HouseDao {

    //新增
    @Override
    public int add(House house) {
        try {
            Connection con = DBConnection.getConnection();
            //新增语句
            String sql = "INSERT into house(NAME,phone,address,rent,state,introduce) VALUES(?,?,?,?,?,?)";
            PreparedStatement ps = con.prepareStatement(sql);
            ps.setString(1, house.getName());
            ps.setString(2, house.getPhone());
            ps.setString(3, house.getAddress());
            ps.setDouble(4, house.getRent());
            ps.setString(5, house.getState());
            ps.setString(6, house.getIntroduce());
            ps.executeUpdate();
            DBConnection.close(null,ps,con);
        } catch (SQLException e) {
            e.printStackTrace();
        }
        return 1;

    }

    //查询房屋出租列表
    @Override
    public List selectAll() {
        List list = new ArrayList<>();
        House house = null;
        try {
            Connection con = DBConnection.getConnection();
            String sql = "select * from house";
            PreparedStatement ps = con.prepareStatement(sql);
            ResultSet rs = ps.executeQuery();
            while (rs.next()){
                house = new House();
                house.setId(rs.getInt(1));
                house.setName(rs.getString(2));
                house.setPhone(rs.getString(3));
                house.setAddress(rs.getString(4));
                house.setRent(rs.getDouble(5));
                house.setState(rs.getString(6));
                house.setIntroduce(rs.getString(7));
                list.add(house);
            }
            DBConnection.close(rs,ps,con);

        } catch (SQLException e) {
            e.printStackTrace();
        }
        return list;
    }

    //根据房屋的id编号查看房屋信息
    @Override
    public House query(int id) {
        House house = null;
        List list = new ArrayList<>();

        try {
            Connection con = DBConnection.getConnection();
            String sql = "SELECt * FROM house WHERe id = ?";
            PreparedStatement ps = con.prepareStatement(sql);
            ps.setInt(1,id);
            ResultSet rs = ps.executeQuery();
            while (rs.next()){
                house = new House();
                house.setId(rs.getInt(1));
                house.setName(rs.getString(2));
                house.setPhone(rs.getString(3));
                house.setAddress(rs.getString(4));
                house.setRent(rs.getDouble(5));
                house.setState(rs.getString(6));
                house.setIntroduce(rs.getString(7));
                list.add(house);
            }
            DBConnection.close(rs,ps,con);

        } catch (SQLException e) {
            e.printStackTrace();
        }
        return house;
    }

    //修改房屋出租信息
    @Override
    public int update(House house) {
        try {
            Connection con = DBConnection.getConnection();
            String sql = "UPDATE house SET `name` = ?,phone = ?,address = ?,rent = ?,state = ?,introduce = ? where id = ?";
            PreparedStatement ps = con.prepareStatement(sql);
            ps.setString(1,house.getName());
            ps.setString(2,house.getPhone());
            ps.setString(3,house.getAddress());
            ps.setDouble(4,house.getRent());
            ps.setString(5,house.getState());
            ps.setString(6,house.getIntroduce());
            ps.setInt(7,house.getId());
            ps.executeUpdate();
            DBConnection.close(null,ps,con);

        } catch (SQLException e) {
            e.printStackTrace();
        }
        return 1;
    }

    //删除房屋出租信息
    @Override
    public int delete(int id) {
        try {
            Connection con = DBConnection.getConnection();
            String sql = "delete from house where id = ?";
            PreparedStatement ps = con.prepareStatement(sql);
            ps.setInt(1,id);
            ps.executeUpdate();
            DBConnection.close(null,ps,con);

        } catch (SQLException e) {
            e.printStackTrace();
        }
        return 1;
    }
}

房屋界面,处理用户操作

package view;

import controller.HouseSevice;
import controller.UserSevice;
import entity.House;
import entity.User;
import tool.Utility;

import java.util.List;


public class HouseView {
    private boolean loop=true;
    private char key=' ';
    //显示房屋列表
    private HouseSevice house_sevice=new HouseSevice();//设置数组大小为10
    private UserSevice userSevice = new UserSevice();
    private User user;

    //编写addhouse(),接收输入,创建addhouse对象,调用add方法
    public void addhouse(){
        if(user == null){
            System.out.println("非常抱歉~您还没有登录,不支持添加");
            return;
        }
        System.out.println("---------添加房屋-------");
        System.out.print("姓名:");
        String name= Utility.readString(6);
        System.out.print("电话:");
        String phone= Utility.readString(11);
        System.out.print("地址:");
        String address= Utility.readString(14);
        System.out.print("月租:");
        double rent= Utility.readDouble();
        System.out.print("状态:");
        String state= Utility.readString(3);
        System.out.print("简介:");
        String introduce= Utility.readString(4);

        //注意id是系统分配的
        House newhouse=new House(0,name,phone,address,rent,state,introduce);
        if(house_sevice.add(newhouse)){
            System.out.println("添加房屋成功");
        }else {
            System.out.println("添加房屋失败");
        }
    }
    //查找房屋
    public void find(){
        System.out.println("---------查找房屋-------");
        System.out.print("请输入要查找的房屋编号:");
        int f= Utility.readInt();
        if(house_sevice.Find(f)==null){
            System.out.println("没有找到该房屋的信息");
        }else {
            System.out.println("编号  房主  t电话  tt地址  t月租  t状态(出租/未出租)t简介n"+house_sevice.Find(f));
        }
    }

    //编写delhosue方法,接收输入的id,调用service的del方法
    public void delhouse(){
        if(user == null){
            System.out.println("非常抱歉~您还没有登录,不支持删除");
            return;
        }
        System.out.println("---------删除房屋-------");
        System.out.print("请输入要删除的房屋编号(-1退出):");
        int delid= Utility.readInt();
        if(delid==-1){
            System.out.println("---------退出删除-------");
            return;
        }
        char c= Utility.readConfirmSelection();//调用该方法,一直循环直到用户输入y或n
        if(c=='Y'){
            if(house_sevice.del(delid)){
                System.out.println("---------删除成功-------");
            }else {
                System.out.println("---------删除失败-------");
            }
        }else {
            System.out.println("---------退出删除-------");
            return;
        }
    }
    //登录系统
    public void register(){
        System.out.println("---------登录系统-------");
        System.out.print("请输入要您的用户名:");
        String name= Utility.readString(6);
        System.out.print("请输入要您的密码:");
        String password= Utility.readString(10);
        user = userSevice.Find(name,password);
        if (user==null){
            System.out.println("没有找到该用户的信息");
        }else {
            System.out.println("欢迎"+user.getName()+"登录系统");
        }
    }

    //修改房屋信息
    public void update(){
        if(user == null){
            System.out.println("非常抱歉~您还没有登录,不支持修改");
            return;
        }
        System.out.println("---------修改房屋信息-------");
        System.out.print("请输入要修改的房屋编号(-1退出):");
        int up= Utility.readInt();
        if(up==-1){
            System.out.println("---------退出修改-------");
            return;
        }
        int b = house_sevice.updata(up);
        if (b==1) {
            System.out.println("---------修改成功-------");
        }else{
            System.out.println("---------修改失败-------");
        }
    }

    //房屋列表
    public  void listHouse(){
        System.out.println("---------房屋出租列表-------");
        System.out.println("编号   房主  tt电话  t地址  t月租  tt状态  tt简介");
        List houses=house_sevice.list();//得到所有房屋的信息
        for (House house:houses) {
            if(house == null){
                break;
            }
            System.out.println(house);
        }

    }
    //主菜单
    public void main_menu(){
        do{
            System.out.println("---------房屋出租系统-------");
            System.out.println("tt1 新 增 房 源");
            System.out.println("tt2 查 找 房 屋");
            System.out.println("tt3 删 除 房 屋");
            System.out.println("tt4 修 改 房 屋 信 息");
            System.out.println("tt5 房 屋 列 表");
            System.out.println("tt6 登 录");
            System.out.println("tt7 退 出");
            System.out.print("请输入你的选择:");
            key= Utility.readChar();
            System.out.println(key);
            switch (key){
                case '1':
                    addhouse();
                    break;
                case '2':
                    find();
                    break;
                case '3':
                    delhouse();
                    break;
                case '4':
                    update();
                    break;
                case '5':
                    listHouse();
                    break;
                case '6':
                    register();
                    break;
                case '7':
                    char n= Utility.readConfirmSelection();
                    if(n=='Y'){
                        loop=false;
                    }
                    break;
                default:
                    System.out.println("输入错误!");
            }
        }while (loop);
    }
}

项目源码链接

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/845069.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号