亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

java學(xué)生信息管理系統(tǒng)設(shè)計

 更新時間:2020年04月08日 10:24:09   作者:xanlv  
這篇文章主要為大家詳細介紹了java學(xué)生信息管理系統(tǒng)設(shè)計,學(xué)生信息添加進入數(shù)據(jù)庫的事務(wù),具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文實例為大家分享了java學(xué)生信息管理系統(tǒng)的具體代碼,供大家參考,具體內(nèi)容如下

本例的學(xué)生信息添加進入數(shù)據(jù)庫的事務(wù)(可以提交事務(wù),事務(wù)回滾,用本地線程完善)

主頁面index.jsp

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
<html>
 <head>

 <title>學(xué)生信息管理</title>
 </head>

 <body>
 <a href='<c:url value="/query"/>?cmd=query'>查看學(xué)生信息</a>
 <br><br>
 <!-- 
 <a href="<c:url value='/StudServlet?cmd=save' />">學(xué)生信息添加</a>
 -->
 <h2>學(xué)生信息添加</h2>
 <form action='<c:url value="/query"/>?cmd=add' method="post">
 姓名:<input type="text" name="name"/><br><br>

 <fieldset style="border: solid;border-color: red;width: 250px;">
 <legend>圖書1</legend>
 書名:<input type="text" name="book"/><br><br>
 價格:<input type="text" name="price"/>
 </fieldset>
 <br>
 <fieldset style="border: solid;border-color:green;width: 250px;">
 <legend>圖書2</legend>
 書名:<input type="text" name="book"/><br><br>
 價格:<input type="text" name="price"/>
 </fieldset>
 <br><br>
 <input type="submit" value="提交"/><br><br>
 </form>
 </body>
</html>

獲取數(shù)據(jù)庫連接的工具ConnUtils5.java

package cn.hncu.utils;

import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
import java.lang.reflect.Proxy;
import java.sql.Connection;
import java.sql.DriverManager;
import java.util.ArrayList;
import java.util.List;
import java.util.Properties;

public class ConnUtils5 {

 //本地線程管理對象,用于實現(xiàn): 同一個線程獲取的連接是同一個
 private static ThreadLocal< Connection> t=new ThreadLocal<Connection>();
 private final static List<Connection> pool=new ArrayList<Connection>();
 private static int SIZE;//由資源文件讀取
 private ConnUtils5(){

 }
 static{
 Properties p=new Properties();
 try {
 //下面這種方式在純Java項目中可以讀取到classpath下的資源文件,但無法讀取JavaEE項目的。因為Tomcat把系統(tǒng)的默認(rèn)類加載器改了
 //p.load( ClassLoader.getSystemClassLoader().getSystemResourceAsStream("jdbc.properties"));
// p.load(ClassLoader.getSystemResourceAsStream("jdbc.properties"));

 //讀取Web項目的classpath下的資源文件,用這個可以
 p.load(ConnUtils3.class.getClassLoader().getResourceAsStream("jdbc.properties"));
 String driver=p.getProperty("driver");
 String url=p.getProperty("url");
 String name=p.getProperty("username");
 String pwd=p.getProperty("password");
 String ssize=p.getProperty("size");
 SIZE=Integer.parseInt(ssize);
 Class.forName(driver);
 for(int i=0;i<SIZE;i++){
 final Connection con=DriverManager.getConnection(url,name,pwd);
 System.out.println("con=="+con);
 //更改conn.close()方法
 //用代理模式生成一個增強版的conn對象,把它的close()方法攔截更改掉
 Object nCon=Proxy.newProxyInstance(
 ConnUtils3.class.getClassLoader(), 
 // conn.getClass().getInterfaces(), 
 //后面這種方式不行,應(yīng)該是驅(qū)動中的實現(xiàn)類和我們當(dāng)前程序不在同一空間(類加載器不同) 
 new Class[]{Connection.class}, 
 new InvocationHandler() {
 @Override
 public Object invoke(Object proxy, Method method, Object[] args)
 throws Throwable {
 if(method.getName().equals("close")){
 System.out.println("還回一個鏈接:"+(Connection)proxy);
 pool.add((Connection)proxy);
 return null;
 }
 return method.invoke(con, args);
 }
 });
 pool.add((Connection)nCon);
 }
 } catch (Exception e) {
 e.printStackTrace();
 }
 }
 public static synchronized Connection getConnection(){
 //先從t中拿,如果有就拿出去,如果沒有再到池中拿且把該對象放到t中
 Connection con=t.get();
 if(con==null){

 if(pool.size()<=0){
 System.out.println("池中連接沒有了...");
 try {
 Thread.sleep(1000);
 } catch (InterruptedException e) {
 e.printStackTrace();
 }
 return getConnection();
 }
 con=pool.remove(0);
 t.set(con);//放到t中
 }

 return con;//拿一個移一個
 }


}

