Sublime text 3 安装 soar 插件

2019-04-12  本文已影响0人  steamed_bun

感谢一波:
此文是看大佬的文章SOAR的IDE插件——您的贴身DBA保镖操作的过程及问题的解决

一、说明

1、soar github: 对SQL进行优化和改写的自动化工具。 由小米人工智能与云平台的数据库团队开发与维护。
2、SublimeLinter-soar github:Sublime text 的插件,安装后可以直接给出提示。
3、安装插件前确保soar可用,即官方的例子实现如下效果

二、安装---如大佬github的说明去操作

1、使用SublimeLinter-soar 插件必须先安装 SublimeLinter 3

1.1、Sublime Text 打开Preferences -> Browse Packages... 会打开一个文件夹

1.2、执行git clone https://github.com/SublimeLinter/SublimeLinter.git,下载文件到上述目录

2、安装并配置插件

2.1、执行git clone https://github.com/liipx/SublimeLinter-soar.git,下载插件到上述目录

2.2、打开Preferences -> Package Settings -> SublimeLinter -> Settings,然后在右边的 Settings - User 加入如下代码:

// SublimeLinter Settings - User
{
    "linters": {
        "soar": {
            "soar_path":"you_soar_path"
            //"soar_path":"/XXX/xxx/soar" 一定要到soar
        }
    }
}

2.3、重启 Sublime Text, 新建一个sql文件,写入官方的测试语句,可得如下效果


2.4、保存或者修改文件的时候就会检查,如果检查到有问题,需要优化,就会出现框,鼠标放上去就会提示。如果没有需要优化的就不会有框。


到这里插件已经可以使用了,但是这样并不能连接我们自己的数据库进行测试,故修改一点点大佬的插件代码 ∠( ᐛ 」∠)_


3、修改插件

3.1、打开刚刚下载的 SublimeLinter-soar 的 linter.py文件,找到

cmd = persist.settings.get('linters').get('soar').get("soar_path") + " -report-type lint -query"

修改为

cmd = persist.settings.get('linters').get('soar').get("soar_path") + " -config " + persist.settings.get('linters').get('soar').get("soar_yml_path") + " -report-type lint -query"

3.2、在刚刚的Preferences -> Package Settings -> SublimeLinter -> Settings,右边的 Settings - User 加入一行代码,最终如下

// SublimeLinter Settings - User
{
    "linters": {
        "soar": {
            "soar_path":"/XXX/xxx/soar",
            "soar_yml_path":"/XXX/xxx/soar.yml" 
        }
    }
}

注:soar.yml 是我自己写的文件,可换成你自己本地的soar config 文件config 文件官方说明
3.3、即加上 -config 参数及对应的文件路径,最后可得如下效果

由于已经使用了我自己的配置文件,发现无此表,此语句执行失败了。


到这里已经基本满足需求了,但是发现信息有时候太少了,需要看更多一点,可如下操作。


4、打印详细信息在控制台

4.1、在刚刚的Preferences -> Package Settings -> SublimeLinter -> Settings左边 的debug打开, "debug": true
4.3、再次打开刚刚下载的 SublimeLinter-soar 的 linter.py文件 修改同一个位置,即去掉-report-type lint,使用默认的markdown格式。

persist.settings.get('linters').get('soar').get("soar_path") + " -config " + persist.settings.get('linters').get('soar').get("soar_yml_path") + " -report-type lint -query"

注:但是由于不符合SublimeLinter的格式要求,不能直接显示在上面官方说明

4.2、使用 control + `,打开Sublime Text 的控制台,就可以看到详细的信息了。

三、遇到的问题

1、soar cannot locate 'soar'错误 其实一直没有找到真实的原因@( ̄- ̄)@
try:
        print(persist.settings.get('linters').get('soar').get("soar_path")) #新代码 打印出路径而已
        print(persist.settings.get('linters').get('soar').get("soar_yml_path")) #新代码 打印出路径而已
        cmd = persist.settings.get('linters').get('soar').get("soar_path") + " -config " + persist.settings.get('linters').get('soar').get("soar_yml_path") + " -report-type lint -query"
    except Exception as e:
        cmd = "soar -report-type lint -query"
上一篇下一篇

猜你喜欢

热点阅读