If you want to query the DB once, you should definitely restructure the route a bit.
Here's the simplest option IMO. The goal is to query once and make the query result available to all split tasks: - Run bindy before the split, which will generate a List of AED objects. - Create a small bean that constructs the SQL query from the List of AED. - Do the JDBC enrichment before the split. - In your aggregation strategy, inject the result of the DB query in an exchange property. - Then run the split without specifying any split criteria (no tokenize). We split lists into its constituents out of the box. - Inside the split body, enrich your AED object with the DB results stored in the above exchange property. Hope this helps! Raúl. Sent while on the move. On 7 Mar 2013 08:25, "Jean Francois LE BESCONT" <jflebesc...@gmail.com> wrote: > Sorry if my explanation are not good ... :) > > I have a csv file. I would like to process this file to enrich with data > in sql table (then write enriched line in output). > > I process file with a binding in business class : > > .from("file://mycsv.csv") > .split() > .tokenize("\n") > .streaming() > .unmarshal() > .bindy(BindyType.Csv, AED.class) > > Then I would like to enrich the line converted in AED to add element from a > DB table : > .enrich("direct:datasource", new AggregationEnrichissementZone()) > > > The AggregationEnrichissementZone do my business transformation with both > the current line and the content of the database which is in > direct:datasource. It works no problem ! The > direct:datasource is called correctly and retrieve the data from sql table. > Initially I wrote it like this : > > from("direct:datasource") > .setBody(constant("SELECT * FROM TEST")) > .to("jdbc:dataSource") > .to("direct:ds") > .end(); > > But direct:datasource is called for each line which cost to much time. I > would like to make the database query only once for my csv file. > > Thanks > > JF > > > > > 2013/3/7 Claus Ibsen <claus.ib...@gmail.com> > > > On Thu, Mar 7, 2013 at 8:03 AM, Jean Francois LE BESCONT > > <jflebesc...@gmail.com> wrote: > > > it is a really simple studies case no ? I can't be the first guy who > > > don't want to reload the datasource on each line isn't it ? > > > > > > > I dont think people can understand what you try to do and pasting a > > lot of code and with little detail to go along. > > I suggest to debug your application and see what goes on and figure > > out your solution. > > > > > > > > > > > > 2013/3/6 Jean Francois LE BESCONT <jflebesc...@gmail.com> > > > > > >> I made a mistake in my test. It doesn't do what expected ... > > >> > > >> Still the same example : > > >> > > >> .from(...) > > >> .split() > > >> .tokenize("\n") > > >> .streaming() > > >> .unmarshal() > > >> .bindy(BindyType.Csv, AED.class) > > >> .enrich("direct:refreshReferentielDynamic", new > > >> AggregationEnrichissementZone()) > > >> > > >> And a : > > >> > > >> from("direct:refreshReferentielDynamic") > > >> .processRef("validatingProcessor") > > >> > > >> .end(); > > >> > > >> > > >> And > > >> > > >> > > >> public class ValidatingProcessor implements Processor { > > >> > > >> @Autowired > > >> DriverManagerDataSource dataSource; > > >> public void process(Exchange exchange) throws Exception { > > >> > > >> > > >> Integer idxParse = (Integer) > exchange.getProperty(Exchange.SPLIT_INDEX); > > >> if (idxParse != null & idxParse == 0) { > > >> JdbcTemplate jdbcTemplate = new JdbcTemplate(dataSource); > > >> List<Map<String, Object>> ref = jdbcTemplate > > >> .queryForList("SELECT ID , CODE , LIBELLE FROM ZONE_T "); > > >> Map<String, Zone> newRef = new HashMap(); > > >> for (Map<String, Object> map : ref) { > > >> int id=(Integer) map.get("ID"); > > >> String code =(String) map.get("CODE"); > > >> String libelle =(String)map.get("LIBELLE"); > > >> newRef.put(code, new Zone(id,code,libelle)); > > >> } > > >> exchange.getOut().setBody(newRef) ; > > >> > > >> > > >> } > > >> } > > >> > > >> > > >> The problem is that in my AggregationStrategy zones which is populate > > >> before has data only for the first line ( the first spit index). > > >> > > >> > > >> public class AggregationEnrichissementZone implements > > AggregationStrategy { > > >> > > >> Logger LOG = > > LoggerFactory.getLogger(AggregationEnrichissementZone.class); > > >> > > >> @Override > > >> public Exchange aggregate(Exchange original, Exchange resource) { > > >> > > >> Map<String, Zone> zones = (Map<String, Zone>) > > resource.getIn().getBody(); > > >> > > >> > > >> Any idea ? > > >> > > >> > > >> Thanks ! > > >> > > >> > > >> > > >> > > >> 2013/3/6 Jean Francois LE BESCONT <jflebesc...@gmail.com> > > >> > > >>> Thanks Claus ! > > >>> > > >>> Tricky but it works :) > > >>> > > >>> > > >>> 2013/3/6 Claus Ibsen <claus.ib...@gmail.com> > > >>> > > >>>> On Wed, Mar 6, 2013 at 1:05 PM, Jean Francois LE BESCONT > > >>>> <jflebesc...@gmail.com> wrote: > > >>>> > When we do an enrich, the *resourceUri ( in my example > > >>>> *.enrich("direct:ds", > > >>>> > new AggregationStrategyRessource())) is called every time. > > >>>> > > > >>>> > When I parse a file, big query with all the datasource while be > > called > > >>>> > every, is there a trick to tell the route to execute only one ? I > > have > > >>>> > watch camel cache but I have understand that it is used for > > something > > >>>> else. > > >>>> > > > >>>> > Thanks ! > > >>>> > > > >>>> > > >>>> You can use a filter / content based route and only use the enrich > the > > >>>> 1st time. > > >>>> When you use the splitter the exchange has a property with the split > > >>>> index, so the 1st time the index is zero. > > >>>> > > >>>> The key for that property is Exchange.SPLIT_INDEX > > >>>> > > >>>> > > > >>>> > > > >>>> > > > >>>> > 2013/3/6 Jean Francois LE BESCONT <jflebesc...@gmail.com> > > >>>> > > > >>>> >> Thanks Claus for the link ( have you an HashMap off the FAQ in > the > > >>>> head ? > > >>>> >> :) > > >>>> >> > > >>>> >> Don't forget to add : > > >>>> >> > > >>>> >> > > >>>> >> original.getOut().setHeaders(original.getIn().getHeaders()); > > >>>> >> > > >>>> >> > > >>>> >> When enrich with strategy ! > > >>>> >> > > >>>> >> > > >>>> >> 2013/3/6 Claus Ibsen <claus.ib...@gmail.com> > > >>>> >> > > >>>> >>> On Wed, Mar 6, 2013 at 10:26 AM, Jean Francois LE BESCONT > > >>>> >>> <jflebesc...@gmail.com> wrote: > > >>>> >>> > My mistake ...I used resource.getOut().getBody(); instead > > >>>> >>> > od resource.getIn().getBody(); > > >>>> >>> > > > >>>> >>> > > >>>> >>> Yeah see this FAQ > > >>>> >>> > > >>>> > > http://camel.apache.org/using-getin-or-getout-methods-on-exchange.html > > >>>> >>> > > >>>> >>> > > > >>>> >>> > public Exchange aggregate(Exchange original, Exchange > > resource) { > > >>>> >>> > > > >>>> >>> > AED originalBody = (AED)original.getIn().getBody(); > > >>>> >>> > Object resourceResponse = (Object) resource.getIn().getBody(); > > >>>> >>> > > > >>>> >>> > LOG.info("originalBody " + originalBody ) ; > > >>>> >>> > LOG.info("resourceResponse " + resourceResponse ) ; > > >>>> >>> > // do stuff with > > >>>> >>> > > > >>>> >>> > return resource; > > >>>> >>> > } > > >>>> >>> > > > >>>> >>> > Thanks raul for the help ! :) > > >>>> >>> > > > >>>> >>> > > > >>>> >>> > 2013/3/6 Jean Francois LE BESCONT <jflebesc...@gmail.com> > > >>>> >>> > > > >>>> >>> >> Thanks Raul ! > > >>>> >>> >> > > >>>> >>> >> I haven't found simple example enrich here ( > > >>>> >>> >> http://camel.apache.org/content-enricher.html, > > direct:resource in > > >>>> >>> never > > >>>> >>> >> explains ). Perharps that I haven't understand fondamental > but > > >>>> it's a > > >>>> >>> >> huge framework and learning needs time :) > > >>>> >>> >> > > >>>> >>> >> So I have a querie : > > >>>> >>> >> > > >>>> >>> >> from("direct:refreshReferentielDynamic") > > >>>> >>> >> .setBody(constant("SELECT * FROM TEST")) > > >>>> >>> >> .to("jdbc:dataSource") > > >>>> >>> >> .to("direct:ds") > > >>>> >>> >> .end(); > > >>>> >>> >> > > >>>> >>> >> Plus : > > >>>> >>> >> > > >>>> >>> >> from("direct:ds").to("log:dans.directds").end(); > > >>>> >>> >> > > >>>> >>> >> Otherwise it doesn't works. > > >>>> >>> >> > > >>>> >>> >> > > >>>> >>> >> And an " main route " : > > >>>> >>> >> > > >>>> >>> >> from("file://....") > > >>>> >>> >> .split() > > >>>> >>> >> .tokenize("\n") > > >>>> >>> >> .enrich("direct:ds", new AggregationStrategyRessource()) > > >>>> >>> >> > > >>>> >>> >> With : > > >>>> >>> >> > > >>>> >>> >> > > >>>> >>> >> public class AggregationStrategyRessource implements > > >>>> >>> AggregationStrategy { > > >>>> >>> >> > > >>>> >>> >> > > >>>> >>> >> public Exchange aggregate(Exchange original, Exchange > > >>>> resource) { > > >>>> >>> >> > > >>>> >>> >> return resource; // for the moment > > >>>> >>> >> } > > >>>> >>> >> > > >>>> >>> >> } > > >>>> >>> >> > > >>>> >>> >> But original is always null ... > > >>>> >>> >> > > >>>> >>> >> Do you see with ? > > >>>> >>> >> > > >>>> >>> >> > > >>>> >>> >> > > >>>> >>> >> > > >>>> >>> >> > > >>>> >>> >> > > >>>> >>> >> > > >>>> >>> >> 2013/3/6 Jean Francois LE BESCONT <jflebesc...@gmail.com> > > >>>> >>> >> > > >>>> >>> >>> Hey ! > > >>>> >>> >>> > > >>>> >>> >>> A picture is sometime better than explication :) I try to > > make a > > >>>> >>> really > > >>>> >>> >>> simple test ( equivalent of MAP with lookup in ETL) : > > >>>> >>> >>> > > >>>> >>> >>> > > >>>> >>> >>> > > >>>> ------------------------- > > >>>> >>> >>> | TABLE TEST | > > >>>> >>> >>> > > >>>> ------------------------- > > >>>> >>> >>> | COL1 | COL2 | > > >>>> >>> >>> | jack | 2 > > | > > >>>> >>> >>> | bob | 3 > > | > > >>>> >>> >>> > > >>>> ------------------------ > > >>>> >>> >>> | > > >>>> >>> >>> | > > >>>> >>> >>> | > > >>>> >>> >>> | > > >>>> >>> >>> | > > >>>> >>> >>> ---------------- > > ---------------------- > > >>>> >>> >>> ------------------------ > > >>>> >>> >>> | FILE INPUT | | ENRICH ? | > > >>>> >>> >>> | FILE OUTPUT | > > >>>> >>> >>> ---------------- > > ---------------------- > > >>>> >>> >>> ----------------------- > > >>>> >>> >>> | jack | cool | >>>>>>>>> | | > > >>>>>>>>> > > >>>> | > > >>>> >>> jack > > >>>> >>> >>> | cool | 2 | > > >>>> >>> >>> | bob | foo | | > > | > > >>>> >>> >>> | bob | foo | 3 | > > >>>> >>> >>> ---------------- > > >>>> ----------------------- > > >>>> >>> >>> ------------------------ > > >>>> >>> >>> > > >>>> >>> >>> > > >>>> >>> >>> > > >>>> >>> >>> > > >>>> >>> >>> > > >>>> >>> >>> > > >>>> >>> >>> > > >>>> >>> >>> 2013/3/6 Jean Francois LE BESCONT <jflebesc...@gmail.com> > > >>>> >>> >>> > > >>>> >>> >>>> If i do: > > >>>> >>> >>>> public class AggregationStrategyRessource implements > > >>>> >>> AggregationStrategy > > >>>> >>> >>>> { > > >>>> >>> >>>> > > >>>> >>> >>>> @Override > > >>>> >>> >>>> public Exchange aggregate(Exchange original, Exchange > > >>>> resource) { > > >>>> >>> >>>> int i = 1 / 0; > > >>>> >>> >>>> return original; > > >>>> >>> >>>> } > > >>>> >>> >>>> } > > >>>> >>> >>>> > > >>>> >>> >>>> no exception are thows. > > >>>> >>> >>>> > > >>>> >>> >>>> > > >>>> >>> >>>> > > >>>> >>> >>>> 2013/3/6 Jean Francois LE BESCONT <jflebesc...@gmail.com> > > >>>> >>> >>>> > > >>>> >>> >>>>> thks Raul > > >>>> >>> >>>>> > > >>>> >>> >>>>> For the moment it's a simple : > > >>>> >>> >>>>> > > >>>> >>> >>>>> public class AggregationStrategyRessource implements > > >>>> >>> >>>>> AggregationStrategy { > > >>>> >>> >>>>> > > >>>> >>> >>>>> @Override > > >>>> >>> >>>>> public Exchange aggregate(Exchange original, Exchange > > >>>> resource) > > >>>> >>> { > > >>>> >>> >>>>> return original; > > >>>> >>> >>>>> } > > >>>> >>> >>>>> > > >>>> >>> >>>>> } > > >>>> >>> >>>>> > > >>>> >>> >>>>> If I put a debug point on it, it is never fired .... > > >>>> >>> >>>>> > > >>>> >>> >>>>> > > >>>> >>> >>>>> > > >>>> >>> >>>>> > > >>>> >>> >>>>> > > >>>> >>> >>>>> 2013/3/6 Raúl Kripalani <r...@evosent.com> > > >>>> >>> >>>>> > > >>>> >>> >>>>>> Can we see the code of AggregationStrategyRessource? > > >>>> >>> >>>>>> > > >>>> >>> >>>>>> Regards, > > >>>> >>> >>>>>> Raúl. > > >>>> >>> >>>>>> > > >>>> >>> >>>>>> On Mar 5, 2013, at 23:30, Jean Francois LE BESCONT wrote: > > >>>> >>> >>>>>> > > >>>> >>> >>>>>> > Hey, > > >>>> >>> >>>>>> > > > >>>> >>> >>>>>> > I have this > > > >>>> >>> >>>>>> > > > >>>> >>> >>>>>> > > >>>> >>> > > >>>> > > > http://camel.465427.n5.nabble.com/Enrich-message-with-data-from-dynamic-sql-query-td5329427.html > > >>>> >>> >>>>>> > > > >>>> >>> >>>>>> > But I haven't found a solution to my question. > > >>>> >>> >>>>>> > > > >>>> >>> >>>>>> > How can enrich my stream with data from a queries ? > > >>>> >>> >>>>>> > > > >>>> >>> >>>>>> > I have a a route called from the start : > > >>>> >>> >>>>>> > > > >>>> >>> >>>>>> > from("direct:refreshReferentielDynamic") > > >>>> >>> >>>>>> > // > > >>>> >>> >>>>>> > .setBody(constant("SELECT * FROM TEST")) > > >>>> >>> >>>>>> > // > > >>>> >>> >>>>>> > .to("jdbc:dataSource") > > >>>> >>> >>>>>> > // > > >>>> >>> >>>>>> > .to("direct:ds") > > >>>> >>> >>>>>> > // > > >>>> >>> >>>>>> > .end(); > > >>>> >>> >>>>>> > > > >>>> >>> >>>>>> > > > >>>> >>> >>>>>> > End I would like to acces data in memory in direct:ds > > from > > >>>> an > > >>>> >>> other > > >>>> >>> >>>>>> route. > > >>>> >>> >>>>>> > I have try this : > > >>>> >>> >>>>>> > > > >>>> >>> >>>>>> > from("foo"). > > >>>> >>> >>>>>> > [...] > > >>>> >>> >>>>>> > .enrich("direct:ds", new > AggregationStrategyRessource()) > > >>>> >>> >>>>>> > > > >>>> >>> >>>>>> > But code in AggregationStrategyRessource is not called > > ... > > >>>> and > > >>>> >>> body > > >>>> >>> >>>>>> is > > >>>> >>> >>>>>> > replace by the content of the query. > > >>>> >>> >>>>>> > > > >>>> >>> >>>>>> > Thks ! > > >>>> >>> >>>>>> > > > >>>> >>> >>>>>> > Thks ! > > >>>> >>> >>>>>> > > >>>> >>> >>>>>> > > >>>> >>> >>>>> > > >>>> >>> >>>> > > >>>> >>> >>> > > >>>> >>> >> > > >>>> >>> > > >>>> >>> > > >>>> >>> > > >>>> >>> -- > > >>>> >>> Claus Ibsen > > >>>> >>> ----------------- > > >>>> >>> Red Hat, Inc. > > >>>> >>> FuseSource is now part of Red Hat > > >>>> >>> Email: cib...@redhat.com > > >>>> >>> Web: http://fusesource.com > > >>>> >>> Twitter: davsclaus > > >>>> >>> Blog: http://davsclaus.com > > >>>> >>> Author of Camel in Action: http://www.manning.com/ibsen > > >>>> >>> > > >>>> >> > > >>>> >> > > >>>> > > >>>> > > >>>> > > >>>> -- > > >>>> Claus Ibsen > > >>>> ----------------- > > >>>> Red Hat, Inc. > > >>>> FuseSource is now part of Red Hat > > >>>> Email: cib...@redhat.com > > >>>> Web: http://fusesource.com > > >>>> Twitter: davsclaus > > >>>> Blog: http://davsclaus.com > > >>>> Author of Camel in Action: http://www.manning.com/ibsen > > >>>> > > >>> > > >>> > > >> > > > > > > > > -- > > Claus Ibsen > > ----------------- > > Red Hat, Inc. > > FuseSource is now part of Red Hat > > Email: cib...@redhat.com > > Web: http://fusesource.com > > Twitter: davsclaus > > Blog: http://davsclaus.com > > Author of Camel in Action: http://www.manning.com/ibsen > > >