Discussions

Stay up-to-date with the latest news from NetSuite. You’ll be in the know about how to connect with peers and take your business to new heights at our virtual, in-person, on demand events, and much more.
Now is the time to ask your NetSuite-savvy friends and colleagues to join the NetSuite Support Community! Refer now! Click here to watch and learn more!
Update your Profile with your Support type to get your Support Type badge.
Don't miss out on our Pop Quiz You only have until November 7, 2025, 2:00PM ET to comment your answers and earn rewards! Click here for more details.
Uncover the power of data with the Analytics Hub —your ultimate guide to mastering NetSuite Saved Searches and Reports. Simplify the complex and unlock your organization's true potential. Dive into the Analytics Hub now and soar to new heights!
To help you get the most out of your 2025.2 Release Preview account, review the topics outlined in the 2025.2 Release Preview Guide.
Nominate Your Peers for NetSuite Support Community's Choice of the Quarter! Submit your nomination today.
Intelligent Payment Automation version 1.0.3 is now available in the SuiteApp Marketplace. The SuiteApp, powered by BILL, lets you automate payments, manage vendor details, and bank account information within NetSuite. Learn more

Map/Reduce Unexpected Type Conversions

edited Dec 2, 2019 5:46PM in SuiteCloud / Customization 4 comments

I am building a very simple prototype Map/Reduce script just to get an idea of the data flow through each phase. I am seeing what I consider unexpected behaviour when passing data from the map phase to the reduce phase. It seems that no matter what type of data is written to the context during map, it will always come out as Strings during reduce.

Consider the following code (the module define and return object have been removed for brevity, but they are correct):

/**   * The input data is just a list of Strings.    */  function getInputData() {      return ["a", "string", "array", "for", "testing", "data"];  }    /**   * The map phase gets the length of each String from the input data and   * writes it back to the context in three different formats: Number, String,   * Object   */  function map(context) {      log.debug(arguments.callee.name, context);      context.write('numberData', context.value.length);      context.write('stringData', context.value.length.toString());      context.write('objectData', {'length' : context.value.length});  }    /**   * The reduce phase currently just logs what it receives   */  function reduce(context) {      log.debug(arguments.callee.name + ':' + context.key, context.values);  }    function summarize(summary) {      log.debug(arguments.callee.name, summary);  }

Howdy, Stranger!

Log In

To view full details, sign in.

Register

Don't have an account? Click here to get started!

Leaderboard

Community Whiz

Quarter 4 (Oct-Dec 2025)

This Week's Leaders

This Month's Leaders

All Time Leaders