jsp中使用Servlet查询SQLSERVER数据库中的表的信息,并且打印在屏幕上

本文涉及的产品
RDS SQL Server Serverless,2-4RCU 50GB 3个月
推荐场景:
云数据库 RDS SQL Server,基础系列 2核4GB
简介: 该博客文章介绍了在JSP应用中使用Servlet查询SQL Server数据库的表信息,并通过JavaBean封装图书信息,将查询结果展示在Web页面上的方法。

jsp中使用Servlet查询SQLSERVER数据库中的表的信息,并且打印在屏幕上

jsp中使用Servlet查询SQLSERVER数据库中的表的信息,并且打印在屏幕上

1、JavaBean的使用

package com.zheng;


public class BookBean {
    private int id;// 编号
    private String name;// 图书名称
    private double price;// 定价
    private int bookCount;// 数量
    private String author;// 作者

    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 double getPrice() {
        return price;
    }

    public void setPrice(double price) {
        this.price = price;
    }

    public int getBookCount() {
        return bookCount;
    }

    public void setBookCount(int bookCount) {
        this.bookCount = bookCount;
    }

    public String getAuthor() {
        return author;
    }

    public void setAuthor(String author) {
        this.author = author;
    }

}

Servlet的编写(连接数据库并且查询)

package com.zheng;
import java.io.IOException;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.ArrayList;
import java.util.List;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

/**
 * Servlet实现类FindServlet
 */
@WebServlet("/FindServlet")        //配置Servlet
public class FindServlet extends HttpServlet {
    private static final long serialVersionUID = 1L;
     public FindServlet() {
        super();
    }

    /**
     * 执行POST请求的方法
     */
    protected void doPostt(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        doGet(request,response);
    }

    /**
     * 执行GET请求的方法
     */
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        try {    
            Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver");        // 加载数据库驱动,注册到驱动管理器
            String url = "jdbc:sqlserver://localhost:1433;databaseName=test";// 数据库连接字符串
            String username = "zheng";                        // 数据库用户名    
            String password = "123";                        // 数据库密码    
            // 创建Connection连接
            Connection conn = DriverManager.getConnection(url,username,password);
            Statement stmt = conn.createStatement();        // 获取Statement
            String sql = "select * from tb_book2";            // 添加图书信息的SQL语句    
            ResultSet rs = stmt.executeQuery(sql);            // 执行查询    
            List<BookBean> list = new ArrayList<>();        // 实例化List对象    
            while(rs.next()){                                // 光标向后移动,并判断是否有效
                BookBean book = new BookBean();                    // 实例化Book对象
                book.setId(rs.getInt("id"));                // 对id属性赋值
                book.setName(rs.getString("name"));        // 对name属性赋值
                book.setPrice(rs.getDouble("price"));        // 对price属性赋值
                book.setBookCount(rs.getInt("bookCount"));    // 对bookCount属性赋值
                book.setAuthor(rs.getString("author"));        // 对author属性赋值
                list.add(book);                             // 将图书对象添加到集合中
            }
            request.setAttribute("list", list);             // 将图书集合放置到request中
            rs.close();                                    // 关闭ResultSet
            stmt.close();                                    // 关闭Statement
            conn.close();                                    // 关闭Connection
        } catch (ClassNotFoundException e) {
            e.printStackTrace();
        } catch (SQLException e) {
            e.printStackTrace();
        }
        // 请求转发到bookList.jsp
        request.getRequestDispatcher("bookList.jsp").forward(request, response);

    }

}

输出数据库中表的信息

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<%@ page import="java.util.*"%>
<%@ page import="com.zheng.BookBean"%>
<!DOCTYPE HTML>
<html>
<head>
<meta charset="utf-8">
<title>显示图书列表</title>
<style type="text/css">
td,th {
    padding: 5px;
}
</style>
</head>
<body>
    <div width="98%" align="center">
        <h2>所有图书信息</h2>
    </div>
    <table width="98%" border="0" align="center" cellpadding="0"
        cellspacing="1" bgcolor="#666666">
        <tr>
            <th bgcolor="#FFFFFF">编号</th>
            <th bgcolor="#FFFFFF">图书名称</th>
            <th bgcolor="#FFFFFF">价格</th>
            <th bgcolor="#FFFFFF">数量</th>
            <th bgcolor="#FFFFFF">作者</th>
        </tr>
        <%
            // 获取图书信息集合
            List<BookBean> list = (List<BookBean>) request.getAttribute("list");
            // 判断集合是否有效
            if (list == null || list.size() < 1) {
                out.print("<tr><td bgcolor='#FFFFFF' colspan='5'>没有任何图书信息!</td></tr>");
            } else {
                // 遍历图书集合中的数据
                for (BookBean book : list) {
        %>
        <tr align="center">
            <td bgcolor="#FFFFFF" ><%=book.getId()%></td>
            <td bgcolor="#FFFFFF"><%=book.getName()%></td>
            <td bgcolor="#FFFFFF"><%=book.getPrice()%></td>
            <td bgcolor="#FFFFFF"><%=book.getBookCount()%></td>
            <td bgcolor="#FFFFFF"><%=book.getAuthor()%></td>
        </tr>
        <%
            }
        }
        %>
    </table>
