cube.js prepareCompiler api 试用

前边有介绍过prepareCompiler API ,以下是一个项目集成使用简单说明

包装prepareCompiler api

实际上可以不用,但是为了方便使用可以包装一下,比如提供给express 或者类似web 框架

  • cmd module
    app.js, 此处的adapter 并不是必须,如果需要进行特定数据库的测试,就需要了
 
const {prepareCompiler} = require("@cubejs-backend/schema-compiler")
module.exports = {
    preCompiler:function(content,options){
       return prepareCompiler({
            localPath: () => __dirname,
            dataSchemaFiles: () => Promise.resolve([
              { fileName: 'main.js', content }
            ])
          }, { adapter: 'postgres', ...options });     
    }
}

使用

  • 可以提供一个简单的cube schme 文件
    比如
    demo-schmea.js
 
cube('visitors', {
    sql: `select * from visitors`,
    measures: {
        visitor_count: {
            type: 'count',
            sql: 'id',
            drillMembers: [source, created_at]
        },
        visitor_revenue: {
            type: 'sum',
            sql: 'amount',
            drillMemberReferences: [source, created_at]
        }
    },
    dimensions: {
        source: {
            type: 'string',
            sql: 'source'
        },
        created_at: {
            type: 'date',  //  此处编译会报错
            sql: 'created_at'
        }
    }
})
  • 测试
    index.js
 
const app = require("./app")
const fs = require("fs")
let myapp = app.preCompiler(fs.readFileSync("./demo-schmea.js").toString("utf-8"))
myapp.compiler.compile().then(data=>{
    console.log(data)
}).catch(err=>{
    console.log("some wrong:",err.messages)
})
  • 运行效果

 

 

说明

项目集成prepareCompiler api 可以提升项目的稳定性

参考资料

https://github.com/rongfengliang/cubejs-prepareCompiler-learning

posted on   荣锋亮  阅读(92)  评论(0编辑  收藏  举报

编辑推荐:
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
阅读排行:
· 全程不用写代码,我用AI程序员写了一个飞机大战
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· .NET10 - 预览版1新功能体验(一)
历史上的今天:
2019-04-10 nomad 0.9 新特性
2019-04-10 goaccess geoip 测试
2018-04-10 elixir 几种安装方式
2018-04-10 一张elixir生产环境部署的图
2017-04-10 基于jquery 的ajax 文件下载
2014-04-10 无法对 数据库'XXXXX' 执行 删除,因为它正用于复制

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5
点击右上角即可分享
微信分享提示