米鼠商城

多快好省,买软件就上米鼠网

最新项目

人才服务

靠谱的IT人才垂直招聘平台

magic-api 对posgresql的jsonb数据的支持

  • darkalex
  • 5
  • 2021-04-13 15:05

@magic-api

定义表:

CREATE TABLE public.tb_form_schema (
	id int8 NOT NULL,
	"name" varchar(50) NULL,
	form_schema jsonb NULL,
	CONSTRAINT tb_form_schema_pk PRIMARY KEY (id)
);

有两种方案:

方案 1、创建function类:

import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONObject;
import lombok.extern.slf4j.Slf4j;
import org.apache.commons.lang3.StringUtils;
import org.postgresql.util.PGobject;
import org.springframework.stereotype.Component;
import org.ssssssss.magicapi.config.MagicFunction;
import org.ssssssss.script.annotation.Comment;
import org.ssssssss.script.annotation.Function;
@Slf4j
@Component
public class JsonFunction implements MagicFunction {
    @Function
    @Comment("将jsonp数据转为JSONObject")
    public JSONObject toJson(PGobject p){
        log.info("数据:{}",p);

        if(p==null){
            return null;
        }
        if(StringUtils.isEmpty(p.getValue())){
            return null;
        }
        switch (p.getType().toLowerCase()){
            case "json":
            case "jsonb":
                return JSON.parseObject(p.getValue());
        }
        return null;
    }
}

方案 2 、定义函数:

import "com.alibaba.fastjson.JSON" as JSON;
import "org.apache.commons.lang3.StringUtils" as StringUtils;
if(v==null){
    return null
}
if(StringUtils.isEmpty(v.getValue())){
    return null
}
var vt=v.getType()
if(vt =="jsonb"){
    return JSON.parseObject(v.getValue())
}
return v

调用:

import "@/conver/toJSON" as toJSON
var list=
select t.id,t.formSchema from 
(db.camel().select("select * from magic_api_file")) b 
left join 
(
 db.hyLowCode.camel().select("select * from tb_form_schema")
) t
on t.id = b.id where t.id=b.id
return list.each(it=>it.formSchema=toJSON(it.formSchema))

 



这里给大家推荐一个在线软件复杂项交易平台:米鼠网 https://www.misuland.com

米鼠网自成立以来一直专注于从事软件项目人才招聘软件商城等,始终秉承“专业的服务,易用的产品”的经营理念,以“提供高品质的服务、满足客户的需求、携手共创双赢”为企业目标,为中国境内企业提供国际化、专业化、个性化、的软件项目解决方案,我司拥有一流的项目经理团队,具备过硬的软件项目设计和实施能力,为全国不同行业客户提供优质的产品和服务,得到了客户的广泛赞誉。



如有侵权请联系邮箱(service@misuland.com)

猜你喜欢

评论留言