元数据管理小工具。
作用:可以自动将所有的表信息和字段信息存入元数据表中,便于统一查阅。(注释需要保证库本身已经包含了对于表和字段的注释)
用于为数据库提供两张表。 meta_field
, meta_model
。
表名称 | 说明 |
---|---|
meta_model | 用于存放所有的表信息。(包含元数据表) |
meta_field | 用于存放所有的表字段信息。(包含元数据表) |
数据库 | 是否支持 | 测试版本 |
---|---|---|
MySQL | YES | 5.5, 5.6 |
SQL Server | YES | 2008 R2 |
Oracle | NO | |
MongoDB | NO |
备注:测试条件限制,只对手中的数据库版本进行了测试验证。
问题:有没有一种环境,可以模拟各个版本的数据库?
- 思考
数据库的种类繁多,不胜枚举。应该为每一个数据库提供好可覆写的方法。脚本分类提前留好地方。
不同的数据库脚本是不同的。可以使用 PowerDesigner 进行统一生成设计。(mac DbWrench Database)
你需要熟悉 maven,tomcat,jdk
- 方式一
直接点击下载本项目:https://github.com/houbb/metadata。
- 方式二
使用 Git 直接签入到本地:
git clone https://github.com/houbb/metadata
将下载的项目用编辑器打开。推荐 IDEA
本项目 jar 管理使用 Maven,请确保已正确配置。
在根目录运行命令打包:
mvn clean install
有两种方式:
- tomcat
将编译生成的 war
部署到 Tomcat 运行。
- tomcat7 plugin(推荐)
运行模块 metadata-web 下的 maven tomcat7 插件。
默认的 tomcat7 plugin 端口号为 18082。
任意浏览器打开 http://localhost:18082/ 即可。
在 mysql 页面指定数据库链接信息,点击【Execute】按钮即可。
- 属性说明
属性 | 描述 | 默认值 |
---|---|---|
Host | 地址 | localhost |
Port | 端口号 | 3306 |
DataBase | 数据库名称 | |
Username | 用户名称 | root |
Password | 密码 | 123456 |
- 测试脚本
CREATE DATABASE `metadata-test`
DEFAULT CHARACTER SET UTF8;
USE `metadata-test`;
CREATE TABLE `user` (
`id` int(11) NOT NULL AUTO_INCREMENT COMMENT '唯一标识',
`username` varchar(255) DEFAULT NULL COMMENT '用户名',
`password` varchar(255) DEFAULT NULL COMMENT '密码',
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=UTF8 COMMENT='用户表';
原始数据如下:
mysql> show tables;
+----------------+
| Tables_in_metadata-test |
+----------------+
| user |
+----------------+
mysql> show tables;
+-------------------------+
| Tables_in_metadata-test |
+-------------------------+
| meta_field |
| meta_model |
| user |
+-------------------------+
- meta_model 内容
mysql> SELECT * FROM meta_model \G;
*************************** 1. row ***************************
ID: 1
uid: cdae6d5ab5bd4e8fac974e6cbfb0d9c1
name: meta_field
dbObjectName: NULL
alias: NULL
description: 元数据字段表
category: NULL
isVisible: 0
isEditable: 0
createTime: 2018-01-18 09:48:20
updateTime: 2018-01-18 09:48:20
*************************** 2. row ***************************
ID: 2
uid: 0869811946e34d9bae22d2ac7940a8d7
name: meta_model
dbObjectName: NULL
alias: NULL
description: 元数据实体表
category: NULL
isVisible: 0
isEditable: 0
createTime: 2018-01-18 09:48:20
updateTime: 2018-01-18 09:48:20
*************************** 3. row ***************************
ID: 3
uid: c94524236260483e9494aa6e5596a787
name: user
dbObjectName: NULL
alias: NULL
description: 用户表
category: NULL
isVisible: 0
isEditable: 0
createTime: 2018-01-18 09:48:20
updateTime: 2018-01-18 09:48:20
3 rows in set (0.01 sec)
和上面类似。
在 sql server 页面指定数据库链接信息,点击【Execute】按钮即可。
- 属性说明
属性 | 描述 | 默认值 |
---|---|---|
Host | 地址 | localhost |
Port | 端口号 | 1433 |
DataBase | 数据库名称 | |
Username | 用户名称 | sa |
Password | 密码 | 123456 |
和上面类似。
在 oracle 页面指定数据库链接信息,点击【Execute】按钮即可。
- 属性说明
属性 | 描述 | 默认值 |
---|---|---|
Host | 地址 | localhost |
Port | 端口号 | 49161 |
Service | oralce 服务名称 | XE |
Username | 用户名称 | system |
Password | 密码 | 123456 |