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

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

相关实践学习
使用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天前
|
算法 Java
【编程基础知识】Java打印九九乘法表
本文介绍了在Java中实现九九乘法表的三种方法:嵌套循环、数组和流控制。通过代码示例、流程图和表格对比,帮助读者深入理解每种方法的优缺点,提升编程技能。
30 2
|
8天前
|
存储 Java
【编程基础知识】 分析学生成绩:用Java二维数组存储与输出
本文介绍如何使用Java二维数组存储和处理多个学生的各科成绩,包括成绩的输入、存储及格式化输出,适合初学者实践Java基础知识。
36 1
|
4天前
|
安全 Java UED
Java中的多线程编程:从基础到实践
本文深入探讨了Java中的多线程编程,包括线程的创建、生命周期管理以及同步机制。通过实例展示了如何使用Thread类和Runnable接口来创建线程,讨论了线程安全问题及解决策略,如使用synchronized关键字和ReentrantLock类。文章还涵盖了线程间通信的方式,包括wait()、notify()和notifyAll()方法,以及如何避免死锁。此外,还介绍了高级并发工具如CountDownLatch和CyclicBarrier的使用方法。通过综合运用这些技术,可以有效提高多线程程序的性能和可靠性。
|
3天前
|
缓存 Java UED
Java中的多线程编程:从基础到实践
【10月更文挑战第13天】 Java作为一门跨平台的编程语言,其强大的多线程能力一直是其核心优势之一。本文将从最基础的概念讲起,逐步深入探讨Java多线程的实现方式及其应用场景,通过实例讲解帮助读者更好地理解和应用这一技术。
19 3
|
4天前
|
Java 开发者
在Java编程中,正确的命名规范不仅能提升代码的可读性和可维护性,还能有效避免命名冲突。
【10月更文挑战第13天】在Java编程中,正确的命名规范不仅能提升代码的可读性和可维护性,还能有效避免命名冲突。本文将带你深入了解Java命名规则,包括标识符的基本规则、变量和方法的命名方式、常量的命名习惯以及如何避免关键字冲突,通过实例解析,助你写出更规范、优雅的代码。
23 3
|
4天前
|
Java 程序员
在Java编程中,关键字不仅是简单的词汇,更是赋予代码强大功能的“魔法咒语”。
【10月更文挑战第13天】在Java编程中,关键字不仅是简单的词汇,更是赋予代码强大功能的“魔法咒语”。本文介绍了Java关键字的基本概念及其重要性,并通过定义类和对象、控制流程、访问修饰符等示例,展示了关键字的实际应用。掌握这些关键字,是成为优秀Java程序员的基础。
11 3
|
4天前
|
Java 程序员 编译器
在Java编程中,保留字(如class、int、for等)是具有特定语法意义的预定义词汇,被语言本身占用,不能用作变量名、方法名或类名。
在Java编程中,保留字(如class、int、for等)是具有特定语法意义的预定义词汇,被语言本身占用,不能用作变量名、方法名或类名。本文通过示例详细解析了保留字的定义、作用及与自定义标识符的区别,帮助开发者避免因误用保留字而导致的编译错误,确保代码的正确性和可读性。
14 3
|
4天前
|
算法 Java
在Java编程中,关键字和保留字是基础且重要的组成部分,正确理解和使用它们
【10月更文挑战第13天】在Java编程中,关键字和保留字是基础且重要的组成部分。正确理解和使用它们,如class、int、for、while等,不仅能够避免语法错误,还能提升代码的可读性和执行效率。本指南将通过解答常见问题,帮助你掌握Java关键字的正确使用方法,以及如何避免误用保留字,使你的代码更加高效流畅。
18 3
|
3天前
|
存储 安全 Java
了解final关键字在Java并发编程领域的作用吗?
在Java并发编程中,`final`关键字不仅用于修饰变量、方法和类,还在多线程环境中确保对象状态的可见性和不变性。本文深入探讨了`final`关键字的作用,特别是其在final域重排序规则中的应用,以及如何防止对象的“部分创建”问题,确保线程安全。通过具体示例,文章详细解析了final域的写入和读取操作的重排序规则,以及这些规则在不同处理器上的实现差异。
了解final关键字在Java并发编程领域的作用吗?
|
5天前
|
设计模式 SQL 安全
【编程进阶知识】Java单例模式深度解析:饿汉式与懒汉式实现技巧
本文深入解析了Java单例模式中的饿汉式和懒汉式实现方法,包括它们的特点、实现代码和适用场景。通过静态常量、枚举类、静态代码块等方式实现饿汉式,通过非线程安全、同步方法、同步代码块、双重检查锁定和静态内部类等方式实现懒汉式。文章还对比了各种实现方式的优缺点,帮助读者在实际项目中做出更好的设计决策。
22 0