PL/SQL :: Count Number Of Employees In Every Department - Group By Clause Not Working
			Oct 31, 2012
				I have two columns Department and EmpName:
Department EmpName
____________________________________
Sales empname1
Sales empname2
Marketing empname3
Development empname4
Now I want to count the number of employees in every department. I want the output to be
Department Total
______________________
Sales 2
Marketing 1
Development 1
I am retrieving names of the department through a subquery
The query I am trying to execute is:
SELECT Department, Employee FROM
( SELECT ...query from other table) AS Department, count( A.EmpName) AS Employee
FROM Employer A, EmployeeInfo B
WHERE (A.EmpID = B.EmpID AND A.EmpCategory like 'Category2')
GROUP BY Department
I know that you cannot group by using aliases and hence a little work around, but still the query isn't working.
	
	View 2 Replies
  
    
	ADVERTISEMENT
    	
    	
        Aug 21, 2013
        I am having a table employees with columns
1.employee_id
2.department_id
3.hire_date
Display department ID, year, and Number of employees joined?
	View 10 Replies
    View Related
  
    
	
    	
    	
        Dec 1, 2007
        I am using oracle, and have the following relations.
Patient(Patno, name,docno*)
Doctor(Docno, name, specialization)
Treatment(treatno, startdate, reason, docno*, patno*)
I want to list every patients number and name, and the number of treatments given by a certain doctor (e.g doctor name = 'smith'). the problem i am having is that if i specify the doctor is WHERE clause it only gives me the doctors who are under 'smith' but i want all even if 'smith' has given them 0 treatments. below is code that i have so far to view all patients with corresponding data.
select pa.patno, pa.lname, tr.treatno
from patient pa full join treatment tr on tr.patno=pa.patno;
	View 1 Replies
    View Related
  
    
	
    	
    	
        Mar 31, 2012
        This query is taking 7 hours to execute as I am retrieving data from history table dept_hist.
select count(distinct empid), e.group_nm, d.date,
from emp e, dept_hist d 
where e.deptno = d.deptno
  and e.up_ts > sysdate -30
[Code]...
Its taking 7 hours to execute.restructing this query.
	View 4 Replies
    View Related
  
    
	
    	
    	
        Mar 4, 2013
        Get the highly paid two employees from each department with all details?
	View 3 Replies
    View Related
  
    
	
    	
    	
        Jan 21, 2013
        I WANT to RETRIEVE all the INFORMATION of DEPT ALONG with TWO EMPLOYEES of each DEPARTMENT.is any OTHER WAY to DO THIS due to performance in Oracle 10g