資源文件jdbc.properties

##MySQL
driver=com.mysql.jdbc.Driver
url=jdbc:mysql://127.0.0.1:3306/hncu?useUnicode=true&characterEncoding=utf-8
username=root
password=1234
size=3
##Oracle
#driver=oracle.jdbc.driver.OracleDriver
#url=jdbc:oracle:thin:@127.0.0.1:1521:orcl
#username=scott
#password=tiger

值對象
Stud.java

package cn.hncu.domain;

import java.util.ArrayList;
import java.util.List;
/*
 * 一對多中的 “一”方 值對象的建法
 */
public class Stud {

 private String id;
 private String name;
 //※專為“多”方添加一個集合---體現(xiàn)多表中的“一對多關(guān)系”
 private List<Book> books=new ArrayList<Book>();//注意,該集合要在構(gòu)造時或之前就new出來。
 public String getId() {
 return id;
 }
 public void setId(String id) {
 this.id = id;
 }
 public String getName() {
 return name;
 }
 public void setName(String name) {
 this.name = name;
 }



 public List<Book> getBooks() {
 return books;
 }
 public void setBooks(List<Book> books) {
 this.books = books;
 }
 @Override
 public String toString() {
 return "id=" + id + "," + name + "," + books;
 }

}

Book.java

package cn.hncu.domain;
/*
 * 一對多中的 “多”方 值對象的建法
 */
public class Book {

 private Integer id;
 //基本數(shù)據(jù)類型全部用包裝類的聲明,為以后使用框架做技術(shù)準(zhǔn)備---包裝類能夠兼容框架(因為一般框架都會使用類反射)
 private String name;
 private Double price;
 //※專為“一”方添加一個對象類型的變量(注意,不用studid)---體現(xiàn)多表中的“一對多關(guān)系”
 private Stud s;//設(shè)置主人
 //private String studid;//★★不要這樣設(shè)
 public Integer getId() {
 return id;
 }
 public void setId(Integer 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 Stud getS() {
 return s;
 }
 public void setS(Stud s) {
 this.s = s;
 }
 /*
 * 多表關(guān)聯(lián)時的toString()方法要注意一個陷阱,就是一方輸出另一方,同時另一方又反過來輸出前一方,形成無窮遞歸!
 */
 @Override
 public String toString() {
 return "id=" + id + "," + name + "," + price;//這里不能輸出Stud對象,否則無窮遞歸
 }

}

stud層的servlet層–QueryServlet.java

package cn.hncu.stud.servlet;

import java.io.IOException;
import java.util.List;
import java.util.Map;

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

import cn.hncu.domain.Book;
import cn.hncu.domain.Stud;
import cn.hncu.stud.service.IStudService;
import cn.hncu.stud.service.StudServiceImpl;

public class QueryServlet extends HttpServlet {

 //注入
 IStudService service=new StudServiceImpl();
 public void doGet(HttpServletRequest request, HttpServletResponse response)
 throws ServletException, IOException {

 doPost(request, response);
 }


 public void doPost(HttpServletRequest request, HttpServletResponse response)
 throws ServletException, IOException {
 String cmd=request.getParameter("cmd");
 System.out.println("cmd:"+cmd);
 if("query".equals(cmd)){
 query(request, response);
 }else if("add".equals(cmd)){
 add(request, response);
 }
 }


 public void query(HttpServletRequest request, HttpServletResponse response)
 throws ServletException, IOException {
 List<Map<String, String>> studs=service.query();
 request.setAttribute("studs", studs);
 request.getRequestDispatcher("/jsps/show.jsp").forward(request, response);
 }
 public void add(HttpServletRequest request, HttpServletResponse response)
 throws ServletException, IOException {
 //1收集參數(shù) 2組織參數(shù)(id字段留到dao中去補)
 String name[]=request.getParameterValues("name");
 System.out.println(name[0]);
 Stud s=new Stud();
 s.setName(name[0]);
 //圖書信息
 String books[]=request.getParameterValues("book");
 //防護一下 ---價格的防護應(yīng)該也要寫,這里我們偷懶了
 if(books==null||books.length<=0){
 return;
 }
 String prices[]=request.getParameterValues("price");
 for(int i=0;i<books.length;i++){
 Book b=new Book();
 b.setName(books[i]);
 b.setPrice(Double.parseDouble(prices[i]));
 //※完成兩個值對象的“一對多”關(guān)系的數(shù)據(jù)封裝
 s.getBooks().add(b);//一方
 b.setS(s);//多方
 }
 //3調(diào)用service層
 try {
 service.save(s);
 } catch (Exception e) {
 //導(dǎo)向失敗頁面
 }

 }

}

stud層的service層–
接口:

package cn.hncu.stud.service;

import java.util.List;
import java.util.Map;

import cn.hncu.domain.Stud;

public interface IStudService {

