Mysql数据库 (JTree应用)
package com.databases.jtree; import java.awt.FlowLayout;
import java.awt.GridLayout;
import java.awt.event.MouseAdapter;
import java.awt.event.MouseEvent;
import java.awt.event.MouseListener;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.ResultSetMetaData;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.ArrayList; import javax.swing.JFrame;
import javax.swing.JOptionPane;
import javax.swing.JPanel;
import javax.swing.JScrollPane;
import javax.swing.JTable;
import javax.swing.JTree;
import javax.swing.plaf.PanelUI;
import javax.swing.table.DefaultTableModel;
import javax.swing.tree.DefaultMutableTreeNode;
import javax.swing.tree.TreePath; public class MainFrame extends JFrame {
private Connection conn; // 数据库连接对象
ResultSet rs;
Statement st;
private JTree tree;
ArrayList<String> list = new ArrayList<>();
private DefaultMutableTreeNode databases;
public static JTable jtable;
public static JScrollPane jScrollPane; public static JPanel p1 = new JPanel();
public static JPanel p2 = new JPanel();
public static JPanel p3 = new JPanel(); public static void main(String[] args) throws SQLException {
new MainFrame();
} public MainFrame() throws SQLException {
super("数据库管理");
this.setBounds(400, 300, 780, 480);
this.setDefaultCloseOperation(EXIT_ON_CLOSE);
this.getContentPane().setLayout(new FlowLayout(FlowLayout.LEFT));
databases = new DefaultMutableTreeNode("数据库管理 ");
tree = new JTree(databases);
tree.setSize(600, 600);
tree.setLocation(400, 300); p2.add(new JScrollPane(tree));
p3.add(jScrollPane = new JScrollPane(jtable));
p1.setLayout(new GridLayout(1, 2));
p1.add(p2);
p1.add(p3);
this.add(p1); conDB("information_schema");
String sql = "SELECT SCHEMA_NAME FROM information_schema.SCHEMATA";
rs = st.executeQuery(sql);
while (rs.next()) {
System.out.println(rs.getString("SCHEMA_NAME"));
list.add(rs.getString("SCHEMA_NAME"));
}
closeDB(); for (int i = 0; i < list.size(); i++) {
DefaultMutableTreeNode roots = new DefaultMutableTreeNode(list.get(i));
databases.add(roots);
conDB("information_schema");
String sql1 = "SELECT TABLE_NAME FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_SCHEMA = '" + list.get(i)
+ "';";
rs = st.executeQuery(sql1);
while (rs.next()) {
System.out.println(rs.getString("TABLE_NAME"));
DefaultMutableTreeNode tables = new DefaultMutableTreeNode(rs.getString("TABLE_NAME"));
roots.add(tables);
}
closeDB();
}
MouseListener ml = new MouseAdapter() {
public void mousePressed(MouseEvent e) {
int selRow = tree.getRowForLocation(e.getX(), e.getY());
TreePath selPath = tree.getPathForLocation(e.getX(), e.getY());
if (selRow != -1) {
if (e.getClickCount() == 1) {
try {
mySingleClick(selRow, selPath);
} catch (SQLException e1) {
e1.printStackTrace();
}
System.out.println("长度" + selPath.getPathCount());
}
}
}
}; tree.addMouseListener(ml);
this.setVisible(true);
}
public void mySingleClick(int selRow, TreePath selPath) throws SQLException {
if (selPath.getPathCount() == 3) {
String tableName = selPath.getLastPathComponent().toString();
String databasesName = selPath.getPathComponent(1).toString();
conDB(databasesName);
JTable jtable = new JTable();
jtable= query(tableName);
p3.removeAll();
jScrollPane = new JScrollPane(jtable);
p3.add(MainFrame.jScrollPane);
p3.updateUI();
closeDB();
}
}
// 以下是连接数据库
public void conDB(String DBName) {
try {
// 加载数据库驱动
Class.forName("com.mysql.jdbc.Driver");
} catch (ClassNotFoundException e) {
JOptionPane.showMessageDialog(null, "数据库加载失败!");
}
try {
// 连接数据库
String url = "jdbc:mysql://localhost:3306/" + DBName + "";
System.out.println(url);
String user = "root";
String passwd = "10521";
conn = DriverManager.getConnection(url, user, passwd);
st = conn.createStatement();
} catch (SQLException e) {
JOptionPane.showMessageDialog(null, "数据库连接失败!");
}
} // 以下是关闭数据库
public void closeDB() {
try {
conn.close();
} catch (SQLException e) {
JOptionPane.showMessageDialog(null, "数据库关闭失败!");
}
} public JTable query(String table) throws SQLException {
DefaultTableModel tablemodel = new DefaultTableModel();
String sql = "SELECT * FROM " + table + ";";
Statement stmt = this.conn.createStatement(); // 创建语句对象
ResultSet rest = stmt.executeQuery(sql); // 执行数据查询SELECT语句
ResultSetMetaData rsmd = rest.getMetaData(); // 返回表属性对象
int count = rsmd.getColumnCount(); // 获得列数
for (int j = 1; j <= count; j++) // 将各列名添加到表格模型作为标题,列序号>=1
tablemodel.addColumn(rsmd.getColumnLabel(j)); // 将结果集中各行数据添加到表格模型
Object[] columns = new Object[count]; // 创建对象数组,数组长度为列数
while (rest.next()) // 迭代遍历结果集,从前向后访问每行
{
for (int j = 1; j <= columns.length; j++) // 获得每行各列值
columns[j - 1] = rest.getString(j);
tablemodel.addRow(columns); // 表格模型添加一行,参数指明各列值
}
rest.close();
stmt.close();
return new JTable(tablemodel);
}
}
Mysql数据库 (JTree应用)的更多相关文章
- nodejs进阶(6)—连接MySQL数据库
1. 建库连库 连接MySQL数据库需要安装支持 npm install mysql 我们需要提前安装按mysql sever端 建一个数据库mydb1 mysql> CREATE DATABA ...
- 当忘记mysql数据库密码时如何进行修改
因为长时间没有使用数据库了,或者把密码改完之后就忘了数据库密码,不能正常进入数据库,也无法修改密码,有一个简单的常用修改密码方式: 1.首先找到和打开mysql.exe和mysqld.exe所在的文件 ...
- MySQL数据库和InnoDB存储引擎文件
参数文件 当MySQL示例启动时,数据库会先去读一个配置参数文件,用来寻找数据库的各种文件所在位置以及指定某些初始化参数,这些参数通常定义了某种内存结构有多大等.在默认情况下,MySQL实例会按照一定 ...
- 一起学微软Power BI系列-使用技巧(1)连接Oracle与Mysql数据库
说起Oracle数据库,以前没用过Oracle不知道,但是这1年用Oracle后,发现真的是想狂吐槽,特别是那个.NET驱动和链接字符串,特别奇葩.总归是和其他数据库不一样,标新立异,不知道为何.另外 ...
- CentOS下mysql数据库常用命令总结
mysql数据库使用总结 本文主要记录一些mysql日常使用的命令,供以后查询. 1.更改root密码 mysqladmin -uroot password 'yourpassword' 2.远程登陆 ...
- [原创]java使用JDBC向MySQL数据库批次插入10W条数据测试效率
使用JDBC连接MySQL数据库进行数据插入的时候,特别是大批量数据连续插入(100000),如何提高效率呢?在JDBC编程接口中Statement 有两个方法特别值得注意:通过使用addBatch( ...
- mysql数据库主从同步
环境: Mater: CentOS7.1 5.5.52-MariaDB 192.168.108.133 Slave: CentOS7.1 5.5.52-MariaDB 192.168. ...
- PDO连接mysql数据库
1.PDO简介 PDO(PHP Data Object) 是PHP 5 中加入的东西,是PHP 5新加入的一个重大功能,因为在PHP 5以前的php4/php3都是一堆的数据库扩展来跟各个数据库的连接 ...
- mysql数据库开发常见问题及优化
mysql 数据库是被广泛应用的关系型数据库,其体积小.支持多处理器.开源并免费的特性使其在 Internet 中小型网站中的使用率尤其高.在使用 mysql 的过程中不规范的 SQL 编写.非最优的 ...
随机推荐
- Java学习路线思维导图
- 承接AR定制AR项目外包(正规公司,内附案例)
京团队长年承接AR项目外包 咨询QQ:372900288 微信:liuxiang0884 以下是AR项目案例演示,索取更多案例请通过以上方式在线联系我们
- Delphi XE5 Android 调用手机震动
uses Androidapi.JNI.Os, Androidapi.JNIBridge; function GetVibratorArray(const AIntArr: array of Int6 ...
- flask-appbuilder +echarts 展示数据笔记
pip install flask-appbuilder fabmanager create-app cd newapp fabmanager create-admin fabmanager run ...
- 解决python3.5无法导入cv2.so的问题
问题描述: 在python3.5环境中导入cv2报错,在python2.7中正常.注:命令行的前缀RL_2018HW是python3.5的环境. (RL_2018HW) gordon@gordon-: ...
- element-ui的不稳定性
伤脑筋的版本升级 element-ui升级到2.0版本了! element-ui作为比较成熟的广为人知的前端框架,原本满怀热情的去学习,也基于element-ui搭建出了一套系统,可是它居然升级了! ...
- Pyhon文件的用途
Python1个文件2种用途: 当文件被当做脚本运行时 __name__='__main__'当模块被导入使用 __name__='spam' ==>等于模块名 假定spam代码如下 money ...
- ZooKeeper和CAP理论及一致性原则
一.CAP理论概述CAP理论告诉我们,一个分布式系统不可能同时满足以下三种 一致性(C:Consistency)可用性(A:Available)分区容错性(P:Partition Tolerance) ...
- MySQL Antelope和Barracuda的区别分析
Antelope是innodb-base的文件格式,Barracude是innodb-plugin后引入的文件格式,同时Barracude也支持Antelope文件格式.两者区别在于: 文件格式 支持 ...
- C#将对象序列化成JSON字符串
C#将对象序列化成JSON字符串 public string GetJsonString() { List<Product> products = new List<Product& ...