溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

如何將xml文件作為數(shù)據(jù)庫進(jìn)行學(xué)生的增刪改查

發(fā)布時(shí)間:2021-09-15 09:59:09 來源:億速云 閱讀:119 作者:柒染 欄目:web開發(fā)

如何將xml文件作為數(shù)據(jù)庫進(jìn)行學(xué)生的增刪改查,相信很多沒有經(jīng)驗(yàn)的人對此束手無策,為此本文總結(jié)了問題出現(xiàn)的原因和解決方法,通過這篇文章希望你能解決這個(gè)問題。

1.xml文件:

<?xml version="1.0" encoding="UTF-8"?><Students>
 <student id="2">
  <name>ttt</name>
  <age>44</age>
 </student>
 <student id="3">
  <name>linda2</name>
  <age>22</age>
 </student>
 <student id="4">
  <name>linda3</name>
  <age>23</age>
 </student>
 <student id="5">
  <name>jack</name>
  <age>2</age>
 </student>
 <student id="1">
   <name>yyh2</name>
   <age>22</age>
 </student>
</Students>

2.Java代碼

import java.io.File;
import java.io.IOException;
import java.util.Scanner;

import javax.xml.parsers.ParserConfigurationException;
import javax.xml.transform.Transformer;
import javax.xml.transform.TransformerConfigurationException;
import javax.xml.transform.TransformerException;
import javax.xml.transform.TransformerFactory;
import javax.xml.transform.TransformerFactoryConfigurationError;
import javax.xml.transform.dom.DOMSource;
import javax.xml.transform.stream.StreamResult;

import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.NodeList;
import org.w3c.dom.Text;
import org.xml.sax.SAXException;

//在學(xué)生管理系統(tǒng)里面,學(xué)生的學(xué)號是唯一的,姓名有可能重復(fù)
public class StudentManager {
  public static void main(String[] args) {
    try {
      Document doc = Domutils.getDoc(new File("xml文件的相對路徑"));
      Scanner input = new Scanner(System.in);
      System.out.println("歡迎來到學(xué)生管理系統(tǒng)\n\n\n請輸入你要進(jìn)行什么操作是:\n1.添加學(xué)生信息\n2.刪除學(xué)生信息\n3.修改學(xué)生信息\n(請輸入前邊的序號)");
      int num = input.nextInt();
      if(num == 1) {
        addStudent(doc);
      }else if(num == 2) {
        delStudent(doc);
      }else if(num == 3) {
        updStudent(doc);
      }
    } catch (SAXException e) {
      e.printStackTrace();
    } catch (IOException e) {
      e.printStackTrace();
    } catch (ParserConfigurationException e) {
      e.printStackTrace();
    }
  }
  //修改學(xué)生信息
  private static void updStudent(Document doc) {
    Element updStudent = null;
    Scanner input = new Scanner(System.in);
    System.out.println("請輸入你要修改的學(xué)生的學(xué)號:");
    String studentid = input.nextLine();
    System.out.println("請輸入新學(xué)生的姓名:");
    String newName = input.nextLine();
    System.out.println("請輸入新學(xué)生的年齡:");
    String newAge = input.nextLine();
    
    //將每一個(gè)學(xué)生的列出來,for循環(huán)判斷你要修改信息的學(xué)生是哪一個(gè)
    NodeList list = doc.getElementsByTagName("student");
    for(int i = 0; i <list.getLength(); i++) {
      if(studentid.equals(list.item(i).getAttributes().getNamedItem("id").getNodeValue())){
        updStudent = (Element) doc.getElementsByTagName("student").item(i).getFirstChild().getParentNode();
        //對學(xué)生的name屬性進(jìn)行賦新值
        updStudent.getElementsByTagName("name").item(i).getFirstChild().setNodeValue(newName);
        //對學(xué)生的age 屬性賦新值
        updStudent.getElementsByTagName("age").item(i).getFirstChild().setNodeValue(newAge);
        
      }else{
        break;
      }
    }
    //找出根元素,將修改后的元素持久化到文件
    Element root = doc.getDocumentElement();
    transform(root);
    System.out.println(updStudent);
  }
  //刪除學(xué)生信息
  private static void delStudent(Document doc) {
    Scanner input = new Scanner(System.in);
    //輸入你要刪除的學(xué)生的 學(xué)號
    System.out.println("請輸入要刪除學(xué)生的學(xué)號:");
    String studentid = input.nextLine();
    Element root = doc.getDocumentElement();
    
    //將學(xué)生列成一個(gè)表,進(jìn)行遍歷,找對應(yīng)學(xué)號的學(xué)生進(jìn)行刪除
    NodeList list = doc.getElementsByTagName("student");
    for(int i = 0; i < list.getLength(); i++) {
    if((studentid).equals(list.item(i).getAttributes().getNamedItem("id").getNodeValue())){
      Element delStudent = (Element) doc.getElementsByTagName("student").item(i).getFirstChild().getParentNode(); 
        root.removeChild(delStudent);
        break;
      }else {
        System.out.println("沒有該學(xué)生");
        break;
      }
    }
    //持久化到文件
    transform(root);
  }
  
