Skip to Main Content
IBM Power Ideas Portal


This portal is to open public enhancement requests against IBM Power Systems products, including IBM i. To view all of your ideas submitted to IBM, create and manage groups of Ideas, or create an idea explicitly set to be either visible by all (public) or visible only to you and IBM (private), use the IBM Unified Ideas Portal (https://ideas.ibm.com).


Shape the future of IBM!

We invite you to shape the future of IBM, including product roadmaps, by submitting ideas that matter to you the most. Here's how it works:

Search existing ideas

Start by searching and reviewing ideas and requests to enhance a product or service. Take a look at ideas others have posted, and add a comment, vote, or subscribe to updates on them if they matter to you. If you can't find what you are looking for,

Post your ideas
  1. Post an idea.

  2. Get feedback from the IBM team and other customers to refine your idea.

  3. Follow the idea through the IBM Ideas process.


Specific links you will want to bookmark for future use

Welcome to the IBM Ideas Portal (https://www.ibm.com/ideas) - Use this site to find out additional information and details about the IBM Ideas process and statuses.

IBM Unified Ideas Portal (https://ideas.ibm.com) - Use this site to view all of your ideas, create new ideas for any IBM product, or search for ideas across all of IBM.

ideasibm@us.ibm.com - Use this email to suggest enhancements to the Ideas process or request help from IBM for submitting your Ideas.

Status Not under consideration
Workspace IBM i
Categories Db2 for i
Created by Guest
Created on Aug 22, 2023

JSON_UPDATE - Updating a true/false value

Whith JSON_UPDATE it is possible to modify existing JSON data. It is possbile to exchange a single value, to add a key/value pair, to exchange an existing Object, to add an existing Object, exchange an array and add a new array.

... but it is not possible to exchange a Boolean value, i.e. it is not possible to exchange the true literal in the following JSON document with false. The Boolean value (i.e. true or false without quotes arroung) is replaced with a string, i.e. "TRUE" or "FALSE". 

The only way to exhange the true/false literal, is to rxchange the whole Object. (a true/false literal in an object is not converted into a  string).

It would be great if we could not only replace numeric values and strings and null values, but also true and false literals without replacing the whole object. 

Idea priority Medium
  • Guest
    Reply
    |
    Sep 23, 2023
    IBM does not intend to provide a solution to this Idea at this time, so it is being closed.

    This request to convert the SQL Boolean data type directly to a JSON Boolean value cannot be implemented without adding extra syntax to the JSON_UPDATE function due to compatibility considerations. While this could be done, this support will not be provided any time soon so the Idea is being closed.

    As an alternative, a Boolean value can be converted to a JSON Boolean value by using a CASE construct. This allows the value to be updated without reconstructing the entire object.

    create variable mylib.boolvar boolean;
    set mylib.boolvar = true;
    values JSON_UPDATE('{"a":7}','SET','$.a',mylib.boolvar); -- {"a":"TRUE"}
    values JSON_UPDATE('{"a":7}','SET','$.a', case mylib.boolvar when true then 'true' when false then 'false' end); -- {"a":true}


    Db2 for i development team
    IBM Power Systems Development