Ignite的jdbc与网格的连接方式的查询性能对比

环境:

数据量100万

Ignite2.5

Windows10 8g

 

  1. jdbc方式连接

import java.sql.Connection;

import java.sql.DriverManager;

import java.sql.PreparedStatement;

import java.sql.ResultSet;

import java.sql.SQLException;

import java.util.Arrays;

import java.util.List;

 

public class IgniteQury {

         public static void main(String[] args) throws SQLException, ClassNotFoundException {

                   // TODO Auto-generated method stub

                   //连接远程单节点ignite

                   Class.forName("org.apache.ignite.IgniteJdbcDriver");

                   Connection conn = DriverManager.getConnection("jdbc:ignite:thin://ip:10800");           

                   PreparedStatement ps = conn.prepareStatement("select s.*,i.* from staff s join internetcafe i on s.ID=i.STAFFID"

                                     +" union all "

                                     +"select s.*,p.TrackID,p.STAFFID,concat(concat(p.TAKEOFFNAME,','),p.FALLDOWNNAME) FLIGHTADD,p.FLIGHTDATE from staff s left join plane p on s.ID=p.STAFFID");

//                                   +" union all "

//                                   +"select s.*,t.TrackID,t.STAFFID,concat(concat(t.OUTSETNAME,','),t.TERMINAL) TRIVALADD,t.travelDate from staff s join train t on s.ID=t.STAFFID");

                   long t1 = System.currentTimeMillis();

                   ResultSet res=ps.executeQuery();

                   long t2 = System.currentTimeMillis();

                   long t3=t2-t1;

                   float s=(float)t3/1000;

                   System.out.println("执行时间:"+s+"秒");

         }

}

使用jdbc连接,用java程序取数据,合并两个查询子集,查询时间50几秒,合并三个查询子集,拉跨ignite

 

  1. 网格方式连接

import java.util.Arrays;

import java.util.List;

 

import org.apache.ignite.Ignite;

import org.apache.ignite.IgniteCache;

import org.apache.ignite.Ignition;

import org.apache.ignite.cache.query.QueryCursor;

import org.apache.ignite.cache.query.SqlFieldsQuery;

import org.apache.ignite.configuration.CacheConfiguration;

import org.apache.ignite.configuration.IgniteConfiguration;

import org.apache.ignite.spi.discovery.tcp.TcpDiscoverySpi;

import org.apache.ignite.spi.discovery.tcp.ipfinder.vm.TcpDiscoveryVmIpFinder;

 

public class IgniteCollocationQuery {

 

         public static void main(String[] args) {

                   // TODO Auto-generated method stub

                   TcpDiscoverySpi spi = new TcpDiscoverySpi();

        TcpDiscoveryVmIpFinder ipFinder = new TcpDiscoveryVmIpFinder();

        ipFinder.setAddresses(Arrays.asList("ip:47500..47509"));

//        spi.setJoinTimeout(4000);

        spi.setIpFinder(ipFinder);

        IgniteConfiguration cfg = new IgniteConfiguration();

        cfg.setDiscoverySpi(spi);

        cfg.setClientMode(true);

        Ignition.setClientMode(true);

        Ignite ignite = Ignition.start(cfg);  

//        IgniteCache() cache = ignite.cache("SQL_PUBLIC_STAFF");

        CacheConfiguration ccfg = new CacheConfiguration();

        ccfg.setName("SQL_PUBLIC_STAFF");

        IgniteCache cache = ignite.getOrCreateCache(ccfg);

//        SqlFieldsQuery query = new SqlFieldsQuery("select * from staff");

        SqlFieldsQuery query = new SqlFieldsQuery("select s.*,i.* from staff s join internetcafe i on s.ID=i.STAFFID"

                                     +" union all "

                                     +"select s.*,p.TrackID,p.STAFFID,concat(concat(p.TAKEOFFNAME,','),p.FALLDOWNNAME) FLIGHTADD,p.FLIGHTDATE from staff s left join plane p on s.ID=p.STAFFID"

                                     +" union all "

                                     +"select s.*,t.TrackID,t.STAFFID,concat(concat(t.OUTSETNAME,','),t.TERMINAL) TRIVALADD,t.travelDate from staff s join train t on s.ID=t.STAFFID");

                   //设置collocation可用

       query.setDistributedJoins(true);

       

        long t1 = System.currentTimeMillis();

                   QueryCursor<List<?>> cursor=cache.query(query);

                   long t2 = System.currentTimeMillis();

                   long t3=t2-t1;

                   float s=(float)t3/1000;

                   System.out.println("执行时间:"+s+"秒");

         }

 

}

使用网格连接,合并三个查询子集,1.9秒,设置query.setDistributedJoins(true)性能提升10倍,0.19秒

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

仔仔1993

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值