| Author | Topic | 
                            
                                    | sayerStarting Member
 
 
                                        35 Posts | 
                                            
                                            |  Posted - 2013-04-16 : 14:57:31 
 |  
                                            | tabel|------id_student-----|--id_lecture------|--state------|   29111                  1                    yes   29111                  2                    yes   29111                  3                    yes   29111                  4                    no   29111                  5                    no   29222                  1                    yes   29222                  2                    no   29222                  3                    yes   29222                  4                    no   29222                  5                    no------------------------------------------------------i select number of state yes and  no group by student id|------id_student-----|--number_of_yes------|--number_of_no------|      29111                   3                   2       29222                   2                   3how to  do that ? please help me              http://aman-services.netfor office???? ???? ??????? |  | 
       
                            
                       
                          
                            
                                    | chadmatThe Chadinator
 
 
                                    1974 Posts | 
                                        
                                          |  Posted - 2013-04-16 : 15:52:33 
 |  
                                          | Is it possible to have 0 yes or no states for a given student id?-Chad |  
                                          |  |  | 
                            
                       
                          
                            
                                    | sayerStarting Member
 
 
                                    35 Posts |  | 
                            
                       
                          
                            
                                    | chadmatThe Chadinator
 
 
                                    1974 Posts | 
                                        
                                          |  Posted - 2013-04-16 : 16:06:10 
 |  
                                          | Is it possible for a student id to have a yes entry and not any no entries, or have a no entry, with 0 yes entries?-Chad |  
                                          |  |  | 
                            
                       
                          
                            
                                    | sayerStarting Member
 
 
                                    35 Posts | 
                                        
                                          |  Posted - 2013-04-16 : 16:16:52 
 |  
                                          | i want get report about absent and present in lecturehttp://aman-services.netfor office???? ???? ??????? |  
                                          |  |  | 
                            
                       
                          
                            
                                    | chadmatThe Chadinator
 
 
                                    1974 Posts | 
                                        
                                          |  Posted - 2013-04-16 : 16:38:06 
 |  
                                          | Alright,This should work unless You can have "no" entries without a "yes" entry, but since you won't tell me if that is a valid case, I won't waste time solving that problem:create table #t1(id int, state varchar(3))goinsert into #t1 values (1, 'yes')insert into #t1 values (1, 'no')insert into #t1 values (1, 'yes')insert into #t1 values (1, 'yes')insert into #t1 values (2, 'yes')insert into #t1 values (2, 'yes')insert into #t1 values (2, 'yes')insert into #t1 values (3, 'yes')insert into #t1 values (3, 'no')insert into #t1 values (3, 'no')goselect isnull(#t1.id, a.id) id, isnull(COUNT(1), 0) Yes, isnull(no, 0) Nofrom #t1  left join (select id, COUNT(1) nofrom #t1where state = 'no'group by id) aon #t1.id = a.idwhere #t1.state='yes'group by #t1.id, a.id, nogodrop table #t1-Chad |  
                                          |  |  | 
                            
                       
                          
                            
                                    | LampreyMaster Smack Fu Yak Hacker
 
 
                                    4614 Posts | 
                                        
                                          |  Posted - 2013-04-16 : 18:07:45 
 |  
                                          | Slightly more simplified: SELECT 	ID AS id_student, 	SUM(CASE WHEN state = 'yes' THEN 1 ELSE 0 END) AS number_of_yes,	SUM(CASE WHEN state = 'no' THEN 1 ELSE 0 END) AS number_of_noFROM 	#t1GROUP BY 	ID |  
                                          |  |  | 
                            
                       
                          
                            
                                    | djj55Constraint Violating Yak Guru
 
 
                                    352 Posts | 
                                        
                                          |  Posted - 2013-04-17 : 13:25:43 
 |  
                                          | Lamprey has a good answer which will show zero total.  Here is something to think about. DECLARE @t1 TABLE (id int, state varchar(3))insert into @t1 values (1, 'yes')insert into @t1 values (1, 'no')insert into @t1 values (1, 'yes')insert into @t1 values (1, 'yes')insert into @t1 values (2, 'yes')insert into @t1 values (2, 'yes')insert into @t1 values (2, 'yes')insert into @t1 values (3, 'yes')insert into @t1 values (3, 'no')insert into @t1 values (3, 'no')select DISTINCT     ID,     state,    COUNT(ID) OVER(PARTITION BY id, state) AS 'Count'from @t1djj |  
                                          |  |  | 
                            
                       
                          
                            
                                    | ScottPletcherAged Yak Warrior
 
 
                                    550 Posts | 
                                        
                                          |  Posted - 2013-04-18 : 15:35:22 
 |  
                                          | [code]SELECT    id_student,    SUM(CASE WHEN state = 'yes' THEN 1 ELSE 0 END) AS number_of_yes,    SUM(CASE WHEN state = 'no' THEN 1 ELSE 0 END) AS number_of_noFROM dbo.tablenameGROUP BY id_studentORDER BY id_student --optional, of course[/code] |  
                                          |  |  | 
                            
                            
                                |  |