public class BFormService { Book book=new Book(); BFormdao dao=new BFormdao(); public List<Book> select_by_id(Book bf) { List<Book> aList=dao.select_by_id(bf); return aList; } public List<Book> select_by_isbn(Book bf) { List<Book> aList=dao.select_by_isbn(bf); return aList; } public List<BForm> selectByBookNameAndReaderId(String BookName,String ReaderId){ List<BForm> bList=dao.selectByBookNameAndReaderId(BookName,ReaderId); return bList; } public List<BForm> selectByISBNAndReaderId(String ISBN,String ReaderId){ List<BForm> bList=dao.selectByISBNAndReaderId(ISBN,ReaderId); return bList; } }
时间: 2024-04-01 09:32:31 浏览: 194
这是一个Java类,名为BFormService。它包含了一个Book对象和一个BFormdao对象,并提供了四个方法:
1. select_by_id(Book bf):根据图书ID查询图书信息并返回一个Book类型的List集合。
2. select_by_isbn(Book bf):根据图书ISBN查询图书信息并返回一个Book类型的List集合。
3. selectByBookNameAndReaderId(String BookName,String ReaderId):根据图书名称和读者ID查询借阅信息并返回一个BForm类型的List集合。
4. selectByISBNAndReaderId(String ISBN,String ReaderId):根据图书ISBN和读者ID查询借阅信息并返回一个BForm类型的List集合。
相关问题
在数据库中建立表格T_BOOK(BOOKID,BOOKNAME,BOOKPRICE),插入一些记录。制作一个查询页面,输入两个数字,显示价格在这两个数字之间的图书信息。使用PreparedStatment命令执行sql,要求使用Java Bean技术的DAO和VO模式实现。
首先,我们需要创建一个Java Bean,来映射数据库中的T_BOOK表。假设我们的Java Bean叫做BookVO,代码如下:
```
public class BookVO {
private int bookid;
private String bookname;
private double bookprice;
public int getBookid() {
return bookid;
}
public void setBookid(int bookid) {
this.bookid = bookid;
}
public String getBookname() {
return bookname;
}
public void setBookname(String bookname) {
this.bookname = bookname;
}
public double getBookprice() {
return bookprice;
}
public void setBookprice(double bookprice) {
this.bookprice = bookprice;
}
}
```
然后,我们需要创建一个DAO类,来操作T_BOOK表。假设我们的DAO类叫做BookDAO,代码如下:
```
public class BookDAO {
private Connection conn;
public BookDAO(Connection conn) {
this.conn = conn;
}
public List<BookVO> findByPrice(double minPrice, double maxPrice) throws SQLException {
List<BookVO> books = new ArrayList<>();
String sql = "SELECT BOOKID, BOOKNAME, BOOKPRICE FROM T_BOOK WHERE BOOKPRICE >= ? AND BOOKPRICE <= ?";
try (PreparedStatement stmt = conn.prepareStatement(sql)) {
stmt.setDouble(1, minPrice);
stmt.setDouble(2, maxPrice);
try (ResultSet rs = stmt.executeQuery()) {
while (rs.next()) {
BookVO book = new BookVO();
book.setBookid(rs.getInt("BOOKID"));
book.setBookname(rs.getString("BOOKNAME"));
book.setBookprice(rs.getDouble("BOOKPRICE"));
books.add(book);
}
}
}
return books;
}
}
```
最后,我们可以在JSP页面中使用这个DAO类来查询数据库并显示结果。假设我们的JSP页面叫做query.jsp,代码如下:
```
<%@ page import="java.sql.*" %>
<%@ page import="java.util.*" %>
<%@ page import="com.example.BookDAO" %>
<%@ page import="com.example.BookVO" %>
<%
double minPrice = Double.parseDouble(request.getParameter("minPrice"));
double maxPrice = Double.parseDouble(request.getParameter("maxPrice"));
List<BookVO> books = null;
try (Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/mydb", "root", "password")) {
BookDAO dao = new BookDAO(conn);
books = dao.findByPrice(minPrice, maxPrice);
} catch (SQLException e) {
e.printStackTrace();
}
%>
<table>
<tr>
<th>ID</th>
<th>Name</th>
<th>Price</th>
</tr>
<% for (BookVO book : books) { %>
<tr>
<td><%= book.getBookid() %></td>
<td><%= book.getBookname() %></td>
<td><%= book.getBookprice() %></td>
</tr>
<% } %>
</table>
```
这个JSP页面会从请求参数中获取最小价格和最大价格,然后调用BookDAO中的findByPrice方法来查询数据库,并将结果显示在表格中。需要注意的是,这个JSP页面仅用于演示如何使用DAO和VO模式,实际应用中应该使用MVC或其他更合适的架构。
2、在数据库中建立表格T_BOOK(BOOKID,BOOKNAME,BOOKPRICE),插入一些记录。制作一个查询页面,输入两个数字,显示价格在这两个数字之间的图书信息。使用PreparedStatment命令执行sql,要求使用Java Bean技术的DAO和VO模式实现。
好的,这是一个关于数据库的问题,我会尽力回答。首先,我们需要在数据库中建立表格T_BOOK,可以使用如下的SQL语句:
```
CREATE TABLE T_BOOK (
BOOKID INT NOT NULL AUTO_INCREMENT,
BOOKNAME VARCHAR(50) NOT NULL,
BOOKPRICE DECIMAL(10,2) NOT NULL,
PRIMARY KEY (BOOKID)
);
```
接着,我们需要插入一些记录:
```
INSERT INTO T_BOOK (BOOKNAME, BOOKPRICE) VALUES ('Java入门', 68.00);
INSERT INTO T_BOOK (BOOKNAME, BOOKPRICE) VALUES ('Spring实战', 98.00);
INSERT INTO T_BOOK (BOOKNAME, BOOKPRICE) VALUES ('MyBatis深入浅出', 88.00);
INSERT INTO T_BOOK (BOOKNAME, BOOKPRICE) VALUES ('Python编程', 78.00);
INSERT INTO T_BOOK (BOOKNAME, BOOKPRICE) VALUES ('数据结构与算法', 58.00);
```
然后,我们可以使用Java Bean技术的DAO和VO模式实现查询功能。首先,我们创建一个Book类作为VO(Value Object):
```
public class Book {
private int bookId;
private String bookName;
private double bookPrice;
// 省略getter和setter方法
}
```
然后,我们创建一个BookDao类作为DAO(Data Access Object):
```
public class BookDao {
public List<Book> queryBooks(double minPrice, double maxPrice) throws SQLException {
Connection conn = null;
PreparedStatement pstmt = null;
ResultSet rs = null;
List<Book> bookList = new ArrayList<Book>();
try {
conn = DbUtil.getConnection();
String sql = "SELECT BOOKID, BOOKNAME, BOOKPRICE FROM T_BOOK WHERE BOOKPRICE >= ? AND BOOKPRICE <= ?";
pstmt = conn.prepareStatement(sql);
pstmt.setDouble(1, minPrice);
pstmt.setDouble(2, maxPrice);
rs = pstmt.executeQuery();
while (rs.next()) {
Book book = new Book();
book.setBookId(rs.getInt("BOOKID"));
book.setBookName(rs.getString("BOOKNAME"));
book.setBookPrice(rs.getDouble("BOOKPRICE"));
bookList.add(book);
}
} finally {
DbUtil.close(rs, pstmt, conn);
}
return bookList;
}
}
```
其中,DbUtil是一个数据库工具类,负责获取数据库连接、关闭连接等操作。可以参考如下的实现:
```
public class DbUtil {
// 数据库连接参数
private static final String URL = "jdbc:mysql://localhost:3306/test";
private static final String USER = "root";
private static final String PASSWORD = "root";
// 获取数据库连接
public static Connection getConnection() throws SQLException {
return DriverManager.getConnection(URL, USER, PASSWORD);
}
// 关闭数据库连接
public static void close(ResultSet rs, Statement stmt, Connection conn) {
try { if (rs != null) rs.close(); } catch (SQLException e) { e.printStackTrace(); }
try { if (stmt != null) stmt.close(); } catch (SQLException e) { e.printStackTrace(); }
try { if (conn != null) conn.close(); } catch (SQLException e) { e.printStackTrace(); }
}
}
```
最后,我们可以在Servlet中调用BookDao的queryBooks方法,获取符合条件的图书信息,并将其展示在JSP页面上。
```
public class BookServlet extends HttpServlet {
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
double minPrice = Double.parseDouble(request.getParameter("minPrice"));
double maxPrice = Double.parseDouble(request.getParameter("maxPrice"));
BookDao bookDao = new BookDao();
try {
List<Book> bookList = bookDao.queryBooks(minPrice, maxPrice);
request.setAttribute("bookList", bookList);
request.getRequestDispatcher("/book_list.jsp").forward(request, response);
} catch (SQLException e) {
e.printStackTrace();
}
}
}
```
在JSP页面上,我们可以使用JSTL标签库展示查询结果:
```
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
...
<table>
<tr>
<th>书名</th>
<th>价格</th>
</tr>
<c:forEach items="${bookList}" var="book">
<tr>
<td>${book.bookName}</td>
<td>${book.bookPrice}</td>
</tr>
</c:forEach>
</table>
```
阅读全文