音乐管理系统修改 数据和集合 list和set 异常和错误 分层

一.音乐管理系统

1.新建一个包,名为“dao”,再在其中新建一个JAVA文件“MusicDao”,再将前一天写好的代码复制到“MusicDao”进行修改
在这里插入图片描述
修改后代码如下

public class MusicDao {
    public List<Music> findMusics(){
        ResultSet resultSet = null;
        PreparedStatement statement = null;
        Connection connection = null;
        List<Music> musics=new ArrayList<>();
        try {
            connection = DBUtil.getConnection();
            String sql = "select * from music";
            statement = connection.prepareStatement(sql);
            resultSet = statement.executeQuery();
            while (resultSet.next()) {
                Music music = new Music();
                music.setId(resultSet.getInt(1));
                music.setName(resultSet.getString(2));
                music.setAuthor(resultSet.getString(3));
                musics.add(music);
            }
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            DBUtil.closeAll(resultSet, statement, connection);
        }
        return musics;
    }
    public void delete(int id) throws SQLException {
        Connection connection = DBUtil.getConnection();
        String sql = "delete from music where id=?";
        PreparedStatement statement = connection.prepareStatement(sql);
        statement.setInt(1,id);
        statement.executeUpdate();
        DBUtil.closeAll(null,statement,connection);
    }
    public void zj(String name,String author) throws SQLException {
        Connection connection = DBUtil.getConnection();
        String sql = "insert into music(name,author) values (?,?)";
        PreparedStatement statement = connection.prepareStatement(sql);
        statement.setString(1,name);
        statement.setString(2,author);
        statement.executeUpdate();
        DBUtil.closeAll(null,statement,connection);
    }
    public void xg(int id,String name) throws SQLException{
        Connection connection = DBUtil.getConnection();
        String sql = "update music set name=? where id=?";
        PreparedStatement statement = connection.prepareStatement(sql);
        statement.setInt(2,id);
        statement.setString(1,name);
        statement.executeUpdate();
        DBUtil.closeAll(null,statement,connection);
    }

}

2.前一天的“Test”文件也有所修改。我将“Test”文件修改的更加完善了些,加入了增加,修改和删除功能。
在Idea软件中的条件改动,SQL软件中刷新运行后结果也会随之改变。
修改代码如下

public class Test {
    public static void main(String[] args) throws SQLException {
        MusicDao musicDao=new MusicDao();
        List<Music> musics=musicDao.findMusics();
        System.out.println(musics);
        Scanner input=new Scanner(System.in);
//        System.out.println("请输入你喜欢的歌名:");
//        String name=input.next();
//        System.out.println("请输入你喜欢的歌的歌手:");
//        String author=input.next();
//        System.out.println("请输入你想修改的歌的id:");
//        int ids=input.nextInt();
//        System.out.println("请输入你想修改歌的歌名:");
//        String names=input.next();
        System.out.println("请输入你想删除歌的id:");
        int id=input.nextInt();
//        musicDao.zj(name,author);
//        musicDao.xg(ids,names);
        musicDao.delete(id);
    }
}

将增加的代码注释取消,再把删除和修改的代码注释,代码运行后输入歌名和即可
在这里插入图片描述程序运行结果如下
在这里插入图片描述下面是数据改变后在sql运行后的结果
在这里插入图片描述
接下来是修改数据,同上,将修改的代码注释取消,增加和删除添加注释
在这里插入图片描述程序运行结果如下
在这里插入图片描述运行成功后转到SQL,刷新运行后结果如下
在这里插入图片描述
接下来是删除数据,同上,删除代码注释取消,增加和修改添加注释
在这里插入图片描述程序运行结果
在这里插入图片描述
运行成功后进入sql,可以看到id为4的一行数据已经被删除
在这里插入图片描述
DBUtil代码也有所修改
代码如下

public class DBUtil {
    public static Connection getConnection() throws SQLException{
        try {
            Class.forName("com.mysql.jdbc.Driver");
        } catch (ClassNotFoundException e) {
            e.printStackTrace();
        }
        Connection connection= DriverManager.getConnection("jdbc:mysql://127.0.0.1:3306/zjgm?characterEncoding=utf-8&user=root&password=123456");
        System.out.println("操作成功!");
        return connection;
    }
    public static void closeAll(ResultSet resultSet,Statement statement, Connection connection){
        if (resultSet!=null){
            try {
                resultSet.close();
            } catch (SQLException e) {
                e.printStackTrace();
            }
        }
        if (connection!=null){
            try {
                connection.close();
            } catch (SQLException e) {
                e.printStackTrace();
            }
        }
        if (statement!=null){
            try {
                statement.close();
            } catch (SQLException e) {
                e.printStackTrace();
            }
        }
    }
}

二.数据和集合的区别

数组和集合的区别:
1.数组大小是固定的 集合不是固定
2.数组只能放一种类型的数据 集合可以放多种类型的数据

三.list和set的区别

list 和 set 的区别
1.list 有序可重复
2.set 无序不可以重复

list
arraylist 数组list 查询快 删除和添加慢
linkedlist 添加和删除快 查询慢

set
treeset 通过树状保存数据

四.异常和错误

1.运行时异常 可以不处理 jvm虚拟机 处理
2.编译异常 必须要处理

处理异常的2种方式:
1.try catch 自己处理
2.throws 给掉用者处理

自定义异常

实体类:与数据库 对象
1.构造方法
2.属性
3.get set
4.toString

五.分层

1.model 实体类
2.dao 持久层 对数据库操作 增删改查

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
目标检测(Object Detection)是计算机视觉领域的一个核心问题,其主要任务是找出图像所有感兴趣的目标(物体),并确定它们的类别和位置。以下是对目标检测的详细阐述: 一、基本概念 目标检测的任务是解决“在哪里?是什么?”的问题,即定位出图像目标的位置并识别出目标的类别。由于各类物体具有不同的外观、形状和姿态,加上成像时光照、遮挡等因素的干扰,目标检测一直是计算机视觉领域最具挑战性的任务之一。 二、核心问题 目标检测涉及以下几个核心问题: 分类问题:判断图像的目标属于哪个类别。 定位问题:确定目标在图像的具体位置。 大小问题:目标可能具有不同的大小。 形状问题:目标可能具有不同的形状。 三、算法分类 基于深度学习的目标检测算法主要分为两大类: Two-stage算法:先进行区域生成(Region Proposal),生成有可能包含待检物体的预选框(Region Proposal),再通过卷积神经网络进行样本分类。常见的Two-stage算法包括R-CNN、Fast R-CNN、Faster R-CNN等。 One-stage算法:不用生成区域提议,直接在网络提取特征来预测物体分类和位置。常见的One-stage算法包括YOLO系列(YOLOv1、YOLOv2、YOLOv3、YOLOv4、YOLOv5等)、SSD和RetinaNet等。 四、算法原理 以YOLO系列为例,YOLO将目标检测视为回归问题,将输入图像一次性划分为多个区域,直接在输出层预测边界框和类别概率。YOLO采用卷积网络来提取特征,使用全连接层来得到预测值。其网络结构通常包含多个卷积层和全连接层,通过卷积层提取图像特征,通过全连接层输出预测结果。 五、应用领域 目标检测技术已经广泛应用于各个领域,为人们的生活带来了极大的便利。以下是一些主要的应用领域: 安全监控:在商场、银行
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值