## 介绍
[数据源数据集用法总结](https://my.oschina.net/u/4517014/blog/5270828)
- 支持多数据源,内置mysql、elasticsearch、kudu等多种驱动
- 可动态扩展(见下文)
data:image/s3,"s3://crabby-images/7742e/7742e1bc822a453cab5c31341406977c4a9bf2a4" alt="source.png"
## 类型
查看已有的数据源类型。
data:image/s3,"s3://crabby-images/ac6c7/ac6c72c8650ec2612e1b9a7a70b2fdbd477c0301" alt="img2"
data:image/s3,"s3://crabby-images/be6f2/be6f2dd72ea66f047e42b70e465a2ef1a1ee2583" alt="img3"
```text
可以在此页面进行新增数据源配置,也可以去数据库中增加你需要的数据源类型。
表aj_report.gaea_dict_item,字段dict_code:SOURCE_TYPE
表aj_report.gaea_dict_item, item_extend字段是下拉选择后动态表单渲染的json数据
```
## 操作
- 只有测试通过的数据源才可以保存。
data:image/s3,"s3://crabby-images/3fb66/3fb6628a910d0d5e52fe13f6f53b55b8dc18d695" alt="An image"
## 内置数据源
### JDBC数据源
适用于JDBC驱动类数据库,驱动类、连接串、用户名、密码必须填写正确。
data:image/s3,"s3://crabby-images/ac6b4/ac6b4cd5770562a1c01eb5edbd5f8d796b1aa623" alt="img6"
### elasticsearch_sql数据源
目前只支持 elasticsearch 的 x-pack sql。
固定写法:
- 请求路径:http://127.0.0.1:9200/_xpack/sql?format=json
- 请求方式:POST
- 请求头:{"Content-Type":"application/json"}
- 请求体:{"query":"select 1"}
data:image/s3,"s3://crabby-images/21bc1/21bc15fdbb43acfee92b0c1ed18c596e3f25b5d7" alt="img7"
### HTTP数据源
针对http,最好得返回结果是``List``,目前而言,http 数据源操作上可能过于繁琐了些。
支持请求路径和请求头中存在动态数据,采用 ${} 方式进行动态替换,具体操作看数据集的相关说明。
data:image/s3,"s3://crabby-images/c44ee/c44eec575babb7568ba721e89027b52a78861e29" alt="img8"
**注:** Http数据源功能已经移动到Http数据集中,原功能不变,有Http接口数据请直接使用Http数据集,请注意Http接口数据返回格式必须是Json。
## 扩展
### JDBC驱动类数据源添加
**发行版**
```text
1、将jar包上传到 "aj-report.xxx/lib"目录下
2、启动项目(重启项目)
3、前端页面数据源类型选择"jdbc",填上对应的驱动类、连接串、用户名密码
```
data:image/s3,"s3://crabby-images/bfc1b/bfc1ba9e57da7f98b93953688cad81ce658c32d4" alt="img4"
data:image/s3,"s3://crabby-images/6d684/6d6842b42438fb13b559fa94d2d2a63ee2160cf5" alt="img5"
**源码**
源码推荐使用第二种方式。
- 第一种,在report-core/lib目录下添加
按照同样的层级将驱动包放置,使用build.sh脚本进行打包,前端页面数据源类型选择"jdbc"
,填上对应的驱动类、连接串、用户名密码。
**注意:** 此方式添加的jar包只能使用build.sh进行编译后才会生效。
- 第二种,在pom.xml中添加
使用build.sh脚本编译或者maven package编译都可以,前端页面数据源类型选择"jdbc"
,填上对应的驱动类、连接串、用户名密码。
### 非JDBC驱动类数据源添加
例如原生ES、Redis之类。
```text
1、在源码中编写解析代码(datasource)
2、生成数据字典,可在数据字典页面找到"数据源类型",在"操作"栏中选择"编辑字典项"
3、添加对应驱动包
```