JPA定义自定义sql返回JSONArray形式的结果

import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONArray;
import com.yss.capital.core.api.sql.service.ISQLExecuteService;
import lombok.extern.slf4j.Slf4j;
import net.oschina.j2cache.cache.support.util.SpringUtil;
import org.hibernate.query.internal.NativeQueryImpl;
import org.hibernate.transform.Transformers;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;

import javax.persistence.EntityManager;
import javax.persistence.Query;
import java.util.List;

@Service
@Slf4j
@Transactional(readOnly = true)
public class SQLExecuteServiceImpl implements ISQLExecuteService {

    @Override
    public JSONArray executeSql(String sql) {
        //封装返回的json数组对象
        JSONArray jsonArray = new JSONArray();
        try{
            //创建数据库操作实体
            EntityManager entityManager = SpringUtil.getBean(EntityManager.class);
            //执行数据库的查询操作
            Query query = entityManager.createNativeQuery(sql);
            //将查询结果转换成mq对象即键值对模式
            query.unwrap(NativeQueryImpl.class).setResultTransformer(Transformers.ALIAS_TO_ENTITY_MAP);
            List resultList = query.getResultList();
            jsonArray = JSONArray.parseArray(JSON.toJSONString(resultList));
            log.info("自定义sql查询结果为:"+jsonArray.toJSONString());
        }catch (Exception exception){
            log.error("当前执行自定义sql语句失败,sql内容为【"+sql+"】");
        }
        // 将返回结果转成JSON数组
        return  jsonArray;
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值