I am getting error during executing the function “subquery must return only one column”
I am getting error as "subquery must return only one column". Because i have more employees in each department. Tell me the solution to fix this issue
CREATE OR REPLACE FUNCTION dept_emp()
RETURNS TEXT AS
$$
DECLARE
cur_dept CURSOR FOR SELECT dept_name FROM dept;
cur_emp CURSOR FOR SELECT employee_id,dob,department FROM emp;
d RECORD;
e RECORD;
BEGIN
FOR d IN SELECT dept_name FROM dept
LOOP
FOR e IN SELECT employee_id,dob,department FROM emp
LOOP
RAISE NOTICE 'Department: %',d.dept_name;
RETURN (SELECT employee_id,dob FROM emp WHERE d.dept_name=e.department);
END LOOP;
END LOOP;
END;
$$ LANGUAGE 'plpgsql';
sql postgresql subquery
|
show 2 more comments
I am getting error as "subquery must return only one column". Because i have more employees in each department. Tell me the solution to fix this issue
CREATE OR REPLACE FUNCTION dept_emp()
RETURNS TEXT AS
$$
DECLARE
cur_dept CURSOR FOR SELECT dept_name FROM dept;
cur_emp CURSOR FOR SELECT employee_id,dob,department FROM emp;
d RECORD;
e RECORD;
BEGIN
FOR d IN SELECT dept_name FROM dept
LOOP
FOR e IN SELECT employee_id,dob,department FROM emp
LOOP
RAISE NOTICE 'Department: %',d.dept_name;
RETURN (SELECT employee_id,dob FROM emp WHERE d.dept_name=e.department);
END LOOP;
END LOOP;
END;
$$ LANGUAGE 'plpgsql';
sql postgresql subquery
5
Your function return only one value of type text. But in your return clause you try to return 'employee_id,dob' which is obviously not a simple text value.
– StephaneM
Nov 23 '18 at 10:14
In my dept table i'm having 10 departments. In emp table am having 30 records(3 records for each department). Thats Y it returns 'more than one row returned'.
– Deepan
Nov 23 '18 at 11:11
My Output should looks like this
– Deepan
Nov 23 '18 at 11:13
I need a output like this Department : Sales 1.employee_id, dob 2.employee_id, dob 3.employee_id, dob Department : Marketing 1.employee_id, dob 2.employee_id, dob 3.employee_id, dob
– Deepan
Nov 23 '18 at 11:14
1
Why don't you just join all those tables in a simple SQL statement? Nested FOR loops or even a function seems completely unnecessary here.
– a_horse_with_no_name
Nov 23 '18 at 11:18
|
show 2 more comments
I am getting error as "subquery must return only one column". Because i have more employees in each department. Tell me the solution to fix this issue
CREATE OR REPLACE FUNCTION dept_emp()
RETURNS TEXT AS
$$
DECLARE
cur_dept CURSOR FOR SELECT dept_name FROM dept;
cur_emp CURSOR FOR SELECT employee_id,dob,department FROM emp;
d RECORD;
e RECORD;
BEGIN
FOR d IN SELECT dept_name FROM dept
LOOP
FOR e IN SELECT employee_id,dob,department FROM emp
LOOP
RAISE NOTICE 'Department: %',d.dept_name;
RETURN (SELECT employee_id,dob FROM emp WHERE d.dept_name=e.department);
END LOOP;
END LOOP;
END;
$$ LANGUAGE 'plpgsql';
sql postgresql subquery
I am getting error as "subquery must return only one column". Because i have more employees in each department. Tell me the solution to fix this issue
CREATE OR REPLACE FUNCTION dept_emp()
RETURNS TEXT AS
$$
DECLARE
cur_dept CURSOR FOR SELECT dept_name FROM dept;
cur_emp CURSOR FOR SELECT employee_id,dob,department FROM emp;
d RECORD;
e RECORD;
BEGIN
FOR d IN SELECT dept_name FROM dept
LOOP
FOR e IN SELECT employee_id,dob,department FROM emp
LOOP
RAISE NOTICE 'Department: %',d.dept_name;
RETURN (SELECT employee_id,dob FROM emp WHERE d.dept_name=e.department);
END LOOP;
END LOOP;
END;
$$ LANGUAGE 'plpgsql';
sql postgresql subquery
sql postgresql subquery
edited Nov 23 '18 at 11:17
a_horse_with_no_name
292k46446541
292k46446541
asked Nov 23 '18 at 10:11
DeepanDeepan
61
61
5
Your function return only one value of type text. But in your return clause you try to return 'employee_id,dob' which is obviously not a simple text value.
– StephaneM
Nov 23 '18 at 10:14
In my dept table i'm having 10 departments. In emp table am having 30 records(3 records for each department). Thats Y it returns 'more than one row returned'.
– Deepan
Nov 23 '18 at 11:11
My Output should looks like this
– Deepan
Nov 23 '18 at 11:13
I need a output like this Department : Sales 1.employee_id, dob 2.employee_id, dob 3.employee_id, dob Department : Marketing 1.employee_id, dob 2.employee_id, dob 3.employee_id, dob
– Deepan
Nov 23 '18 at 11:14
1
Why don't you just join all those tables in a simple SQL statement? Nested FOR loops or even a function seems completely unnecessary here.
– a_horse_with_no_name
Nov 23 '18 at 11:18
|
show 2 more comments
5
Your function return only one value of type text. But in your return clause you try to return 'employee_id,dob' which is obviously not a simple text value.
– StephaneM
Nov 23 '18 at 10:14
In my dept table i'm having 10 departments. In emp table am having 30 records(3 records for each department). Thats Y it returns 'more than one row returned'.
– Deepan
Nov 23 '18 at 11:11
My Output should looks like this
– Deepan
Nov 23 '18 at 11:13
I need a output like this Department : Sales 1.employee_id, dob 2.employee_id, dob 3.employee_id, dob Department : Marketing 1.employee_id, dob 2.employee_id, dob 3.employee_id, dob
– Deepan
Nov 23 '18 at 11:14
1
Why don't you just join all those tables in a simple SQL statement? Nested FOR loops or even a function seems completely unnecessary here.
– a_horse_with_no_name
Nov 23 '18 at 11:18
5
5
Your function return only one value of type text. But in your return clause you try to return 'employee_id,dob' which is obviously not a simple text value.
– StephaneM
Nov 23 '18 at 10:14
Your function return only one value of type text. But in your return clause you try to return 'employee_id,dob' which is obviously not a simple text value.
– StephaneM
Nov 23 '18 at 10:14
In my dept table i'm having 10 departments. In emp table am having 30 records(3 records for each department). Thats Y it returns 'more than one row returned'.
– Deepan
Nov 23 '18 at 11:11
In my dept table i'm having 10 departments. In emp table am having 30 records(3 records for each department). Thats Y it returns 'more than one row returned'.
– Deepan
Nov 23 '18 at 11:11
My Output should looks like this
– Deepan
Nov 23 '18 at 11:13
My Output should looks like this
– Deepan
Nov 23 '18 at 11:13
I need a output like this Department : Sales 1.employee_id, dob 2.employee_id, dob 3.employee_id, dob Department : Marketing 1.employee_id, dob 2.employee_id, dob 3.employee_id, dob
– Deepan
Nov 23 '18 at 11:14
I need a output like this Department : Sales 1.employee_id, dob 2.employee_id, dob 3.employee_id, dob Department : Marketing 1.employee_id, dob 2.employee_id, dob 3.employee_id, dob
– Deepan
Nov 23 '18 at 11:14
1
1
Why don't you just join all those tables in a simple SQL statement? Nested FOR loops or even a function seems completely unnecessary here.
– a_horse_with_no_name
Nov 23 '18 at 11:18
Why don't you just join all those tables in a simple SQL statement? Nested FOR loops or even a function seems completely unnecessary here.
– a_horse_with_no_name
Nov 23 '18 at 11:18
|
show 2 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%2f53444649%2fi-am-getting-error-during-executing-the-function-subquery-must-return-only-one%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.
Some of your past answers have not been well-received, and you're in danger of being blocked from answering.
Please pay close attention to the following guidance:
- 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%2f53444649%2fi-am-getting-error-during-executing-the-function-subquery-must-return-only-one%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
5
Your function return only one value of type text. But in your return clause you try to return 'employee_id,dob' which is obviously not a simple text value.
– StephaneM
Nov 23 '18 at 10:14
In my dept table i'm having 10 departments. In emp table am having 30 records(3 records for each department). Thats Y it returns 'more than one row returned'.
– Deepan
Nov 23 '18 at 11:11
My Output should looks like this
– Deepan
Nov 23 '18 at 11:13
I need a output like this Department : Sales 1.employee_id, dob 2.employee_id, dob 3.employee_id, dob Department : Marketing 1.employee_id, dob 2.employee_id, dob 3.employee_id, dob
– Deepan
Nov 23 '18 at 11:14
1
Why don't you just join all those tables in a simple SQL statement? Nested FOR loops or even a function seems completely unnecessary here.
– a_horse_with_no_name
Nov 23 '18 at 11:18