Solved

non normalized table

Posted on 2014-01-26
7
349 Views
Last Modified: 2014-01-30
I have a non normalized table - I think that's the correct description.  I have a column that is a code that indicates the type of data that is contained in a second column, so let's say "code" and "value" are the column names.    I need the average of all value for each code returned in a single record.  I only need this for, say 3 specific codes, 11, 22, 33.  How can I do this?
0
Comment
Question by:HLRosenberger
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
7 Comments
 
LVL 13

Expert Comment

by:magarity
ID: 39810300
select code, avg(value) from table where code in (11,22,33) group by code
0
 
LVL 13

Expert Comment

by:magarity
ID: 39810308
PS - A 'denormalized' table is one where two or more normalized tables are combined.  For example, if 'code' in your example also has 'code long description' in this same table then that would be denormalized.  If code long description were in a lookup table, that would be normalized,
0
 
LVL 48

Expert Comment

by:PortletPaul
ID: 39810818
>>" returned in a single record. "

Why must it be returned as a single record?

(the solution provided above will produce 3 rows)
0
Edgartown IT Case Study

Learn about Edgartown's quest to ensure the safety and security of the entire town's employee and citizen data. Read the case study!

 
LVL 69

Accepted Solution

by:
Scott Pletcher earned 500 total points
ID: 39812202
SELECT
    AVG(CASE WHEN code = '11' THEN value END) AS code_11_avg,
    AVG(CASE WHEN code = '22' THEN value END) AS code_22_avg,
    AVG(CASE WHEN code = '33' THEN value END) AS code_33_avg
FROM dbo.tablename
WHERE
    code IN ( '11', '22', '33' )
0
 
LVL 13

Expert Comment

by:magarity
ID: 39812491
It's not clear either way that it's supposed to be a single record result set. That sentence doesn't parse well. The second query will do if that's the case.
0
 
LVL 32

Expert Comment

by:awking00
ID: 39812740
Perhaps some sample data and your expected output would help clarify. I think one of the two solutions provided will accomplish what you want. Assume the average value of code 11 is 5, and the average value of code 22 is 10, and the average value of code 33 is 15, the first produces
code value
11     5
22    10
33    15
and the second produces
11avgval  22avgval  33avgval
5              10             15
0
 
LVL 1

Author Closing Comment

by:HLRosenberger
ID: 39823205
thanks.
0

Featured Post

Microsoft Certification Exam 74-409

VeeamĀ® is happy to provide the Microsoft community with a study guide prepared by MVP and MCT, Orin Thomas. This guide will take you through each of the exam objectives, helping you to prepare for and pass the examination.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

Title # Comments Views Activity
sql how to insert a column with the data  in an existing table 4 36
VMware PVSCSI SQL Server 2016 AlwaysOn 2 37
Report 8 27
Group ordersum by orderdate 3 16
How to leverage one TLS certificate to encrypt Microsoft SQL traffic and Remote Desktop Services, versus creating multiple tickets for the same server.
In the first part of this tutorial we will cover the prerequisites for installing SQL Server vNext on Linux.
Via a live example, show how to extract information from SQL Server on Database, Connection and Server properties
Via a live example, show how to extract insert data into a SQL Server database table using the Import/Export option and Bulk Insert.

734 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question