 public List<Map<String, String>> query();
 public void save(Stud stud);
}

實現(xiàn)類

package cn.hncu.stud.service;


import java.sql.Connection;
import java.sql.SQLException;
import java.util.List;
import java.util.Map;

import cn.hncu.domain.Stud;
import cn.hncu.stud.dao.BookDAO;
import cn.hncu.stud.dao.BookJdbcDao;
import cn.hncu.stud.dao.StudDAO;
import cn.hncu.stud.dao.StudJdbcDAO;
import cn.hncu.utils.ConnUtils3;

/*我們以后開發(fā)時通常都要采用一個dao獨立操作一個表,系統(tǒng)中有幾個實體表就寫幾個dao,
 * 以后框架都是這么干的,我們也要這樣做,因為架構(gòu)好!
 * 
 * 采用事務(wù)的場合:
 * 1、如果只有一個dao,但要執(zhí)行多條sql語句且涉及增刪改,則要開啟事務(wù)
 * 2、如果一個service調(diào)用多個dao,通常也要開啟事務(wù)。
 */
public class StudServiceImpl implements IStudService {

 //注入
 StudDAO dao_stud=new StudJdbcDAO();
 BookDAO dao_book=new BookJdbcDao();
 @Override
 public List<Map<String, String>> query() {
 return dao_stud.query();
 }
 @Override
 public void save(Stud stud) {
 Connection con=null;

 try {
 con=ConnUtils3.getConnection();
 System.out.println("拿到一個鏈接:"+con);
 con.setAutoCommit(false);
 dao_stud.save(stud);
 dao_book.save(stud.getBooks());

 System.out.println("提交一個事務(wù)...");
 con.commit();
 } catch (Exception e) {
 try {
 System.out.println("回滾一個事務(wù)...");
 con.rollback();
 } catch (SQLException e1) {
 e1.printStackTrace();
 }
 }finally{
 try {
 con.setAutoCommit(true);
 con.close();
 } catch (SQLException e) {
 e.printStackTrace();
 }
 }
 }

}

stud層的dao層–
Stud接口

package cn.hncu.stud.dao;

import java.util.List;
import java.util.Map;

import cn.hncu.domain.Stud;

public interface StudDAO {

 public List<Map<String, String>> query();
 public void save(Stud stud) throws Exception;
}

Stud實現(xiàn)類

package cn.hncu.stud.dao;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.UUID;

import cn.hncu.domain.Book;
import cn.hncu.domain.Stud;
import cn.hncu.utils.ConnUtils3;

public class StudJdbcDAO implements StudDAO {

 @Override
 public List<Map<String, String>> query() {
 List<Map<String, String>> list=new ArrayList<Map<String,String>>();
 //一個map就是一行數(shù)據(jù), List<Map>就是整個數(shù)據(jù)表
 Connection con=null;
 try {
 con=ConnUtils3.getConnection();
 Statement st=con.createStatement();
 String sql="select * from stud";
 ResultSet rs=st.executeQuery(sql);
 while(rs.next()){
 Map<String,String> m=new HashMap<String, String>();
 m.put("id", (String) rs.getObject(1));
 m.put("name", (String) rs.getObject(2));
 list.add(m);
 }
 rs.close();
 st.close();
 } catch (SQLException e) {
 e.printStackTrace();
 }finally{
 try {
 con.close();
 } catch (SQLException e) {
 e.printStackTrace();
 }
 }


 return list;
 }

 @Override
 public void save(Stud stud) throws Exception {
 Connection con=ConnUtils3.getConnection();
 System.out.println("拿到一個鏈接:"+con);
 String sql="insert into stud values(?,?)";
 String uuid=UUID.randomUUID().toString().replace("-", "");
 PreparedStatement pst=con.prepareStatement(sql);
 stud.setId(uuid);//為了"多方"即book能夠拿到"一方"的id,專門補的
 pst.setString(1, uuid);
 pst.setString(2, stud.getName());
 System.out.println("1:"+uuid+",2:"+stud.getName());
 pst.executeUpdate();
// con.close();//拿到同一個con,這里就不需要關(guān)了
 }

}

Book接口

package cn.hncu.stud.dao;

import java.util.List;

import cn.hncu.domain.Book;

public interface BookDAO {

