druid使用presto數(shù)據(jù)源

1. 說明

presto并不能算是數(shù)據(jù)源朵逝,它只是一個(gè)數(shù)據(jù)查詢引擎窑业,通過presto集成多種數(shù)據(jù)源翔怎。
我這里已經(jīng)安裝好了presto并且集成了兩個(gè)oracle、一個(gè)mysql豆胸、一個(gè)hive奥洼、一個(gè)kudu


下面以spring boot為例介紹如何在druid中集成presto,實(shí)現(xiàn)數(shù)據(jù)查詢

2. 修改配置文件

spring:
  datasource-presto:
    type: com.alibaba.druid.pool.DruidDataSource
    driverClassName: com.facebook.presto.jdbc.PrestoDriver
    url: jdbc:presto://ip:8099
    username: 1234
    filters: default

3. 添加datasource的bean


    @Bean(name="prestoDataSource")
//    @Qualifier("kuduDataSource")
    @ConfigurationProperties(prefix ="spring.datasource-presto")
    public DataSource prestoDataSource(){
        DruidDataSource druidDataSource=new DruidDataSource();

        List list= new ArrayList<Filter>(){{add(logFilter);}};
        druidDataSource.setProxyFilters(list);
        return druidDataSource;
    }

4. 增加數(shù)據(jù)源配置

@Configuration
@MapperScan(basePackages = {"com.base.web.presto.*.dao"},sqlSessionFactoryRef = "prestoSessionFactory")
public class PrestoConfig {
    private static final String MAPPER_LOCATION = "classpath:prestomybatis/*/*.xml";

    @Autowired
    @Qualifier("prestoDataSource")
    private DataSource prestoDataSource;

    @Bean(name = "prestoTransactionManager")
    public DataSourceTransactionManager prestoTransactionManager() {
        return new DataSourceTransactionManager(prestoDataSource);
    }

    @Bean(name = "prestoSessionFactory")
    public SqlSessionFactory prestoSessionFactory(@Qualifier("prestoDataSource") DataSource prestoDataSource)
            throws Exception {
        final SqlSessionFactoryBean sessionFactory = new SqlSessionFactoryBean();
        sessionFactory.setDataSource(prestoDataSource);
        sessionFactory.setMapperLocations(new PathMatchingResourcePatternResolver()
                .getResources(PrestoConfig.MAPPER_LOCATION));
        //添加駝峰命名法 映射
        org.apache.ibatis.session.Configuration configuration = new org.apache.ibatis.session.Configuration();
        configuration.setMapUnderscoreToCamelCase(true);
        sessionFactory.setConfiguration(configuration);
        return sessionFactory.getObject();
    }
}

配置結(jié)束

5. 代碼測試

controller:

    @Autowired
    private PrestoDao prestoDao;
    @ResponseBody
    @GetMapping("/test")
    String test() throws InterruptedException {
        List<Bean1> bean1List = prestoDao.select1();
        List<Bean2> bean2List = prestoDao.select2();
        List<String> nsrmc = prestoDao.select3();
        return "timeout";
    }

xml:

    <select id="select1" resultType="com.base.web.presto.prestotest.domain.Bean1">
SELECT dzdz.djxh,hxzg.uuid
FROM dzdz.dzdz.dj_nsrxx dzdz right join hxzg.hx_zgxt.sb_zyssb_zb hxzg on dzdz.nsrsbh = hxzg.nsrsbh
    </select>
    <select id="select2" resultType="com.base.web.presto.prestotest.domain.Bean2">
      SELECT mysql.password,hive."desc"
FROM mysql22046.jcpt.auth_user mysql left join hive."default".hxzg_hive_dbs hive on mysql.id = hive.db_id
    </select>

    <select id="select3" resultType="java.lang.String">
        SELECT nsrmc
FROM hive.sjjsq_db.dwa_base_djxx limit 10
    </select>

debug運(yùn)行:


數(shù)據(jù)都查詢到了
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末晚胡,一起剝皮案震驚了整個(gè)濱河市灵奖,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌估盘,老刑警劉巖瓷患,帶你破解...
    沈念sama閱讀 217,185評論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異遣妥,居然都是意外死亡擅编,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,652評論 3 393
  • 文/潘曉璐 我一進(jìn)店門箫踩,熙熙樓的掌柜王于貴愁眉苦臉地迎上來爱态,“玉大人,你說我怎么就攤上這事班套≈辏” “怎么了?”我有些...
    開封第一講書人閱讀 163,524評論 0 353
  • 文/不壞的土叔 我叫張陵吱韭,是天一觀的道長吆豹。 經(jīng)常有香客問我鱼的,道長,這世上最難降的妖魔是什么痘煤? 我笑而不...
    開封第一講書人閱讀 58,339評論 1 293
  • 正文 為了忘掉前任凑阶,我火速辦了婚禮,結(jié)果婚禮上衷快,老公的妹妹穿的比我還像新娘宙橱。我一直安慰自己,他們只是感情好蘸拔,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,387評論 6 391
  • 文/花漫 我一把揭開白布师郑。 她就那樣靜靜地躺著,像睡著了一般调窍。 火紅的嫁衣襯著肌膚如雪宝冕。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,287評論 1 301
  • 那天邓萨,我揣著相機(jī)與錄音地梨,去河邊找鬼。 笑死缔恳,一個(gè)胖子當(dāng)著我的面吹牛宝剖,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播歉甚,決...
    沈念sama閱讀 40,130評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼万细,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了铃芦?” 一聲冷哼從身側(cè)響起雅镊,我...
    開封第一講書人閱讀 38,985評論 0 275
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎刃滓,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體耸弄,經(jīng)...
    沈念sama閱讀 45,420評論 1 313
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡咧虎,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,617評論 3 334
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了计呈。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片砰诵。...
    茶點(diǎn)故事閱讀 39,779評論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖捌显,靈堂內(nèi)的尸體忽然破棺而出茁彭,到底是詐尸還是另有隱情,我是刑警寧澤扶歪,帶...
    沈念sama閱讀 35,477評論 5 345
  • 正文 年R本政府宣布理肺,位于F島的核電站,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏妹萨。R本人自食惡果不足惜年枕,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,088評論 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望乎完。 院中可真熱鬧熏兄,春花似錦、人聲如沸树姨。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,716評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽帽揪。三九已至硝清,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間台丛,已是汗流浹背耍缴。 一陣腳步聲響...
    開封第一講書人閱讀 32,857評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留挽霉,地道東北人防嗡。 一個(gè)月前我還...
    沈念sama閱讀 47,876評論 2 370
  • 正文 我出身青樓,卻偏偏與公主長得像侠坎,于是被迫代替她去往敵國和親蚁趁。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,700評論 2 354

推薦閱讀更多精彩內(nèi)容