SQL & PL/SQL :: Group Functions - Number Of Employees Joined
Aug 21, 2013I 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?
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?
getting the following kind of output.
I would like to get Each year and the number of employees joined in the corresponding month for jan, feb, mar and april from emp table.
A sample output looks like below.
YEAR JAN FEB MAR APRIL
2000  4   2   1   2
2001  2   1   1   5
2002  2   4   2   6  
2004  2   4   1   4  
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.
Query to find out employees who are all joined before Manager.
For Example the Table may look like.
EMPIDDesignationDateJoined
E101Programmer10-Jan-04
E102Programmer22-Mar-04
E103Analyst        14-Jan-05
E104Designer20-Dec-06
E105Tester        20-Nov-07
E106Manager        11-Oct-08
E107Programmer20-Nov-09
E108Coordinator12-Dec-10
E109DB Admin10-Feb-07
E110DB Analyst10-Aug-05
The out put must be..
EMPIDDesignationDateJoined
E101Programmer10-Jan-04
E102Programmer22-Mar-04
E103Analyst        14-Jan-05
E104Designer20-Dec-06
E105Tester        20-Nov-07
E109DB Admin10-Feb-07
I have a table:
create table employee_function
(
id_emloyee number,
id_function number
);
with clients and their functions.
I want to extract all employes who has 2 functions (ex:id_function = 1 and id_function=2)
i have employee table i want to update salary with all employee 5 percent
View 4 Replies View Relatedcount the no: of emp working under each manager? and instead of manager number display the manager name
View 5 Replies View Relatedi want to get SUM(salary) by combining both employee and employees table.Look my table structure below:
SQL> select * from employee;
     EMPNO ENAME           HIREDATE  ORIG_SALARY     SALARY R        MGR     DEPTNO
---------- --------------- --------- ----------- ---------- - ---------- ----------
         1 Jason           25-JUL-96        1234       8767 E          2         10
         2 John            15-JUL-97        2341       3456 W          3         20
         3 Joe             25-JAN-86        4321       5654 E          3         10
         4 Tom             13-SEP-06        2413       6787 W          4         20
         5 Jane            17-APR-05        7654       4345 E          4         10
         6 James           18-JUL-04        5679       6546 W          5         20
         7 Jodd            20-JUL-03        5438       7658 E          6         10
         8 Joke            01-JAN-02        8765       4543 W                    20
         9 Jack            29-AUG-01        7896       1232 E                    10
[code]....
Above, i used separate queries to get the result of SUM(salary) by deptno.Here, I want a single query to get SUM(salary)  with deptno.
deptno         Sum(salary)
----------------------------
       10       30056
       20       27132
       30        6300
       40        4300
I have simplified this for ease of understanding. I have a Data column and a Month_ID column like this:
Values Month_ID
--------- -------------------------------------------------------
AAA 1
BBB 2
I split this out to values per year like this
Value_2011 Value_2012 Month_ID
-------------------------------------------------------------------------
AAA 1
BBB 2
Now i am trying to get the max(Value_2011) keep (dense_rank Last order by Month_ID) but i get a NULL. I can understand its because the Month_ID accomodates all years but i only need it to look at Month_ID for 2011 and return me the last dense_rank value, how can i achieve this?
I tried a couple of different methods like Last_Value() but i have group by in my original statement and i think analytical functions dont like GROUP by if they are not part of it. How can i achieve this?
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
I have Table Data in format :- 
--------------------------
ABC
ABC
ABC
XYZ
XYZ
and i have a requirement where I need the output in this format.
-------------
ABC       1
ABC       2
ABC       3 
XYZ       1
XYZ       2
what query to be used for this
If I run the following query I got  997 records by using GROUP BY.
SELECT  c.ins_no, b.pd_date,a.project_id,
                  a.tech_no
                 FROM mis.tranche_balance a,
                  FMSRPT.fund_reporting_period b,
                  ods.proj_info_lookup c,
                  ods.institution d
            WHERE a.su_date = b.pd_date
              AND a.project_id = c.project_id
              AND c.ins_no = d.ins_no
              AND d.sif_code LIKE 'P%'
              AND d.sif_code <> 'P-DA'
              AND a.date_stamp >='01-JAN-2011'
              AND pd_date='31-MAR-2011'
         GROUP BY c.ins_no,
                  b.pd_date,
                  a.project_id,
                  a.tech_no;