  //添加學(xué)生信息
  private static void addStudent(Document doc) {
//    System.out.println(doc.getElementsByTagName("student").item(1).getAttributes().getNamedItem("id").getNodeValue());
    Element root = doc.getDocumentElement();
    //從控制臺輸入
    Scanner input = new Scanner(System.in);
    System.out.println("請輸入學(xué)生的序號:id = ");
     
    //將學(xué)生放到一個(gè)列表里面,看我們要添加的學(xué)生的學(xué)號里面是否已經(jīng)有了,如果有,需要將新加入的學(xué)生的學(xué)號改一下
    NodeList list = doc.getElementsByTagName("student");
    String studentid = input.nextLine();
    for(int i = 0; i < list.getLength(); i++) {
      if(studentid.equals(list.item(i).getAttributes().getNamedItem("id").getNodeValue())){
        System.out.println("該序號學(xué)生表里面已經(jīng)存在,請重新輸入一個(gè)新的序號:");
         studentid = input.nextLine();
      }else {
        break;
      }
    }
    
    System.out.println("請輸入要添加學(xué)生的姓名:name = ");
    String name_value = input.nextLine();
    System.out.println("請輸入要添加學(xué)生的年齡:age = ");
    String age_value = input.nextLine();
    
    //創(chuàng)建節(jié)點(diǎn)
    Element student = doc.createElement("student");
    Element name = doc.createElement("name");
    Element age = doc.createElement("age");
    Text namText = doc.createTextNode(name_value);
    Text ageText = doc.createTextNode(age_value);
    //關(guān)聯(lián)節(jié)點(diǎn)之間的關(guān)系
    root.appendChild(student);
    student.appendChild(name);
    student.appendChild(age);
    student.setAttribute("id", studentid);
    name.appendChild(namText);
    age.appendChild(ageText);
    //持久化到文件
    transform(root);
    
  }
  //持久化到文件的方法
  private static void transform(Element root)
      throws TransformerFactoryConfigurationError {
    TransformerFactory factory = TransformerFactory.newInstance();
    try {
      Transformer tf = factory.newTransformer();
      tf.transform(new DOMSource(root), new StreamResult(new File("src/com/briup/dom/student.xml")));
    } catch (TransformerConfigurationException e) {
      e.printStackTrace();
    } catch (TransformerException e) {
      e.printStackTrace();
    }
  }
}

2.Dom解析文件(將獲取解析文件的部分封裝起來)

import java.io.File;
import java.io.IOException;
import java.nio.file.attribute.AclEntry.Builder;

import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException;

import org.w3c.dom.Document;
import org.xml.sax.SAXException;

public class Domutils {
  public static Document getDoc(File file) throws SAXException, IOException, ParserConfigurationException {
      //獲取工廠模式
    DocumentBuilderFactory factory = 
        DocumentBuilderFactory.newInstance();
        //獲取builder對象
      DocumentBuilder builder = factory.newDocumentBuilder();  
        //將要解析文件加載成一個(gè)樹狀文件,開始解析     
      Document document = builder.parse(file);
    return document;
  }
}

看完上述內(nèi)容,你們掌握如何將xml文件作為數(shù)據(jù)庫進(jìn)行學(xué)生的增刪改查的方法了嗎?如果還想學(xué)到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注億速云行業(yè)資訊頻道,感謝各位的閱讀!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI