I have a table called “users” with 4 fields: ID, UNAME, NAME, SHOW_NAME.
I wish to put this data into one view so that if SHOW_NAME is not set, “UNAME” should be selected as “NAME”, otherwise “NAME”.
My current query:
SELECT id AS id, uname AS name
FROM users
WHERE show_name != 1
UNION
SELECT id AS id, name AS name
FROM users
WHERE show_name = 1
This generally works, but it does seem to lose the primary key (NaviCat telling me “users_view does not have a primary key…”) – which I think is bad.
Is there a better way?
That should be fine. I’m not sure why it’s complaining about the loss of a primary key.
I will offer one piece of advice. When you know that there can be no duplicates in your union (such as the two parts being
when x = 1andwhen x != 1), you should useunion all.The
unionclause will attempt to remove duplicates which, in this case, is a waste of time.If you want more targeted assistance, it’s probably best if you post the details of the view and the underlying table. Views themselves don’t tend to have primary keys or indexes, relying instead on the underlying tables.
So this may well be a problem with your “NaviCat” product (whatever that is) expecting to see a primary key (in other words, it’s not built very well for views).