I want to show the extra columns a.date_stamp and a.su_date in the out put so that I have used PARTITION BY in the second query but I got 1079 records.
SELECT   c.ins_no, b.pd_date,a.date_stamp,a.su_date, a.project_id,
                  a.tech_no,
                COUNT(*)  OVER(PARTITION BY  c.ins_no,
                  b.pd_date,
                  a.project_id,
                  a.tech_no)c   
  [code]....
           
why I got 1079 records.how to show the two extra columns in the out put whcich are not used in GROUP BY clause.
I ve a data in table as follows
   code   status    seqnce   Length
   B1      AVL        1        10
   B2      AVL        2        10
   B3      ASG        3        10
   B4      AVL        4        10
   B5      AVL        5        10
   B6      AVL        6        10
   B4      ASG        7        10
   B4      ASG        8        10
    
I need to group the AVL status codes  with the sum of lengths  Ex) B1 to B2 - 20  B4 to B6 - 30 like that.
I have a schema whereby a table is not joined with other tables. 
the info on that table can be gotten manually (by doing a query) and then using that info in another query.  so is there a way of getting info from that table?
I have the following, simplified, query involving 3 tables:
Table 1
ID---Student
1----Terry
2----Gilbert
3 ---Egbert
4 ---Norris
Table 2
ID--Base_ID--Base_Name
1 --F100 ------St. Vincents
3 --F102 ------AB Junior High
4 --F103 ------CD Middle School
Table 3
ID--Choice_order_ID--Secondary_Base_Choice
1---Co1-------------School A
1---Co2-------------School B
1---Co3-------------School C
2---Co1-------------School B
2---Co2-------------School A
2---Co3-------------(null)
3---Co1-------------School C
3---Co2-------------School A
3---Co3-------------School B
I use the following query:
select table1.student, table2.base_name
from table 1, table2,
where table1.id = table2.id (+)
which returns the student and the base name they attend, i.e. 
Student---Base_Name
Terry-----St. Vincents
Gilbert----(null)
However, I need to also list their school Secondary_Base_Choices horizontally, in the following format, 
I.e. 
Student---Base_Name----Base_Choice_1---Base_Choice_2---Base_Choice_3
Terry-----St. Vincents----School A----------School B-----------School C
Gilbert----(NULL)---------'NO DATA'--------'NO DATA'----------'NO DATA'
Egbert----AB Junior H----School B----------School A-----------'NO DATA'
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.
I have Employees and Salary columns in emp table. So i have nearly 200 employees.
I need to show top 10 employees who has maximum salary.
I read that rownum is applied after the selection is made and before "order by". So, in order to get the sum of salaries for all employees in all departments with a row number starting from 1, i wrote :
select  ROWNUM,department_id,sum(salary) from employees group by department_id
If i remove rownum, it gives the correct output. Why can't rownum be used here ?
For table employees  with 
 
 EMPLOYEES                  
   __________________________________________   
   EMPID  NAME  MANAGERID
   ------------------------------------------   
      34  Amy               
      17  Ben           34  
       5  Chris         34  
      10  Don            5  
   ...
How can we use SQL to get all employees under one manager , either direct or indirect
I only can think the following SQL to get the first direct employee.  
select e1.empid
from employees e1, employees e2
where e1.managerid = e2.empid 
and e2.empid = '34';
Perhaps we could put it in PL/SQL procedure to do recursive call? 
Select top 2 * from employees;
TOP command or function is suitable for oracle 10g SQL
if not then for top analysis what should need to use..is this query work in Oracle SQL 10g?
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]...
I use a table taht i call C where the value of a field ("Type") is always a concat of values coming from more than 2 tables (A et C)
select A.Numero, B.date, B.commentaire,C.Libelle
from A, B, C
where A.codeLibelle = C.codeLibelle
and CONCAT(A.Numero, CONCAT(A.DemNumero, C.Libelle)) = B.Type (+)
when i execute this statement, i obtain
ORA-01417: a table may be outer joined to at most one other table
I have another request where it works fine and where i have concat of fields from only a single table:
select A.Numero, B.date, B.commentaire,C.Libelle
from A, B
where CONCAT(A.Numero, A.DemNumero) = B.Type (+)
In the first request Oracle seems to not accept a join with more than 2 tables
SELECT *
FROM EMP E,DEPT D
WHERE  D.DEPTNO = CASE WHEN COMM IS NULL THEN E.DEPTNO ELSE E.DEPTNO(+) END;
It is giving error on executing saying
ORA-01417 - a table may be outer joined to at most one other table.
Why it is giving this error,
How can i write such a query, since it my requirement
I am trying to update of job_id column of employees table for employee number 205 two times one after another. First time job_id column of employees table for employee number 205 is updated with new job_id. But second time  job_id column of employees for employee number 205 table can not be updated. Oracle returns the following errors
HR:orcl > update employees set JOB_ID='AC_MGR' where employee_id=205;
update employees set JOB_ID='AC_MGR' where employee_id=205
         *
ERROR at line 1:
ORA-00001: unique constraint (HR.JHIST_EMP_ID_ST_DATE_PK) violated
ORA-06512: at "HR.ADD_JOB_HISTORY", line 10
ORA-06512: at "HR.UPDATE_JOB_HISTORY", line 2
ORA-04088: error during execution of trigger 'HR.UPDATE_JOB_HISTORY'
As there is composite primary key using employee_id and start_date column.how to update same employee job_id twice.AS we can see from job_history table, the record for employee 200 is as follow
EMPLOYEE_ID START_DATE   END_DATE    JOB_ID     DEPARTMENT_ID
----------- ----------- ----------  ---------- -------------
200        17-SEP-1987  17-JUN-1993  AD_ASST     90
200       01-JUL-1994   31-DEC-1998 AC_ACCOUNT   90
So how can i do the same for employee 205 without changing hire_date after first job_id update. Since for every update of job_id fires trigger. To insert row  in job_history table employee id and start_date must be unique each time. HERE hire_date of employees table is used as start_date of job_id table. how it was possible for employee id 200 to change job_id twice?
Assign employees to their jobs in consideration the maximum number of employees to  each  jobs is 5 employee plus each job has own the maximum number of employees 
we need the maximum number of employees for each job 5 to be variable when need to change this maximum for certain job , change this number from database (form the from of job ) not form code )
tables 
emp
emp_no 
name
manager
hiredate 
salary
job 
job_no 
job
you can add tables or attributes to tables to complete you business.
I want TO find out FIRST two employee joined IN A particular department WITH department information.THE relation IS basically FROM THE scott SCHEMA.I tried LIKE AS follows. IS there ANY other way FOR best PERFORMANCE.
 SELECT deptno,dname,loc,
       Max(Decode(rn, 1, hiredate))hiredate1,
       Max(Decode(rn, 1, ename))   employee1,
       Max(Decode(rn, 2, hiredate))hiredate2,
       Max(Decode(rn, 2, ename))   employee2
FROM   (SELECT d.deptno,dname,loc,hiredate,ename,Row_number() over(PARTITION BY e.deptno ORDER BY hiredate) rn
        FROM   dept d, emp e
        WHERE  d.deptno = e.deptno(+))
GROUP  BY deptno,dname,loc;  
Refer to the txt file to create table and insert data.
I executed the following query-
SELECT priority, detail, COUNT(1) FROM TEST GROUP BY priority, detail
and got the following result-
PRIORITYDETAIL        COUNT(1)
StandardPatch            27
StandardInitial TSS      1
StandardInitial development 10
StandardProduction deployment5
High PriorPatch             1
Now I want that Initial TSS and Initial development should be combined as Initial together and I should get the result as follows:
PRIORITYDETAIL        COUNT(1)
StandardPatch            27
StandardInitial             11
StandardProduction deployment5
High PriorPatch             1
write a query to see how many(no) employees getting salary 3000 & what are their names respectively.
View 2 Replies View RelatedI 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)
Get the highly paid two employees from each department with all details?
View 3 Replies View Related