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 8510193
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: June 11, 20262026-06-11T03:38:12+00:00 2026-06-11T03:38:12+00:00

I would like to group by Company & Date and generate count columns for

  • 0

I would like to group by Company & Date and generate count columns for 2 separate values (Flag=Y and Flag=N).
Input table looks like this:

Company  Date   Flag
------- ------- -----
001      201201  Y
001      201201  N
001      201202  N
001      201202  N
001      201202  Y

The output should look like this:

Company Date   Count_Y Count_N
------- ------ ------- -------
001     201201  1       1
001     201202  1       2

How can I write the SQL query?
Any kind of help is appreciated! Thanks!

  • 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-06-11T03:38:14+00:00Added an answer on June 11, 2026 at 3:38 am

    You can do it using correlated subqueries like this:

    SELECT 
      Company, 
      Date, 
      (SELECT COUNT(*) FROM MyTable AS T1 
         WHERE T1.Flag='Y' AND T1.Company=T2.Company AND T1.Date=T2.Date) AS Count_Y,
      (SELECT COUNT(*) FROM MyTable AS T1 
         WHERE T1.Flag='N' AND T1.Company=T2.Company AND T1.Date=T2.Date) AS Count_N
    FROM MyTable AS T2
    GROUP BY Company, Date
    

    You can also do it more concisely, but perhaps with (arguably) slighly less readability using the SUM trick:

    SELECT 
      Company, 
      Date, 
      SUM(CASE WHEN Flag='Y' THEN 1 ELSE 0 END) AS Count_Y,
      SUM(CASE WHEN Flag='N' THEN 1 ELSE 0 END) AS Count_N,
    FROM MyTable
    GROUP BY Company, Date
    

    In Oracle/PLSQL, the DECODE function can be used to replace the CASE for the even more concise:

    SELECT 
      Company, 
      Date, 
      SUM(DECODE(Flag,'Y',1,0)) AS Count_Y,
      SUM(DECODE(Flag,'N',1,0)) AS Count_N,
    FROM MyTable
    GROUP BY Company, Date
    
    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

I have some data from log files and would like to group entries by
I would like to implement a fast group by like feature in Java. I
I have an HTML document where I would like to semantically group text to
I would like to create a Group model in Google App Engine and then
I would like to change admin for a group, so it would display how
I would like to clear all radio buttons in a group if I right
I would like to rank sequential rows with the null value inside a group
I would like to be able to go: sed s/^\(\w+\)$/leftside\1rightside/ and have the group
We have a small work group that I would like to encourage to adopt
I'm wondering what would be the best way to group contacts by their company.

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.