Unexpected failure in PHP / Laravel Query
I have a query I am running using Laravel, which runs absolutely fine on my development host, however I get an error when I deploy it to my UAT host. I have simplified all examples to make it easier to work out what is going on.
The simplified code:
DB::select("SELECT c.*
FROM (SELECT 0 AS xxx, u.* FROM users u) c
ORDER BY c.xxx DESC");
The error:
SQLSTATE[42S22]: Column not found: 1054 Unknown column 'c.xxx' in 'order clause' (SQL: SELECT c.*
FROM (SELECT 0 AS xxx, u.* FROM users u) c
ORDER BY c.xxx DESC)
When I run the following query in Workbench directly, it works absolutely fine:
SELECT c.*
FROM (SELECT 0 AS xxx,
u.*
FROM users u) c
ORDER BY c.xxx DESC
So in short, it works on dev DB directly, works within dev code, works on UAT DB directly but fails on UAT application.
Any ideas why the database query could possibly behave differently to the query run via Laravel / php? Any idea why one machine would behave fine and there other display the above error?
php mysql laravel
|
show 4 more comments
I have a query I am running using Laravel, which runs absolutely fine on my development host, however I get an error when I deploy it to my UAT host. I have simplified all examples to make it easier to work out what is going on.
The simplified code:
DB::select("SELECT c.*
FROM (SELECT 0 AS xxx, u.* FROM users u) c
ORDER BY c.xxx DESC");
The error:
SQLSTATE[42S22]: Column not found: 1054 Unknown column 'c.xxx' in 'order clause' (SQL: SELECT c.*
FROM (SELECT 0 AS xxx, u.* FROM users u) c
ORDER BY c.xxx DESC)
When I run the following query in Workbench directly, it works absolutely fine:
SELECT c.*
FROM (SELECT 0 AS xxx,
u.*
FROM users u) c
ORDER BY c.xxx DESC
So in short, it works on dev DB directly, works within dev code, works on UAT DB directly but fails on UAT application.
Any ideas why the database query could possibly behave differently to the query run via Laravel / php? Any idea why one machine would behave fine and there other display the above error?
php mysql laravel
1
DB::raw("SELECT c.* FROM (SELECT 0 AS xxx, u.* FROM users u) c ORDER BY c.xxx DESC"); try this ?
– Anar Bayramov
Nov 20 '18 at 10:09
Did you use migrations for the database?
– Sander Visser
Nov 20 '18 at 10:10
Did you tried setting xxx between SQL quotes ``, like : SELECT 0 AS `xxx`
– csblo
Nov 20 '18 at 10:10
1
why do you want to order by a fixed-value column?? All the rows will have the same value anyway.
– ADyson
Nov 20 '18 at 10:11
The above is for demo purposes. I have simplified the problem as much as I could, in the final code this will not be a fixed value.
– Blueberry
Nov 20 '18 at 10:14
|
show 4 more comments
I have a query I am running using Laravel, which runs absolutely fine on my development host, however I get an error when I deploy it to my UAT host. I have simplified all examples to make it easier to work out what is going on.
The simplified code:
DB::select("SELECT c.*
FROM (SELECT 0 AS xxx, u.* FROM users u) c
ORDER BY c.xxx DESC");
The error:
SQLSTATE[42S22]: Column not found: 1054 Unknown column 'c.xxx' in 'order clause' (SQL: SELECT c.*
FROM (SELECT 0 AS xxx, u.* FROM users u) c
ORDER BY c.xxx DESC)
When I run the following query in Workbench directly, it works absolutely fine:
SELECT c.*
FROM (SELECT 0 AS xxx,
u.*
FROM users u) c
ORDER BY c.xxx DESC
So in short, it works on dev DB directly, works within dev code, works on UAT DB directly but fails on UAT application.
Any ideas why the database query could possibly behave differently to the query run via Laravel / php? Any idea why one machine would behave fine and there other display the above error?
php mysql laravel
I have a query I am running using Laravel, which runs absolutely fine on my development host, however I get an error when I deploy it to my UAT host. I have simplified all examples to make it easier to work out what is going on.
The simplified code:
DB::select("SELECT c.*
FROM (SELECT 0 AS xxx, u.* FROM users u) c
ORDER BY c.xxx DESC");
The error:
SQLSTATE[42S22]: Column not found: 1054 Unknown column 'c.xxx' in 'order clause' (SQL: SELECT c.*
FROM (SELECT 0 AS xxx, u.* FROM users u) c
ORDER BY c.xxx DESC)
When I run the following query in Workbench directly, it works absolutely fine:
SELECT c.*
FROM (SELECT 0 AS xxx,
u.*
FROM users u) c
ORDER BY c.xxx DESC
So in short, it works on dev DB directly, works within dev code, works on UAT DB directly but fails on UAT application.
Any ideas why the database query could possibly behave differently to the query run via Laravel / php? Any idea why one machine would behave fine and there other display the above error?
php mysql laravel
php mysql laravel
asked Nov 20 '18 at 10:07
BlueberryBlueberry
1,61621227
1,61621227
1
DB::raw("SELECT c.* FROM (SELECT 0 AS xxx, u.* FROM users u) c ORDER BY c.xxx DESC"); try this ?
– Anar Bayramov
Nov 20 '18 at 10:09
Did you use migrations for the database?
– Sander Visser
Nov 20 '18 at 10:10
Did you tried setting xxx between SQL quotes ``, like : SELECT 0 AS `xxx`
– csblo
Nov 20 '18 at 10:10
1
why do you want to order by a fixed-value column?? All the rows will have the same value anyway.
– ADyson
Nov 20 '18 at 10:11
The above is for demo purposes. I have simplified the problem as much as I could, in the final code this will not be a fixed value.
– Blueberry
Nov 20 '18 at 10:14
|
show 4 more comments
1
DB::raw("SELECT c.* FROM (SELECT 0 AS xxx, u.* FROM users u) c ORDER BY c.xxx DESC"); try this ?
– Anar Bayramov
Nov 20 '18 at 10:09
Did you use migrations for the database?
– Sander Visser
Nov 20 '18 at 10:10
Did you tried setting xxx between SQL quotes ``, like : SELECT 0 AS `xxx`
– csblo
Nov 20 '18 at 10:10
1
why do you want to order by a fixed-value column?? All the rows will have the same value anyway.
– ADyson
Nov 20 '18 at 10:11
The above is for demo purposes. I have simplified the problem as much as I could, in the final code this will not be a fixed value.
– Blueberry
Nov 20 '18 at 10:14
1
1
DB::raw("SELECT c.* FROM (SELECT 0 AS xxx, u.* FROM users u) c ORDER BY c.xxx DESC"); try this ?
– Anar Bayramov
Nov 20 '18 at 10:09
DB::raw("SELECT c.* FROM (SELECT 0 AS xxx, u.* FROM users u) c ORDER BY c.xxx DESC"); try this ?
– Anar Bayramov
Nov 20 '18 at 10:09
Did you use migrations for the database?
– Sander Visser
Nov 20 '18 at 10:10
Did you use migrations for the database?
– Sander Visser
Nov 20 '18 at 10:10
Did you tried setting xxx between SQL quotes ``, like : SELECT 0 AS `xxx`
– csblo
Nov 20 '18 at 10:10
Did you tried setting xxx between SQL quotes ``, like : SELECT 0 AS `xxx`
– csblo
Nov 20 '18 at 10:10
1
1
why do you want to order by a fixed-value column?? All the rows will have the same value anyway.
– ADyson
Nov 20 '18 at 10:11
why do you want to order by a fixed-value column?? All the rows will have the same value anyway.
– ADyson
Nov 20 '18 at 10:11
The above is for demo purposes. I have simplified the problem as much as I could, in the final code this will not be a fixed value.
– Blueberry
Nov 20 '18 at 10:14
The above is for demo purposes. I have simplified the problem as much as I could, in the final code this will not be a fixed value.
– Blueberry
Nov 20 '18 at 10:14
|
show 4 more comments
0
active
oldest
votes
Your Answer
StackExchange.ifUsing("editor", function () {
StackExchange.using("externalEditor", function () {
StackExchange.using("snippets", function () {
StackExchange.snippets.init();
});
});
}, "code-snippets");
StackExchange.ready(function() {
var channelOptions = {
tags: "".split(" "),
id: "1"
};
initTagRenderer("".split(" "), "".split(" "), channelOptions);
StackExchange.using("externalEditor", function() {
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled) {
StackExchange.using("snippets", function() {
createEditor();
});
}
else {
createEditor();
}
});
function createEditor() {
StackExchange.prepareEditor({
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: true,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader: {
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
},
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
});
}
});
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53390612%2funexpected-failure-in-php-laravel-query%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
0
active
oldest
votes
0
active
oldest
votes
active
oldest
votes
active
oldest
votes
Thanks for contributing an answer to Stack Overflow!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53390612%2funexpected-failure-in-php-laravel-query%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
1
DB::raw("SELECT c.* FROM (SELECT 0 AS xxx, u.* FROM users u) c ORDER BY c.xxx DESC"); try this ?
– Anar Bayramov
Nov 20 '18 at 10:09
Did you use migrations for the database?
– Sander Visser
Nov 20 '18 at 10:10
Did you tried setting xxx between SQL quotes ``, like : SELECT 0 AS `xxx`
– csblo
Nov 20 '18 at 10:10
1
why do you want to order by a fixed-value column?? All the rows will have the same value anyway.
– ADyson
Nov 20 '18 at 10:11
The above is for demo purposes. I have simplified the problem as much as I could, in the final code this will not be a fixed value.
– Blueberry
Nov 20 '18 at 10:14