java從資料庫中讀取資料產生xml儲存到TreeMap中

來源:互聯網
上載者:User

標籤:blog   java   os   io   資料   for   ar   cti   

package data;import java.io.StringWriter;import java.sql.Connection;import java.sql.DriverManager;import java.sql.ResultSet;import java.sql.Statement;import java.util.HashMap;import javax.xml.parsers.DocumentBuilder;import javax.xml.parsers.DocumentBuilderFactory;import javax.xml.transform.Transformer;import javax.xml.transform.TransformerFactory;import javax.xml.transform.dom.DOMSource;import javax.xml.transform.stream.StreamResult;import org.w3c.dom.Document;import org.w3c.dom.Element;public class DataSet {private HashMap<String,String> tm = new HashMap<String,String>();public void init(){try{//1.載入驅動Class.forName("com.mysql.jdbc.Driver");//2、擷取connectionString url = "jdbc:mysql://localhost:3306/mydb";Connection conn = DriverManager.getConnection(url,"neo","neo");//3、建立statementStatement stmt =conn.createStatement();//4、利用statement執行sqlString sql = "select id, name, sex, age from user";ResultSet rs = stmt.executeQuery(sql);DocumentBuilderFactory dFact = DocumentBuilderFactory.newInstance();DocumentBuilder build = dFact.newDocumentBuilder(); TransformerFactory tFact = TransformerFactory.newInstance();while(rs.next()){Document doc = build.newDocument();Element user = doc.createElement("user");doc.appendChild(user); Element name = doc.createElement("name");name.appendChild(doc.createTextNode(rs.getString(2)));user.appendChild(name);Element sex = doc.createElement("sex");sex.appendChild(doc.createTextNode(rs.getString(3)));user.appendChild(sex);Element age = doc.createElement("age");age.appendChild(doc.createTextNode(rs.getString(4)));user.appendChild(age); Transformer trans = tFact.newTransformer();           StringWriter writer = new StringWriter();  StreamResult result = new StreamResult(writer);  DOMSource source = new DOMSource(doc);  trans.transform(source, result);String skey = rs.getString(1);String sValue = writer.toString();tm.put(skey, sValue);}conn.close();}catch(Exception e){e.printStackTrace();}}public String getValue(String key){return tm.get(key);}}

  

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.