Re: BUG #18310: Some SQL commands fail to process duplicate objects with error: tuple already updated by self

From: Yongtao Huang <yongtaoh2022(at)gmail(dot)com>
To: Tender Wang <tndrwang(at)gmail(dot)com>, pgsql-bugs(at)lists(dot)postgresql(dot)org
Subject: Re: BUG #18310: Some SQL commands fail to process duplicate objects with error: tuple already updated by self
Date: 2024-01-27 17:32:08
Message-ID: CAOe1Go1N1XHYMXOq6+0=Awcpngmc9ei+3Jou2Om6o=giW+3pvw@mail.gmail.com
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-bugs

Hi Tender Wang,

I think your code changes *LGTM*. Thanks for your contribution.

But I meet these errors when I git apply your patch, so I do some tiny
formate modification.
Please refer to the patch which is still authored by you.

``` bash
$ git apply 0001-Fix-reporting-error-when-process-duplicate-token-typ.patch
0001-Fix-reporting-error-when-process-duplicate-token-typ.patch:38: indent
with spaces.
List *tokennames = stmt->tokentype;
0001-Fix-reporting-error-when-process-duplicate-token-typ.patch:73: indent
with spaces.
{
0001-Fix-reporting-error-when-process-duplicate-token-typ.patch:74: indent
with spaces.
if (!stmt->missing_ok)
0001-Fix-reporting-error-when-process-duplicate-token-typ.patch:75: indent
with spaces.
ereport(ERROR,
0001-Fix-reporting-error-when-process-duplicate-token-typ.patch:76: indent
with spaces.
(errcode(ERRCODE_INVALID_PARAMETER_VALUE),
warning: squelched 9 whitespace errors
warning: 14 lines add whitespace errors.
```

Regrads

Yongtao Huang
Broadcom Greenplum

Tender Wang <tndrwang(at)gmail(dot)com> 于2024年1月26日周五 14:21写道:

>
>
> Tender Wang <tndrwang(at)gmail(dot)com> 于2024年1月26日周五 12:54写道:
>
>>
>>
>> Michael Paquier <michael(at)paquier(dot)xyz> 于2024年1月26日周五 11:41写道:
>>
>>> On Fri, Jan 26, 2024 at 11:33:24AM +0800, Tender Wang wrote:
>>> > How about using list *res replace int *res in getTokenTypes(), so we
>>> can
>>> > use list_append_unique().
>>> > In outer function, use list *tokens to replace int *tokens, and
>>> ntokens =
>>> > list_length(tokens) not list_length(stmt->tokentype).
>>>
>>> Yeah, I was wondering about this code path. If you feel strongly
>>> about that, would you like to write a patch?
>>>
>>
>> Ok, I try to fix it.
>>
>
> As I said before, return List looks like not complicated to solve this
> issue.
> I found another problem, it didn't report NOTICE if SQL has IF EXISTS, for
> example:
>
> postgres=# alter text search configuration ispell_tst drop mapping if
> exists for test;
> ERROR: token type "test" does not exist
>
> So I change the func getTokenTypes() interface and remove
> DropConfigurationMapping() error report into getTokenTypes().
>
>
> --
>>> Michael
>>>
>>
>>
>> --
>> Tender Wang
>> OpenPie: https://en.openpie.com/
>>
>
>
> --
> Tender Wang
> OpenPie: https://en.openpie.com/
>

Attachment Content-Type Size
0001-Fix-error-when-process-duplicate-token-in-tsearch.patch application/octet-stream 7.5 KB

In response to

Responses

Browse pgsql-bugs by date

  From Date Subject
Next Message Michael Paquier 2024-01-28 23:18:21 Re: BUG #18310: Some SQL commands fail to process duplicate objects with error: tuple already updated by self
Previous Message David Rowley 2024-01-27 00:36:22 Re: v17 Possible Union All Bug