Uploaded image for project: 'MariaDB Server'
  1. MariaDB Server
  2. MDEV-11205

UDF_ARGS "attribute_lengths" incorrect value

Details

    • Bug
    • Status: Closed (View Workflow)
    • Major
    • Resolution: Fixed
    • 5.5(EOL), 10.0(EOL), 10.1(EOL)
    • 5.5.58
    • OTHER
    • Arch Linux
      Linux kernel 4.4.23-1-lts
      Lenovo ThinkPad E540

    Description

      I try to use User Defined Function lib_mysqludf_json from https://github.com/mysqludf/lib_mysqludf_json with MariaDB 10.1.18 and found an incorrect behavior of UDF_ARGS attribute_lengths.

      typedef struct st_udf_args
      {
      ...
        unsigned long *attribute_lengths;     /* Length of attribute arguments */
      ...
      } UDF_ARGS;
      

      Example:
      When you use SELECT json_object("citizen_id") FROM ...
      you will have:

      args->attributes[0] = "citizen_id"
      args->attribute_lengths[0] = 12
      

      That's correct.

      When you use SELECT json_object(citizen_id AS citizen_id) FROM ...

      args->attributes[0] = citizen_id
      args->attribute_lengths[0] = 10
      

      That's also correct.

      But when you use SELECT json_object(citizen_id) FROM ...

      args->attributes[0] = citizen_id
      args->attribute_lengths[0] = 0
      

      That's incorrect. Correct value of attribute_lengths[0] is 10.

      That's not reproducable on MySQL. This is not lib_mysqludf_json incorrect behavior, it just uses standart struct UDF_ARGS.

      Attachments

        Activity

          Sirakuzi Alexander Sidorov created issue -
          elenst Elena Stepanova made changes -
          Field Original Value New Value
          Description I try to use User Defined Function lib_mysqludf_json from https://github.com/mysqludf/lib_mysqludf_json with MariaDB 10.1.18 and found an incorrect behavior of UDF_ARGS attribute_lengths.

          typedef struct st_udf_args
          {
          ...
            unsigned long *attribute_lengths; /* Length of attribute arguments */
          ...
          } UDF_ARGS;

          Example:
          When you use SELECT json_object("citizen_id") FROM ...
          you will have:
          args->attributes[0] = "citizen_id"
          args->attribute_lengths[0] = 12
          That's correct.

          When you use SELECT json_object(citizen_id AS citizen_id) FROM ...
          args->attributes[0] = citizen_id
          args->attribute_lengths[0] = 10
          That's also correct.

          But when you use SELECT json_object(citizen_id) FROM ...
          args->attributes[0] = citizen_id
          args->attribute_lengths[0] = 0
          That's incorrect. Correct value of attribute_lengths[0] is 10.

          That's not reproducable on MySQL. This is not lib_mysqludf_json incorrect behavior, it just uses standart struct UDF_ARGS.
          I try to use User Defined Function lib_mysqludf_json from https://github.com/mysqludf/lib_mysqludf_json with MariaDB 10.1.18 and found an incorrect behavior of UDF_ARGS attribute_lengths.

          {noformat}
          typedef struct st_udf_args
          {
          ...
            unsigned long *attribute_lengths; /* Length of attribute arguments */
          ...
          } UDF_ARGS;
          {noformat}

          Example:
          When you use SELECT json_object("citizen_id") FROM ...
          you will have:
          {noformat}
          args->attributes[0] = "citizen_id"
          args->attribute_lengths[0] = 12
          {noformat}
          That's correct.

          When you use SELECT json_object(citizen_id AS citizen_id) FROM ...
          {noformat}
          args->attributes[0] = citizen_id
          args->attribute_lengths[0] = 10
          {noformat}
          That's also correct.

          But when you use SELECT json_object(citizen_id) FROM ...
          {noformat}
          args->attributes[0] = citizen_id
          args->attribute_lengths[0] = 0
          {noformat}
          That's incorrect. Correct value of attribute_lengths[0] is 10.

          That's not reproducable on MySQL. This is not lib_mysqludf_json incorrect behavior, it just uses standart struct UDF_ARGS.
          elenst Elena Stepanova made changes -
          Status Open [ 1 ] Confirmed [ 10101 ]
          elenst Elena Stepanova made changes -
          Fix Version/s 10.1 [ 16100 ]
          Affects Version/s 5.5 [ 15800 ]
          Affects Version/s 10.0 [ 16000 ]
          Affects Version/s 10.1 [ 16100 ]
          Affects Version/s 10.1.18 [ 22110 ]
          Assignee Alexey Botchkov [ holyfoot ]
          Labels upstream-fixed
          serg Sergei Golubchik made changes -
          Fix Version/s 5.5 [ 15800 ]
          Fix Version/s 10.0 [ 16000 ]
          holyfoot Alexey Botchkov made changes -
          Status Confirmed [ 10101 ] In Progress [ 3 ]
          holyfoot Alexey Botchkov made changes -
          issue.field.resolutiondate 2017-07-18 09:44:09.0 2017-07-18 09:44:09.941
          holyfoot Alexey Botchkov made changes -
          Fix Version/s 5.5.58 [ 22540 ]
          Fix Version/s 5.5 [ 15800 ]
          Fix Version/s 10.0 [ 16000 ]
          Fix Version/s 10.1 [ 16100 ]
          Resolution Fixed [ 1 ]
          Status In Progress [ 3 ] Closed [ 6 ]
          serg Sergei Golubchik made changes -
          Workflow MariaDB v3 [ 78170 ] MariaDB v4 [ 151167 ]

          People

            holyfoot Alexey Botchkov
            Sirakuzi Alexander Sidorov
            Votes:
            0 Vote for this issue
            Watchers:
            4 Start watching this issue

            Dates

              Created:
              Updated:
              Resolved:

              Git Integration

                Error rendering 'com.xiplink.jira.git.jira_git_plugin:git-issue-webpanel'. Please contact your Jira administrators.