 public void save(List<Book> books) throws Exception;
}

Book實現(xiàn)類

package cn.hncu.stud.dao;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.util.List;

import cn.hncu.domain.Book;
import cn.hncu.utils.ConnUtils3;

public class BookJdbcDao implements BookDAO {

 @Override
 public void save(List<Book> books) throws Exception {
 Connection con=ConnUtils3.getConnection();
 System.out.println("拿到一個鏈接:"+con);
 String sql="insert into book(name,price,studid) values(?,?,?)";
 PreparedStatement pst=con.prepareStatement(sql);
 for(Book b:books){
 pst.setString(1, b.getName());
 pst.setDouble(2, b.getPrice());
 pst.setObject(3, "12132312");//異常(故意給一個不存在的外鍵字段,以測試事務(wù)回滾)--測事務(wù)回滾
// pst.setObject(3, b.getS().getId());
 System.out.println("1:"+b.getName()+",2:"+b.getPrice()+",3:"+b.getS().getId());
 pst.addBatch();//添加到批處理
 }
 pst.executeBatch();//執(zhí)行批處理

// con.close();//這里拿到同一個con,這里不需要關(guān)

 }

}

顯示學(xué)生信息頁面jsps/show.jsp

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
<html>
 <head>

 <title>學(xué)生信息管理</title>
 </head>

 <body>
 <h2>學(xué)生信息</h2>
 <c:forEach items="${studs}" var="x">
 ${x.id},${x.name}<br/>
 </c:forEach>
 </body>
</html>

效果圖:

關(guān)于管理系統(tǒng)的更多內(nèi)容請點擊《管理系統(tǒng)專題》進行學(xué)習(xí)

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Java可重入鎖的實現(xiàn)示例

    Java可重入鎖的實現(xiàn)示例

    在java中,可重入鎖分為兩種,即synchronized鎖以及ReentrantLock及其實現(xiàn),文中通過示例代碼介紹的非常詳細,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2024-02-02
  • IDEA 中創(chuàng)建并部署 JavaWeb 程序的方法步驟(圖文)

    IDEA 中創(chuàng)建并部署 JavaWeb 程序的方法步驟(圖文)

    本文主要介紹了IDEA 中創(chuàng)建并部署 JavaWeb 程序的方法步驟,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-02-02
  • Java5種遍歷HashMap數(shù)據(jù)的寫法

    Java5種遍歷HashMap數(shù)據(jù)的寫法

    這篇文章主要介紹了Java5種遍歷HashMap數(shù)據(jù)的寫法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-03-03
  • SpringBoot如何訪問jsp頁面

    SpringBoot如何訪問jsp頁面

    本文介紹了如何在Spring Boot項目中進行Web開發(fā),包括創(chuàng)建項目、配置文件、添加依賴、控制層修改、測試效果以及在IDEA中進行配置的詳細步驟
    2025-01-01
  • Java實現(xiàn)瀏覽器大文件上傳的示例詳解

    Java實現(xiàn)瀏覽器大文件上傳的示例詳解

    文件上傳是許多項目都有的功能,用戶上傳小文件速度一般都很快,但如果是大文件幾個g,幾十個g的時候,上傳了半天,馬上就要完成的時候,網(wǎng)絡(luò)波動一下,文件又要重新上傳,所以本文給大家介紹了Java實現(xiàn)瀏覽器大文件上傳的示例,需要的朋友可以參考下
    2024-07-07
  • Struts2 $,#,%詳解及實例代碼

    Struts2 $,#,%詳解及實例代碼

    這篇文章主要介紹了Struts2 $,#,%詳解及實例代碼的相關(guān)資料,需要的朋友可以參考下
    2016-12-12
  • 解決報java.lang.AssertionError錯誤的問題

    解決報java.lang.AssertionError錯誤的問題

    這篇文章主要介紹了解決報java.lang.AssertionError錯誤的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-05-05
  • IntelliJ IDEA使用SVN分支的簡單介紹

    IntelliJ IDEA使用SVN分支的簡單介紹

    今天小編就為大家分享一篇關(guān)于IntelliJ IDEA使用SVN分支的簡單介紹,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2018-10-10
  • Spring組件開發(fā)模式支持SPEL表達式

    Spring組件開發(fā)模式支持SPEL表達式

    今天小編就為大家分享一篇關(guān)于Spring組件開發(fā)模式支持SPEL表達式,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2018-12-12
  • Java Linkedlist原理及實例詳解

    Java Linkedlist原理及實例詳解

    這篇文章主要介紹了Java Linkedlist原理及實例詳解,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-01-01

最新評論