java 已经获取某个mysql数据库的所有表名 创建JTree

java 已经获取某个mysql数据库的所有表名 创建JTree,第1张

那只能创建一层的JTree ?

import java.sql.Connection  

import java.sql.DriverManager  

import java.sql.ResultSet  

import java.sql.SQLException  

import java.sql.Statement  

  

import javax.swing.JFrame  

import javax.swing.JTree  

import javax.swing.tree.DefaultMutableTreeNode  

  

public class JTreeDemo2 extends JFrame {  

    private Connection con  

    private Statement ste = null  

    ResultSet rs  

  

    JTreeDemo2() {

        super("JTreeDemo")

        this.setSize(200, 200)  

        this.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE)

        OpenDb()

        DefaultMutableTreeNode node = new DefaultMutableTreeNode("所有表")  

        createNodes(node, "0")  

        JTree tree = new JTree(node)  

        this.add(tree)  

        this.setVisible(true)  

    }  

  

    public void createNodes(DefaultMutableTreeNode parent, String ParentID){  

        DefaultMutableTreeNode temp = null  

        String strsql = "show tables"  

        // 光标的相对位置  

        try{  

            rs = ste.executeQuery(strsql)  

            while (rs.next()){  

                temp = new DefaultMutableTreeNode(rs.getString(1))  

                parent.add(temp)  

            }  

        } catch(Exception e){  

            System.out.println(e)  

        }  

    }  

  

    // 连接数据库  

    void OpenDb(){  

        String driver = "com.mysql.jdbc.Driver"  

        String connection = "jdbc:mysql://localhost:3306/test"  

        // 数据库用户名  

        String user = "root"  

        // 数据库密码  

        String password = "root"  

        try {  

            Class.forName(driver)  

        }catch (ClassNotFoundException e) {  

            e.printStackTrace()  

        }  

        try{  

            con = DriverManager.getConnection(connection, user, password)  

            ste = con.createStatement()  

        }catch (SQLException e){  

            e.printStackTrace()  

        }  

    }  

    public static void main(String[] argv) throws Exception {  

        new JTreeDemo2()  

  

    }  

}

JTree组件被用来以树的形式显示数据,一层套一层,看起来清晰明了,使用户很方便地就了解到各个节点之间的层次关系,可以很容易地找到相关的数据。

例如 Windows 系统的文件管理器,它就是一个典型的树层次结构。

JTree的构造函数:

·JTree() 建立一棵默认的树。

·JTree(Hashtable data) 利用Hashtable建立树。

·JTree(Object[] data) 利用数组建立树。

·JTree(TreeModel model) 利用TreeModel建立树。

·JTree(TreeNode root) 建立以root为根的树。

·JTree(TreeNode root,Boolean children) 建立以 root 为根的树,并设定是否允许有子节点。

·JTree(Vector value) 利用Vector建立树。

使用一个JTree可以简单地像下面这样表示:

import javax.swing.JFrame

import javax.swing.JTree

import javax.swing.event.TreeSelectionEvent

import javax.swing.event.TreeSelectionListener

import javax.swing.tree.DefaultMutableTreeNode

 

public class TreeDemo {

    public static void main(String[] args) {

 

        // 创建没有父节点和子节点、但允许有子节点的树节点,并使用指定的用户对象对它进行初始化。

        // public DefaultMutableTreeNode(Object userObject)

        DefaultMutableTreeNode node1 = new DefaultMutableTreeNode("软件部")

        node1.add(new DefaultMutableTreeNode(new User("小花")))

        node1.add(new DefaultMutableTreeNode(new User("小虎")))

        node1.add(new DefaultMutableTreeNode(new User("小龙")))

 

        DefaultMutableTreeNode node2 = new DefaultMutableTreeNode("销售部")

        node2.add(new DefaultMutableTreeNode(new User("小叶")))

        node2.add(new DefaultMutableTreeNode(new User("小雯")))

        node2.add(new DefaultMutableTreeNode(new User("小夏")))

 

        DefaultMutableTreeNode top = new DefaultMutableTreeNode("职员管理")

 

        top.add(new DefaultMutableTreeNode(new User("总经理")))

        top.add(node1)

        top.add(node2)

        final JTree tree = new JTree(top)

        JFrame f = new JFrame("JTreeDemo")

        f.add(tree)

        f.setSize(300, 300)

        f.setVisible(true)

        f.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE)

        // 添加选择事件

        tree.addTreeSelectionListener(new TreeSelectionListener() {

 

            @Override

            public void valueChanged(TreeSelectionEvent e) {

                DefaultMutableTreeNode node = (DefaultMutableTreeNode) tree

                        .getLastSelectedPathComponent()

 

                if (node == null)

                    return

 

                Object object = node.getUserObject()

                if (node.isLeaf()) {

                    User user = (User) object

                    System.out.println("你选择了:" + user.toString())

                }

 

            }

        })

    }

}

 

class User {

    private String name

 

    public User(String n) {

        name = n

    }

 

    // 重点在toString,节点的显示文本就是toString

    public String toString() {

        return name

    }

}


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/10660306.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-10
下一篇 2023-05-10

发表评论

登录后才能评论

评论列表(0条)

保存