</body>
</html>

超链接跳转

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<%@ page import="java.sql.*"%>
<!DOCTYPE HTML>
<html>
<head>
<meta charset="utf-8">
<title>首页</title>
</head>
<body>
<a href="FindServlet">查看图书列表</a>
</body>
</html>

查询结果
在这里插入图片描述

相关实践学习
使用SQL语句管理索引
本次实验主要介绍如何在RDS-SQLServer数据库中,使用SQL语句管理索引。
SQL Server on Linux入门教程
SQL Server数据库一直只提供Windows下的版本。2016年微软宣布推出可运行在Linux系统下的SQL Server数据库,该版本目前还是早期预览版本。本课程主要介绍SQLServer On Linux的基本知识。 相关的阿里云产品:云数据库RDS&nbsp;SQL Server版 RDS SQL Server不仅拥有高可用架构和任意时间点的数据恢复功能,强力支撑各种企业应用,同时也包含了微软的License费用,减少额外支出。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/sqlserver
相关文章
|
16天前
|
SQL 数据库
LangChain-09 Query SQL DB With RUN GPT 查询数据库 并 执行SQL 返回结果
LangChain-09 Query SQL DB With RUN GPT 查询数据库 并 执行SQL 返回结果
29 2
|
11天前
|
SQL Java 数据库连接
如何使用`DriverManager.getConnection()`连接数据库,并利用`PreparedStatement`执行参数化查询,有效防止SQL注入。
【10月更文挑战第6天】在代码与逻辑交织的世界中,我从一名数据库新手出发,通过不断探索与实践,最终成为熟练掌握JDBC的开发者。这段旅程充满挑战与惊喜,从建立数据库连接到执行SQL语句,再到理解事务管理和批处理等高级功能,每一步都让我对JDBC有了更深的认识。示例代码展示了如何使用`DriverManager.getConnection()`连接数据库,并利用`PreparedStatement`执行参数化查询,有效防止SQL注入。
47 5
|
14天前
|
SQL 存储 安全
SQL查询数据库:基础概念与操作指南
在数字化时代,数据库已成为信息管理的重要工具之一。作为管理和操作数据库的核心语言,SQL(结构化查询语言)已成为数据管理和查询的关键技能。本文将全面介绍SQL查询数据库的基本概念、语句和操作指南,以帮助初学者快速上手,同时为进阶用户提供有价值的参考。一、数据库与SQL简介数据库是一种存储、管理和检索
27 3
|
15天前
|
SQL 存储 缓存
SQL数据库查询详解
数据库是现代信息社会的基石,它们存储和管理着大量的数据。而SQL(StructuredQueryLanguage)作为一种强大的数据库查询语言,广泛应用于各种数据库系统中。本文将详细介绍SQL数据库查询的基本概念、语法、常用操作以及优化策略。一、SQL数据库查询概述SQL是一种用于管理关系数据库的标
67 3
|
16天前
|
应用服务中间件 PHP Apache
PbootCMS提示错误信息“未检测到您服务器环境的sqlite3数据库扩展...”
PbootCMS提示错误信息“未检测到您服务器环境的sqlite3数据库扩展...”
|
16天前
|
SQL 存储 数据挖掘
SQL Server 日期格式查询详解
SQL Server 日期格式查询详解
83 2
|
16天前
|
存储 SQL 关系型数据库
MySQL查询数据库锁表的SQL语句
MySQL查询数据库锁表的SQL语句
50 1
|
10天前
|
SQL Go 数据库
【速存】深入理解Django ORM:编写高效的数据库查询
【速存】深入理解Django ORM:编写高效的数据库查询
29 0
|
13天前
|
存储 SQL 数据库
深入理解数据库索引:提升查询性能的关键
数据库索引是优化查询性能的重要工具。本文将带你深入探索索引的内部结构和工作原理,揭示如何通过合理使用索引来加速数据库查询,同时避免常见的索引陷阱。
|
14天前
|
SQL 数据处理 数据库
SQL语句优化与查询结果优化:提升数据库性能的实战技巧
在数据库管理和应用中,SQL语句的编写和查询结果的优化是提升数据库性能的关键环节