I am getting error during executing the function “subquery must return only one column”












1















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';









share|improve this question




















  • 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


















1















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';









share|improve this question




















  • 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
















1












1








1








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';









share|improve this question
















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






share|improve this question















share|improve this question













share|improve this question




share|improve this question








edited Nov 23 '18 at 11:17









a_horse_with_no_name

306k46468566




306k46468566










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
















  • 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














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
});


}
});














draft saved

draft discarded


















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
















draft saved

draft discarded




















































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.




draft saved


draft discarded














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





















































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







這個網誌中的熱門文章

Tangent Lines Diagram Along Smooth Curve

Yusuf al-Mu'taman ibn Hud

Zucchini