123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284 |
- package data
- import (
- "eta/eta_api/models/data_manage"
- "eta/eta_api/services/elastic"
- "eta/eta_api/utils"
- "fmt"
- "strconv"
- "strings"
- )
- func CreateChartInfoIndex() {
- indexName := utils.CHART_INDEX_NAME
- mappingJson := `{
- "mappings": {
- "dynamic": true,
- "properties": {
- "ChartInfoId": {
- "type": "integer"
- },
- "ChartName": {
- "type": "text",
- "term_vector": "with_positions_offsets",
- "analyzer": "ik_smart"
- },
- "ChartClassifyId": {
- "type": "integer"
- },
- "SysUserId": {
- "type": "integer"
- },
- "SysUserRealName": {
- "type": "text",
- "term_vector": "with_positions_offsets",
- "analyzer": "ik_smart"
- },
- "UniqueCode": {
- "type": "text",
- "term_vector": "with_positions_offsets"
- },
- "Unit": {
- "type": "text",
- "term_vector": "with_positions_offsets"
- },
- "CreateTime": {
- "type": "date"
- },
- "ModifyTime": {
- "type": "date"
- },
- "DateType": {
- "type": "integer"
- },
- "StartDate": {
- "type": "text",
- "term_vector": "with_positions_offsets"
- },
- "EndDate": {
- "type": "text",
- "term_vector": "with_positions_offsets"
- },
- "IsSetName": {
- "type": "integer"
- },
- "EdbInfoIds": {
- "type": "text",
- "term_vector": "with_positions_offsets"
- },
- "ChartType": {
- "type": "integer"
- },
- "Calendar": {
- "type": "text",
- "term_vector": "with_positions_offsets"
- },
- "ChartImage": {
- "type": "text",
- "term_vector": "with_positions_offsets"
- }
- }
- }
- }`
- elastic.EsCreateIndex(indexName, mappingJson)
- }
- func AddAllChartInfo() {
- allList, err := data_manage.GetChartInfoAllList()
- if err != nil {
- fmt.Println("GetArticleAll Err:", err.Error())
- return
- }
- total := len(allList)
- for k, v := range allList {
- EsAddOrEditChartInfo(v.ChartInfoId)
- //fmt.Println(v.ChartInfoId)
- fmt.Println("剩余", total-k-1, "条数据,当前图表id:", v.ChartInfoId)
- }
- }
- // EsAddOrEditChartInfo 新增和修改ES中的图表数据
- func EsAddOrEditChartInfo(chartInfoId int) {
- var err error
- defer func() {
- if err != nil {
- fmt.Println("新增和修改ES中的图表数据失败:", err.Error())
- }
- }()
- itemInfo, _ := data_manage.GetChartInfoById(chartInfoId)
- //添加es
- err = elastic.EsAddOrEditChartInfoData(utils.CHART_INDEX_NAME, strconv.Itoa(itemInfo.ChartInfoId), itemInfo)
- return
- }
- // EsDeleteChartInfo 删除ES中的图表数据
- func EsDeleteChartInfo(chartInfoId int) {
- var err error
- defer func() {
- if err != nil {
- fmt.Println("删除ES中的图表数据失败:", err.Error())
- }
- }()
- //添加es
- err = elastic.EsDeleteDataV2(utils.CHART_INDEX_NAME, strconv.Itoa(chartInfoId))
- return
- }
- // EsSearchChartInfo 搜索图表信息
- func EsSearchChartInfo(keyword string, showSysId int, sourceList []int, noPermissionChartIdList []int, startSize, pageSize int) (list []*data_manage.ChartInfoMore, total int64, err error) {
- list, total, err = elastic.SearchChartInfoData(utils.CHART_INDEX_NAME, keyword, showSysId, sourceList, noPermissionChartIdList, startSize, pageSize)
- return
- }
- // AddAllMyChartInfo 添加所有的我的图库数据
- func AddAllMyChartInfo() {
- errMsg := make([]string, 0)
- defer func() {
- if len(errMsg) > 0 {
- fmt.Println("新增和修改ES中的图表数据失败:", strings.Join(errMsg, "\n"))
- }
- }()
- var condition string
- var pars []interface{}
- allList, err := data_manage.GetMyChartListGroupByCharyInfoIdAndAdminIdByCondition(condition, pars)
- if err != nil {
- fmt.Println("AddAllMyChartInfo Err:", err.Error())
- return
- }
- for _, v := range allList {
- //添加es
- err = elastic.EsAddOrEditDataInterface(utils.MY_CHART_INDEX_NAME, strconv.Itoa(v.MyChartId), v)
- if err != nil {
- errMsg = append(errMsg, fmt.Sprintf("myChartId:%d,添加Es失败,err:%s", v.MyChartId, err.Error()))
- }
- }
- }
- // EsAddOrEditMyChartInfoByChartInfoId 根据图表id 新增和修改ES中的图表数据
- func EsAddOrEditMyChartInfoByChartInfoId(chartInfoId int) {
- errMsg := make([]string, 0)
- defer func() {
- if len(errMsg) > 0 {
- fmt.Println("新增和修改ES中的图表数据失败:", strings.Join(errMsg, "\n"))
- }
- }()
- var condition string
- var pars []interface{}
- condition += " and a.chart_info_id = ? "
- pars = append(pars, chartInfoId)
- allList, err := data_manage.GetMyChartListGroupByCharyInfoIdAndAdminIdByCondition(condition, pars)
- if err != nil {
- errMsg = append(errMsg, fmt.Sprintf("EsAddOrEditMyChartInfoByChartInfoId Err:%s", err.Error()))
- return
- }
- for _, v := range allList {
- //添加es
- err = elastic.EsAddOrEditDataInterface(utils.MY_CHART_INDEX_NAME, strconv.Itoa(v.MyChartId), v)
- if err != nil {
- errMsg = append(errMsg, fmt.Sprintf("myChartId:%d,添加Es失败,err:%s", v.MyChartId, err.Error()))
- }
- }
- return
- }
- // EsDeleteMyChartInfoByChartInfoId 根据图表id 删除ES中的图表数据
- func EsDeleteMyChartInfoByChartInfoId(chartInfoId int) {
- errMsg := make([]string, 0)
- defer func() {
- if len(errMsg) > 0 {
- fmt.Println("新增和修改ES中的图表数据失败:", strings.Join(errMsg, "\n"))
- }
- }()
- var condition string
- var pars []interface{}
- condition += " AND a.chart_info_id = ? "
- pars = append(pars, chartInfoId)
- allList, err := data_manage.GetMyChartListGroupByCharyInfoIdAndAdminIdByCondition(condition, pars)
- if err != nil {
- errMsg = append(errMsg, fmt.Sprintf("AddAllMyChartInfo Err:%s", err.Error()))
- return
- }
- for _, v := range allList {
- //删除es
- err = elastic.EsDeleteDataV2(utils.MY_CHART_INDEX_NAME, strconv.Itoa(v.MyChartId))
- if err != nil {
- errMsg = append(errMsg, fmt.Sprintf("myChartId:%d,删除Es失败,err:%s", v.MyChartId, err.Error()))
- }
- }
- return
- }
- // EsAddOrEditMyChartInfoByMyChartId 根据我的图库id 新增和修改ES中的图表数据
- func EsAddOrEditMyChartInfoByMyChartId(myChartId int) {
- errMsg := make([]string, 0)
- defer func() {
- if len(errMsg) > 0 {
- fmt.Println("新增和修改ES中的图表数据失败:", strings.Join(errMsg, "\n"))
- }
- }()
- var condition string
- var pars []interface{}
- condition += " AND a.my_chart_id = ? "
- pars = append(pars, myChartId)
- allList, err := data_manage.GetMyChartListGroupByCharyInfoIdAndAdminIdByCondition(condition, pars)
- if err != nil {
- errMsg = append(errMsg, fmt.Sprintf("EsAddOrEditMyChartInfoByMyChartId Err:%s", err.Error()))
- return
- }
- for _, v := range allList {
- //添加es
- err = elastic.EsAddOrEditDataInterface(utils.MY_CHART_INDEX_NAME, strconv.Itoa(v.MyChartId), v)
- if err != nil {
- errMsg = append(errMsg, fmt.Sprintf("myChartId:%d,添加Es失败,err:%s", v.MyChartId, err.Error()))
- }
- }
- return
- }
- // EsDeleteMyChartInfoByMyChartId 根据我的图库id 删除ES中的图表数据
- func EsDeleteMyChartInfoByMyChartId(myChartId int) {
- var err error
- defer func() {
- if err != nil {
- fmt.Println("删除ES中的图表数据失败:", err.Error())
- }
- }()
- //添加es
- err = elastic.EsDeleteDataV2(utils.MY_CHART_INDEX_NAME, strconv.Itoa(myChartId))
- return
- }
- // EsSearchMyChartInfo 搜索图表信息
- func EsSearchMyChartInfo(keyword string, adminId int, noPermissionChartIdList []int, startSize, pageSize int) (list []*data_manage.MyChartList, total int64, err error) {
- list, total, err = elastic.SearchMyChartInfoData(utils.MY_CHART_INDEX_NAME, keyword, adminId, noPermissionChartIdList, startSize, pageSize)
- return
- }
- // EsDeleteMyChartInfoByMyChartIds 根据我的图表IDs删除ES中的我的图表
- func EsDeleteMyChartInfoByMyChartIds(ids []int) {
- if len(ids) == 0 {
- return
- }
- errMsg := make([]string, 0)
- defer func() {
- if len(errMsg) > 0 {
- fmt.Println("EsDeleteMyChartInfoByMyChartIds, 删除ES中的我的图表数据失败:", strings.Join(errMsg, "\n"))
- }
- }()
- for _, v := range ids {
- id := strconv.Itoa(v)
- if e := elastic.EsDeleteDataV2(utils.MY_CHART_INDEX_NAME, id); e != nil {
- errMsg = append(errMsg, fmt.Sprintf("myChartId:%d,删除Es失败,err:%s", v, e.Error()))
- }
- }
- return
- }
|