JDBC数据库编程(java实训报告)

本文涉及的产品
云数据库 RDS SQL Server,基础系列 2核4GB
RDS SQL Server Serverless,2-4RCU 50GB 3个月
推荐场景:
简介: 这篇文章是关于JDBC数据库编程的实训报告,涵盖了实验要求、实验环境、实验内容和总结。文中详细介绍了如何使用Java JDBC技术连接数据库,并进行增删改查等基本操作。实验内容包括建立数据库连接、查询、添加、删除和修改数据,每个部分都提供了相应的Java代码示例和操作测试结果截图。作者在总结中分享了在实验过程中遇到的问题和解决方案,以及对Java与数据库连接操作的掌握情况。

文章目录

  • 一、实验要求:
  • 二、实验环境:
  • 三、实验内容:
    • 1、建立数据库连接
    • 2、查询数据
      • 2.1 测试结果
    • 3、添加数据
      • 3.1、测试结果
    • 4、删除数据
      • 4.1、测试结果
    • 5、修改数据
      • 5.1 测试结果
    • 四、总结

一、实验要求:

1、掌握数据库访问技术。
2、掌握JDBC连接数据库的方法。
3、掌握JDBC基本操作、包括查找、修改、删除、增加等。

二、实验环境:

1、硬件设备要求:PC及其联网环境;
2、软件设备要求:Windows操作系统;Sqlserver数据库管理系统;Eclipse集成开发工具。

三、实验内容:

编写程序实现对图书信息表的增删改查操作。
需求分析:现有图书信息表bookinfo(序号,图书编号,图书名称,作者,出版社,单价,出版日期,ISBN,库存数量)。写程序实现对该表的增删改查操作。

1、建立数据库连接

package bao_1;

import java.sql.*;

public class JdbcConnection {
    private static Connection conn = null;

    public static Connection dbConnection() {
        try {
            // 连接驱动程序
            Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver");

        } catch (Exception e) {
            e.printStackTrace();
        }

        try {
            //访问sqlserver的url
            String url = "jdbc:sqlserver://localhost:1433;databbaseName=MyDatabase";
            String user="sa";
            String password="123";
            //获得数据连接
            conn = DriverManager.getConnection(url, user, password);
            System.out.println("数据库连接成功\n\n\n");
        } catch (Exception e) {
            e.printStackTrace();
        }

        return conn;
    }

}

2、查询数据

package bao_1;

import java.sql.*;

public class QueryExam {

    public static void main(String[] args) {
        // TODO Auto-generated method stub
        try {
            //获得连接对象
            Connection conn=new JdbcConnection().dbConnection();
            //创建语句对象

            Statement sql=conn.createStatement();
            //执行数据库查询操作,返回一个Resultset 结果集
            ResultSet rs=sql.executeQuery("select *from MyDatabase..student");
            System.out.println("\t\t显示数据的所有信息:\n");
            //循环获得所有数据
            while(rs.next()) {
                int index =rs.getInt(1);//获取表中第1列序号信息
                String name=rs.getString(2);//......第二列图书名称
                float price=rs.getFloat(3);//.......第三列图书价格
                int number =rs.getInt(4);  //........第四列图书数量
                String author=rs.getString(5);//......第五列图书作者
                System.out.print("  序号:"+index);
                System.out.print("  名称:"+name);
                System.out.print("  价格:"+price);
                System.out.print("  数量:"+number);
                System.out.print("  作者:"+author);
                System.out.println("\n");

                }

        } catch (Exception e) {
            e.printStackTrace();
        }
    }

}

2.1 测试结果

在这里插入图片描述

3、添加数据

package bao_1;

import java.sql.*;

public class InsertExam {

    public static void main(String[] args) {

        try {
            Connection conn=new JdbcConnection().dbConnection();
            Statement sql=conn.createStatement();
            //定义插入数据的SQL语句
            String inserStr="insert into MyDatabase..student values(5,'程序设计',38,24,'小黑')";
            sql.executeUpdate(inserStr);//调用executeUpdate()方法,更新数据
            ResultSet rs=sql.executeQuery("select *from MyDatabase..student");
            System.out.println("\t\t插入数据:\n\n");
            while (rs.next()) {
                int index = rs.getInt(1);// 获取表中第1列序号信息
                String name = rs.getString(2);// ......第二列图书名称
                float price = rs.getFloat(3);// .......第三列图书价格
                int number = rs.getInt(4); // ........第四列图书数量
                String author = rs.getString(5);// ......第五列图书作者
                System.out.print("  序号:"+index);
                System.out.print("  名称:" + name);
                System.out.print("  价格:" + price);
                System.out.print("  数量:" + number);
                System.out.print("  作者:" + author);
                System.out.println("\n");
            }
            } catch (Exception e) {
            e.printStackTrace();
        }
    }

}

3.1、测试结果

