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

本文涉及的产品
云数据库 RDS SQL Server,基础系列 2核4GB
简介: 这篇文章是关于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和数据库建立连接成功是第一步,这个连接不成功则没办法继续进行。成功连接后需要编写对数据库增删改查的相关代码。过程虽然很艰辛,遇到了很多的问题,通过查询相关的知识点将问题解决。自己对知识的掌握有了进一步的提高。
在这里插入图片描述

相关文章
|
1月前
|
SQL Java 数据库连接
除了JDBC,还有哪些常见的数据库访问技术?
除了JDBC,还有哪些常见的数据库访问技术?
209 2
|
1月前
|
Java
如何在Java中进行多线程编程
Java多线程编程常用方式包括:继承Thread类、实现Runnable接口、Callable接口(可返回结果)及使用线程池。推荐线程池以提升性能,避免频繁创建线程。结合同步与通信机制,可有效管理并发任务。
144 6
|
1月前
|
IDE Java 编译器
java编程最基础学习
Java入门需掌握:环境搭建、基础语法、面向对象、数组集合与异常处理。通过实践编写简单程序,逐步深入学习,打牢编程基础。
182 0
|
2月前
|
SQL Java 数据库
2025 年 Java 从零基础小白到编程高手的详细学习路线攻略
2025年Java学习路线涵盖基础语法、面向对象、数据库、JavaWeb、Spring全家桶、分布式、云原生与高并发技术,结合实战项目与源码分析,助力零基础学员系统掌握Java开发技能,从入门到精通,全面提升竞争力,顺利进阶编程高手。
547 1
|
1月前
|
安全 前端开发 Java
从反射到方法句柄:深入探索Java动态编程的终极解决方案
从反射到方法句柄,Java 动态编程不断演进。方法句柄以强类型、低开销、易优化的特性,解决反射性能差、类型弱、安全性低等问题,结合 `invokedynamic` 成为支撑 Lambda 与动态语言的终极方案。
145 0
|
3月前
|
安全 Java 数据库连接
2025 年最新 Java 学习路线图含实操指南助你高效入门 Java 编程掌握核心技能
2025年最新Java学习路线图,涵盖基础环境搭建、核心特性(如密封类、虚拟线程)、模块化开发、响应式编程、主流框架(Spring Boot 3、Spring Security 6)、数据库操作(JPA + Hibernate 6)及微服务实战,助你掌握企业级开发技能。
570 3
|
2月前
|
Java 开发者
Java并发编程:CountDownLatch实战解析
Java并发编程:CountDownLatch实战解析
434 100
|
2月前
|
算法 Java
Java多线程编程:实现线程间数据共享机制
以上就是Java中几种主要处理多线程序列化资源以及协调各自独立运行但需相互配合以完成任务threads 的技术手段与策略。正确应用上述技术将大大增强你程序稳定性与效率同时也降低bug出现率因此深刻理解每项技术背后理论至关重要.
220 16
|
2月前
|
NoSQL Java 关系型数据库
超全 Java 学习路线,帮你系统掌握编程的超详细 Java 学习路线
本文为超全Java学习路线,涵盖基础语法、面向对象编程、数据结构与算法、多线程、JVM原理、主流框架(如Spring Boot)、数据库(MySQL、Redis)及项目实战等内容,助力从零基础到企业级开发高手的进阶之路。
281 1
|
3月前
|
安全 算法 Java
Java泛型编程:类型安全与擦除机制
Java泛型详解:从基础语法到类型擦除机制,深入解析通配符与PECS原则,探讨运行时类型获取技巧及最佳实践,助你掌握泛型精髓,写出更安全、灵活的代码。
下一篇
oss云网关配置