Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 7637675
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 31, 20262026-05-31T08:00:07+00:00 2026-05-31T08:00:07+00:00

In my customer table, ref is the auto increment and ID is the customer

  • 0

In my customer table, ref is the auto increment and ID is the customer identification number. Hence there are multiple ID for each customer (which form a history of each customer). I want to update the most recent record for each customer by setting the likelihood field to 1 in all cases – but without creating a new record.

I thought a query like this would do the job:

UPDATE customer SET likelihood = 1 WHERE customer.ref IN
(SELECT MAX(ref) FROM customer GROUP BY ID)

but I get the following error:

“#1093 – You can’t specify target table ‘customer’ for update in FROM clause”

Where am I going wrong?

Edit:
Some sample data (not the complete table)

ref | ID | likelihood | name
----+----+------------+-----
  1 |  1 |          0 | a
  2 |  2 |          0 | b
  3 |  1 |          0 | a
  4 |  2 |          0 | b
  5 |  1 |          0 | a
  6 |  1 |          0 | a

So I want to pick out:

  4 |  2 |          0 | b
  6 |  1 |          0 | a

and change them to:

  4 |  2 |          1 | b
  6 |  1 |          1 | a
  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-05-31T08:00:09+00:00Added an answer on May 31, 2026 at 8:00 am

    I cannot remember whether it will allow a self join in an update. Give this a try –

    UPDATE customer c1
    LEFT JOIN customer c2
        ON c1.ID = c2.ID
        AND c1.ref < c2.ref
    SET c1.likelihood = 1
    WHERE c2.ID IS NULL
    

    EDIT I have changed the column used in the second join condition from ID to ref.

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

I have a Customer table with a Primary key (int auto increment) and an
There is a customer table. I want to list active and inactive status in
Let's say I have a Customer table which has a PrimaryContactId field and a
I am trying to implement NOT NULL constraint in the customer table which is
I want to update a customer table with a spreadsheet from our accounting system.
Say we have customer table which has record CustId LastName 1 Hamlin In one
I have a customer table, which has a field categories. It's a string holding
I have a Customer table with 200.000+ records which i have to loop through
I have couple of rows in database table (lets call it Customer), each row
I have a customer table in sqlserver which contains a rowversion field and I

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.