在这里插入图片描述

4、删除数据

package bao_1;

import java.sql.*;

public class DeleteExample {

    public static void main(String[] args) {
        // TODO Auto-generated method stub
        try {
            Connection conn = new JdbcConnection().dbConnection();
            Statement sql = conn.createStatement();
            // 删除数据的SQL语句
            String deleteStr = "delete from MyDatabase..student where id=2";
            sql.executeUpdate(deleteStr);// 更新数据表
            ResultSet rs = sql.executeQuery("select * from MyDatabase..student ");
              System.out.println("\t\t删除数据:\n");
            while (rs.next()) {
                int index = rs.getInt(1);// 获取表中第1列序号信息
                String name = rs.getString(2);// ......第二列图书名称
                float price = rs.getFloat(3);// .......第三列图书价格
                int number = rs.getInt(4); // ........第四列图书数量
                String author = rs.getString(5);// ......第五列图书作者
                System.out.print("  序号:"+index);
                System.out.print("  名称:" + name);
                System.out.print("  价格:" + price);
                System.out.print("  数量:" + number);
                System.out.print("  作者:" + author);
                System.out.println("\n");
            }
        } catch (Exception e) {
            e.printStackTrace();
        }

    }

}

4.1、测试结果

在这里插入图片描述

5、修改数据

package bao_1;

import java.sql.*;

public class UpdateExam {

    public static void main(String[] args) {
        // TODO Auto-generated method stub
        try {
            Connection conn = new JdbcConnection().dbConnection();
            Statement sql = conn.createStatement();
            // 更新数据的sql
            String updateStr = "Update MyDatabase..student set author='李刚' where id=3";
            sql.executeUpdate(updateStr);
            ResultSet rs = sql.executeQuery("select * from MyDatabase..student");
            System.out.println("\t\t更改数据信息:\n");
            while (rs.next()) {
                int index = rs.getInt(1);// 获取表中第1列序号信息
                String name = rs.getString(2);// ......第二列图书名称
                float price = rs.getFloat(3);// .......第三列图书价格
                int number = rs.getInt(4); // ........第四列图书数量
                String author = rs.getString(5);// ......第五列图书作者
                System.out.print("  序号:"+index);
                System.out.print("  名称:"+name);
                System.out.print("  价格:"+price);
                System.out.print("  数量:"+number);
                System.out.print("  作者:"+author);
                System.out.println("\n");
            }

        } catch (Exception e) {
            e.printStackTrace();
        }
    }

}

5.1 测试结果

在这里插入图片描述

四、总结

实验总结:通过本次实验,我基本掌握了java和数据库的连接,通过在java中编写程序直接对数据库里边的数据进行一系列的操作。在进行java和数据库连接中遇到的问题是下载的驱动程序要怎样加入到java项目中,在数据库建立表的过程中,防火墙的设置始终不能成功,导致数据库中编写时不能正常的运行。经过多次的尝试才能运行。从数据库中本地编写代码实现数据的增删改查较为容易。Java和数据库建立连接成功是第一步,这个连接不成功则没办法继续进行。成功连接后需要编写对数据库增删改查的相关代码。过程虽然很艰辛,遇到了很多的问题,通过查询相关的知识点将问题解决。自己对知识的掌握有了进一步的提高。
在这里插入图片描述