SELECT *
FROM DEPT D,
(SELECT DEPTNO,
MAX(DECODE(RN,1,ENAME,NULL)) ENAME1,
MAX(DECODE(RN,2,ENAME,NULL)) ENAME2
[code]......
	View 6 Replies
    View Related
  
    
	
    	
    	
        Nov 26, 2010
        To find all the employees whose salaries greater than avg(salary) of the department.
Quote
select empname,salary,deptid  from salaries t1 where 
salary > (select avg(salary) from salaries t2 where t1.deptid = t2.deptid);
Unquote
Its not diplaying all departments
	View 14 Replies
    View Related
  
    
	
    	
    	
        Mar 28, 2013
        I used Scott schema.I take 2 blocks ,one block having Deptno,Job and also 1st block is a non database block and Another Block Empno,ename,job,sal,deptno, is a database block,my question is when i enter Deptno,Job then Display Employees Details and also Department name
	View 1 Replies
    View Related
  
    
	
    	
    	
        Sep 11, 2012
        I borrowed some code fragments from other posts and put together a sql query. I think there is a better method in other posts but I couldn't get them working. 
I'm trying to get the count of hired employee(s) using the EMP table. I want from the first hire to the last and ALL in between. If there were no hires in that window, I want 0.
WITH minmax AS
 (SELECT MIN(last_day(hiredate)) fmonth, MAX(last_day(hiredate)) lmonth
    FROM emp),
cal AS
 (SELECT add_months(fmonth, LEVEL - 1) mnth
    FROM minmax
  CONNECT BY LEVEL <= months_between(lmonth, fmonth) + 1),
vals AS
 (SELECT extract(YEAR FROM mnth) YEAR, extract(MONTH FROM mnth) MONTH
    FROM cal),
data AS
 (SELECT extract(YEAR FROM hiredate) YEAR,
         extract(MONTH FROM hiredate) MONTH,
         COUNT(*) hired_cnt
[code]...
	View 2 Replies
    View Related
  
    
	
    	
    	
        Sep 21, 2010
        I have to display count of employees that belongs to different categories.
is the situatio   There is a category table CATEGORY with three columns (PK,NAME,TREEPOSITION) and we have categories A, B, C  these three categories can further have sub-categories so the treeposition for the sub categories will be followed by their root category with _ 'symbol'
  
Now I have table for the employees with 3 columns (pk,name,category_id), where employees.category_id=category.pk So I want to calculate the number of employees in each category or sub-category.
since the number of categories will be large and each will be having different names so going through names will be bad option left is grouping through the treepostion 
the problem is I cant use like using IN for the TREEPOSITION. .
TABLE EMPLOYEES ( PK,NAME,CATEGORY_ID)
TBALE CATEGORIES (PK,NAME,TREEPOSITION)
	View 2 Replies
    View Related
  
    
	
    	
    	
        Nov 1, 2013
        I'm trying to group sets of data based on time separations between records and then count how many records are in each group.
In the example below, I want to return the count for each group of data, so Group 1=5, Group 2=5 and Group 3=5
    SELECT AREA_ID AS "AREA ID",
    LOC_ID         AS "LOCATION ID",
    TEST_DATE      AS "DATE",
    TEST_TIME      AS "TIME"
    FROM MON_TEST_MASTER
    WHERE AREA_ID   =89
    AND LOC_ID      ='3015'
    AND TEST_DATE   ='10/19/1994';
[code]....
Group 1 = 8:00:22 to 8:41:22
Group 2 = 11:35:47 to 11:35:47
Group 3 = 15:13:46 to 15:13:46
Keep in mind the times will always change, and sometime go over the one hour mark, but no group will have more then a one hour separation between records.
	View 4 Replies
    View Related
  
    
	
    	
    	
        Mar 23, 2013
        I'm using this code, and it performs fine, but I'm wondering if there is a more elegant way to do it--maybe with "ROLLBACK". Basically (as you can see) I need to get a normal count for each group but also for each group take a percentage of the total count (so all groups pct adds up to 100 (oh yeah, don't test for zero below, but just a test... )
select 
c.Event,
                c.code,
count(1) as calls,
total.total_count,
count(1) / total.total_count * 100 as pct_of_total
from
table1 c
[Code]....
[Edit MC: add code tags, do it yourself next time]
	View 4 Replies
    View Related
  
    
	
    	
    	
        Apr 19, 2013
        how to show total number of department with their department name assign to employee table.
	View 2 Replies
    View Related
  
    
	
    	
    	
        Mar 25, 2010
        I would like to create a hierarchical tree with Department number as a node and all the employees (only employee names) under that department as shown below:
[-]Department - 10
KING
JAMES
   -----
[-]Department - 20
   MARY
   |
   |
and so on...
I have created a hierarchical tree 'HT_DEPTNO' under block 'BL_EMP'. I also created a Record Group 'RG_HTREE' with query as shown below:
SELECT 1, LEVEL, E.ENAME, D.DEPTNO||' - '||D.DNAME DEPARTMENT, D.DEPTNO 
FROM EMP E, DEPT D 
WHERE E.DEPTNO = D.DEPTNO 
START WITH E.DEPTNO = 10 
CONNECT BY PRIOR E.EMPNO=E.MGR
I am attaching the form for your reference.
	View 19 Replies
    View Related
  
    
	
    	
    	
        Jun 12, 2012
        There is a attendance table having structure(empid number,signtime datetime)It has data of attendance of employees:
What is the right sql to show employees detail attendance according to the no of days attendance . i.e.(According to the maximum no of attendance first and so on)
suppose: 3 employees abc,bbc,cca abc has 20 days of attendance ,bbc has 21 days,cca has 19 days..The report like this: 
bbc 1/5/12 10:30
abc .....
then 
cca
according to the no of attendannce
	View 6 Replies
    View Related
  
    
	
    	
    	
        Mar 31, 2011
        This time, I am going to provide the DML statements.
I have a simple table with 3 fields in it.I want to group by ACCT_NUMBER and sum of BALANCE field. But I want to get the description of the first row in a group.
 the statements below. Here there are two groups of records 2001 and 2002. My sql(which I am working on) should return the following :
2001 EMPL TRAINING-MIS       20
2002 OTHER PROF SERV-HR      40
The following query will group by ACCT_NUMBER and sum of the BALANCE field. But how can I get the  DESCRIPTION?
SELECT ACCT_NUMBER, SUM(BALANCE) 
FROM TEST
GROUP BY ACCT_NUMBER
CREATE TABLE "TEST" 
   ("ACCT_NUMBER" VARCHAR2(20 BYTE), 
"DESCRIPTION" VARCHAR2(20 BYTE), 
[code]...
	View 5 Replies
    View Related
  
    
	
    	
    	
        Mar 7, 2013
        I need suing group by for getting count.I have a table with columns  below
SYS_AUDIT_IDSYS_AUDIT_PROG_IDPROG_FINDING_ID_COUNT
178921652
178921641
178921631
179321521
179321511
179321501
179321491
179321461
I want  to count   number of SYS_AUDIT_PROG_ID  for each audit  and count of   PROG_FINDING_ID_COUNT
I want to get 
1789   3   4
I tried this query but this is not working
[code]select sys_audit_id ,count (sys_audit_prog_id),  count(prog_finding_id_count)  from     
my_table sub
group by sys_audit_id [/code]
	View 2 Replies
    View Related
  
    
	
    	
    	
        Sep 18, 2013
        SELECT sno,mid,mname
FROM manage_date
WHERE mname IN
('KIRAN-KUMAR',
'RAHUL-RAJ',
'KAUSHAL-SONI');
IF I use this query directly in DB it's working fine. But when this query is calling in .net using parameter as below it's not giving any records for more than one value. IN (:p_mname) 
If I pass one name 'KIRAN-KUMAR' from .net It's working.
If I pass multiple names from .net query not returning any records.
	View 4 Replies
    View Related
  
    
	
    	
    	
        May 21, 2010
        how do I count a list of number value eg 1,1,1,1,3,3,6,4 and find the one with maximum number which is 1
	View 5 Replies
    View Related
  
    
	
    	
    	
        Feb 17, 2010
        SNO column should be incremented depending upon the total records to be fetched.if i get 4 records then sno numbers should be 1,2,3,4.i dont want to put rownum also in the GROUP BY clause.how to increment the serial number?
SELECT JC.A,
ROWNUM SNO, --serial number
JC.B,
SUM(CHR.AMOUNT),
SUM(CHR.FINALAMOUNT),
JC.C,
JC.D,
C.E,
JC.F,
JC.G
FROM CHARGES CHR
WHERE JC.B = '12111'
AND JC.STATUS = 'INVOICED'
GROUP BY JC.A, JC.B, JC.C, JC.D, JC.E, JC.F, JC.G;
	View 8 Replies
    View Related
  
    
	
    	
    	
        Apr 23, 2012
        I have a report I created and I need to get a Total Count by Plan Code Description for Each State.  I do this and get all my data:
SELECT 
mv.R1_State,
mv.subscriber_id,
mv.plan_code, 
pm.description,
mv.line_of_business,
[code]...
But I cannot get the count I have to do a separate Query to get the count here it is How can I put the two together to get my count information and Report information together in one Report???
Select 
Count(pm.description),
mv.R1_State
FROM windsoradm.member_mv mv
[code]....
	View 1 Replies
    View Related
  
    
	
    	
    	
        Oct 30, 2013
        I am trying to count the number of IDs dropped and enrolled in each unit for each of the 4 terms between their perspective dates. There are 4 Terms and an ID can participate in a unit in any of these terms:
TERMSTART_DATEEND_DATE125-Feb-1318-Mar-13227-May-1317-Jun-13326-Aug-1316-Sep-13425-Nov-1316-Dec-13 .
I am trying to count how many IDs enrolled in a unit between those dates and how many doped before the end dateThe ENROL_DATE for each ID in a unit has to be between the given Term Dates to count. Unit KIS has 1 ENROL and one DROP in TERM 1 UNIT POL occurs in TERM 2 and 4 and both DROPUNIT LIN and 1 ENROL and 1 DROP in 2 different TERMS My problem is how do i specify count ENROL and count drop between the Term dates and then group by TERM and UNIT. 
{code}CREATE TABLE DAN_GR4(ID             NUMBER(12),STATUS           VARCHAR2(12),TERM             NUMBER(12),ENROL_DTE       DATE,TERM_START_DTE  DATE,TERM_END_DATE   DATE,UNIT            VARCHAR2 (12));  INSERT INTO  DAN_GR4 (ID,STATUS,TERM,ENROL_DTE,TERM_START_DTE,TERM_END_DATE,UNIT) VALUES ('1',    'ENROL'    ,'1',    '15-Mar-13'    ,'25-Feb-13' ,'18-Mar-13',  'KIS');INSERT INTO  DAN_GR4 (ID,STATUS,TERM,ENROL_DTE,TERM_START_DTE,TERM_END_DATE,UNIT) VALUES ('1',    'DROP'    ,'2',    '27-MAY-13'    ,'27-MAY-13' ,'17-JUN-13',    'POL');INSERT INTO  DAN_GR4 (ID,STATUS,TERM,ENROL_DTE,TERM_START_DTE,TERM_END_DATE,UNIT) VALUES ('1',    'DROP'    ,'2',    '27-JUN-13'    ,'27-
[code].....
	View 2 Replies
    View Related
  
    
	
    	
    	
        Nov 8, 2010
        It seems some issue with With Clause along with Row Number. Output is strange when it comes with SELECT MIN()...  But Looks fine Once you add "order by" or "where" clasue inside WITH Clause
SQL> select * from v$version;
BANNER
----------------------------------------------------------------
Oracle Database 10g Enterprise Edition Release 10.2.0.5.0 - 64bi
PL/SQL Release 10.2.0.5.0 - Production
CORE    10.2.0.5.0      Production
[code]....
But Output looks fine once you add ORDER By clause inside WITH clause
SQL> WITH EM AS
  2  (
  3  SELECT EMPNO, ROWNUM RN
  4  FROM SCOTT.EMP T ORDER BY ROWNUM
 
[code]....
why it happens ?
	View 4 Replies
    View Related
  
    
	
    	
    	
        Mar 28, 2011
        getting expression into a Group By query in oracle.
I have a simple table with two columns. 'ID' and 'Amount'
I want output of the SQL to the following (only 2 fields in the output): I have attached the desired output.
select  sum(amountheld) from table1
where member_status = 'MEMBER'
group by ID
This group by query works. But how can i get the expression field (the first field which 'TEMPACCOUNT') in this query (based on my attached output).
	View 5 Replies
    View Related
  
    
	
    	
    	
        Sep 18, 2012
        I want to use Analytical function instead of group by clause for below query..
select   
CASE
    WHEN ADMT.SOURCESYSTEM ='CLU'
    THEN COUNT(ADMT.TOTAL_COUNT)*5
    ELSE COUNT(ADMT.TOTAL_COUNT)
  END TOTAL_COUNT
from   ESMARTABC.ABC_DRVR_MFAILS_TMP ADMT
group by ADMT.SOURCESYSTEM
	View 1 Replies
    View Related
  
    
	
    	
    	
        Apr 4, 2011
        Can Group BY clause have an expression field?
Say for example, I want to group by the fields "Type" and and expression called "expression" (which is a case statement). I tried running this query and it says "expression" is invalide identifier.
select type,   case when SUBSTR (glnumber, 1, 2) = '05' then 'IS'
when SUBSTR (glnumber, 1, 2) = '06' then 'IS'
else 'BS'
end "expression" , sum(balance)
from table
group by TYPE, "expression"
If there is any online material on how to GROUP BY on an expression(like above)
	View 5 Replies
    View Related
  
    
	
    	
    	
        Mar 12, 2012
        IN clause is not working for stored function.At same time, the LIKE conditon is working.
SQL> CREATE OR REPLACE FUNCTION GET_EMPLOYEES (in_asset_type in SECURITY_TYPE.asset_type%TYPE)
2    RETURN VARCHAR2
[Code].....
	View 1 Replies
    View Related
  
    
	
    	
    	
        May 24, 2008
        I have three tables,let's say
table stores
sid | store_name
1  |  one  
2  |  two
3  |  three
table products
pid | sid | p_name
1   | 2   | pone
2   | 2   | ptwo
3   | 3   | pthree
table sales
said | sid | pid 
1     | 2   | 1
2     | 3   | 1
3     | 2   | 2
4     | 1   | 3
5     | 2   | 2
6     | 3   | 2
7     | 3   | 2
and i want display the product that sells best in every store. I try to group by multiple columns counting how many times each product was sold in every store, but don't know how to select the one which was best sold (maximal number of times)
	View 5 Replies
    View Related
  
    
	
    	
    	
        Feb 3, 2011
        We have a table with timestamp column and having millions of records.We want to create a materialized view or query, which can give count based 
-on some group by columns from table and
-group by on condition (if count > 1000) and
-group by on condition (if timestamp range for that group is > 1hr)
	View 4 Replies
    View Related
  
    
	
    	
    	
        Jan 11, 2012
        Using Connect By on a query which has a nested from clause(The from clause fetches around 100k records) gives incorrect results but if the same nested queries are used to build a table and the Connect By is used on the table then the output is correct.
I put the nested queries in a 'WITH' clause  and got the correct output also.
I am not sure how to give the code here as you would need dump to make them work. I am giving the a sample 
--Non Working Code
SELECT     con_item, prod_item, compsite, bcsite, ibrsite, res
FROM (SELECT con_item, prod_item, compsite, bcsite, ibrsite, res
FROM (SELECT bd.item AS con_item, bd.fromid AS compsite,
bd.toid AS bcsite, bd.toid AS ibrsite,
[Code]....
	View 1 Replies
    View Related