相关实践学习
使用SQL语句管理索引
本次实验主要介绍如何在RDS-SQLServer数据库中,使用SQL语句管理索引。
SQL Server on Linux入门教程
SQL Server数据库一直只提供Windows下的版本。2016年微软宣布推出可运行在Linux系统下的SQL Server数据库,该版本目前还是早期预览版本。本课程主要介绍SQLServer On Linux的基本知识。 相关的阿里云产品:云数据库RDS SQL Server版 RDS SQL Server不仅拥有高可用架构和任意时间点的数据恢复功能,强力支撑各种企业应用,同时也包含了微软的License费用,减少额外支出。 了解产品详情: https://www.aliyun.com/product/rds/sqlserver
相关文章
|
8天前
|
人工智能 JavaScript 关系型数据库
【02】Java+若依+vue.js技术栈实现钱包积分管理系统项目-商业级电玩城积分系统商业项目实战-ui设计图figmaUI设计准备-figma汉化插件-mysql数据库设计-优雅草卓伊凡商业项目实战
【02】Java+若依+vue.js技术栈实现钱包积分管理系统项目-商业级电玩城积分系统商业项目实战-ui设计图figmaUI设计准备-figma汉化插件-mysql数据库设计-优雅草卓伊凡商业项目实战
55 14
【02】Java+若依+vue.js技术栈实现钱包积分管理系统项目-商业级电玩城积分系统商业项目实战-ui设计图figmaUI设计准备-figma汉化插件-mysql数据库设计-优雅草卓伊凡商业项目实战
|
11天前
|
人工智能 JavaScript 安全
【01】Java+若依+vue.js技术栈实现钱包积分管理系统项目-商业级电玩城积分系统商业项目实战-需求改为思维导图-设计数据库-确定基础架构和设计-优雅草卓伊凡商业项目实战
【01】Java+若依+vue.js技术栈实现钱包积分管理系统项目-商业级电玩城积分系统商业项目实战-需求改为思维导图-设计数据库-确定基础架构和设计-优雅草卓伊凡商业项目实战
55 13
【01】Java+若依+vue.js技术栈实现钱包积分管理系统项目-商业级电玩城积分系统商业项目实战-需求改为思维导图-设计数据库-确定基础架构和设计-优雅草卓伊凡商业项目实战
|
5天前
|
存储 缓存 Java
java语言后台管理ruoyi后台管理框架-登录提示“无效的会话,或者会话已过期,请重新登录。”-扩展知识数据库中密码加密的方法-问题如何解决-以及如何重置若依后台管理框架admin密码-优雅草卓伊凡
java语言后台管理ruoyi后台管理框架-登录提示“无效的会话,或者会话已过期,请重新登录。”-扩展知识数据库中密码加密的方法-问题如何解决-以及如何重置若依后台管理框架admin密码-优雅草卓伊凡
20 3
java语言后台管理ruoyi后台管理框架-登录提示“无效的会话,或者会话已过期,请重新登录。”-扩展知识数据库中密码加密的方法-问题如何解决-以及如何重置若依后台管理框架admin密码-优雅草卓伊凡
|
28天前
|
SQL Java 关系型数据库
使用 JDBC 实现 Java 数据库操作
JDBC(Java Database Connectivity)是 Java 提供的数据库访问技术,允许通过 SQL 语句与数据库交互。本文详细介绍了 JDBC 的使用方法,包括环境准备、编程步骤和完整示例。
101 7
|
28天前
|
SQL Java 数据库连接
【潜意识Java】MyBatis中的动态SQL灵活、高效的数据库查询以及深度总结
本文详细介绍了MyBatis中的动态SQL功能,涵盖其背景、应用场景及实现方式。
91 6
|
28天前
|
SQL Java 数据库连接
【潜意识Java】Java中JDBC过时方法的替代方案以及JDBC为什么过时详细分析
本文介绍了JDBC中一些常见过时方法及其替代方案。
41 5
|
28天前
|
前端开发 Java 数据库连接
Java后端开发-使用springboot进行Mybatis连接数据库步骤
本文介绍了使用Java和IDEA进行数据库操作的详细步骤,涵盖从数据库准备到测试类编写及运行的全过程。主要内容包括: 1. **数据库准备**:创建数据库和表。 2. **查询数据库**:验证数据库是否可用。 3. **IDEA代码配置**:构建实体类并配置数据库连接。 4. **测试类编写**:编写并运行测试类以确保一切正常。
52 2
|
2月前
|
存储 缓存 Java
Java 并发编程——volatile 关键字解析
本文介绍了Java线程中的`volatile`关键字及其与`synchronized`锁的区别。`volatile`保证了变量的可见性和一定的有序性,但不能保证原子性。它通过内存屏障实现,避免指令重排序,确保线程间数据一致。相比`synchronized`,`volatile`性能更优,适用于简单状态标记和某些特定场景,如单例模式中的双重检查锁定。文中还解释了Java内存模型的基本概念,包括主内存、工作内存及并发编程中的原子性、可见性和有序性。
Java 并发编程——volatile 关键字解析
|
2月前
|
Java 数据库连接 数据库
springboot java.lang.ClassNotFoundException: dm.jdbc.driver.DmDriver应该如何解决
通过上述步骤,可以有效解决Spring Boot项目中遇到的 `java.lang.ClassNotFoundException: dm.jdbc.driver.DmDriver`问题。确保在项目中正确添加达梦数据库的JDBC驱动依赖,并在配置文件中正确配置数据源信息,是解决此问题的关键。通过这些方法,可以确保Spring Boot项目能够正确连接达梦数据库并正常运行。
320 31
|
2月前
|
算法 Java 调度
java并发编程中Monitor里的waitSet和EntryList都是做什么的
在Java并发编程中,Monitor内部包含两个重要队列:等待集(Wait Set)和入口列表(Entry List)。Wait Set用于线程的条件等待和协作,线程调用`wait()`后进入此集合,通过`notify()`或`notifyAll()`唤醒。Entry List则管理锁的竞争,未能获取锁的线程在此排队,等待锁释放后重新竞争。理解两者区别有助于设计高效的多线程程序。 - **Wait Set**:线程调用`wait()`后进入,等待条件满足被唤醒,需重新竞争锁。 - **Entry List**:多个线程竞争锁时,未获锁的线程在此排队,等待锁释放后获取锁继续执行。
85 12