Difference between revisions of "Credit debit"

From SQLZOO
Jump to: navigation, search
Line 43: Line 43:
 
so that there are only positive numbers in the table.</p>
 
so that there are only positive numbers in the table.</p>
 
<p>To combine two columns into a single one you () to do this with this example you can use this code:
 
<p>To combine two columns into a single one you () to do this with this example you can use this code:
 
 
</div>
 
</div>
 
<source lang='sql' class='def e-sqlserver'>
 
<source lang='sql' class='def e-sqlserver'>

Revision as of 15:27, 2 August 2012

In this example you are shown how to split a single column into two separate columns and also below you are

told how to combine two tables into a single table. Here we are splitting cash amounts into credit and debit.

Table 1 shows the results without the split column and Table 2 shows what we get when the column is split into two.

Table 1
whndescriptionamount
2006-11-01Wages50
2006-11-02Company Store-10
2006-11-03Company Store-10
2006-11-04Company Store-10
2006-11-05Company Store-10
2006-11-06Company Store-10
Table 2
whndescriptioncshINcshOUT
2006-11-01Wages50
2006-11-02Company Store10
2006-11-03Company Store10
2006-11-04Company Store10
2006-11-05Company Store10
2006-11-06Company Store10
schema:scott
DROP TABLE transact
 CREATE TABLE transact(
  whn DATE,
  description VARCHAR(20),
  amount INTEGER );
INSERT INTO transact VALUES ('2006-11-01','Wages',50);
INSERT INTO transact VALUES ('2006-11-02','Company Store',-10);
INSERT INTO transact VALUES ('2006-11-03','Company Store',-10);
INSERT INTO transact VALUES ('2006-11-04','Company Store',-10);
INSERT INTO transact VALUES ('2006-11-05','Company Store',-10);
INSERT INTO transact VALUES ('2006-11-06','Company Store',-10);

To split a column into two you have to use a CASE function as shown in the example. The SUBSTRING used in the example is used to get rid of the negative sign infront of the number so that there are only positive numbers in the table.

To combine two columns into a single one you () to do this with this example you can use this code: </div>

SELECT w AS dte, d AS description, 
   CASE WHEN (a>=0) THEN a ELSE NULL END AS cshIN,
   CASE WHEN (a<0) THEN SUBSTRING(a,2,10) ELSE NULL END AS cshOUT
  FROM
  (SELECT x.whn AS w, x.description AS d, 
          x.amount AS a
     FROM transact x
     JOIN transact y ON (x.whn>=y.whn)
     GROUP BY x.whn, x.description, x.amount) t
SELECT w AS dte, d AS description, 
   CASE WHEN (a>=0) THEN a ELSE NULL END AS cshIN,
   CASE WHEN (a<0) THEN SUBSTR(a,2,10) ELSE NULL END AS cshOUT
  FROM
  (SELECT x.whn AS w, x.description AS d, 
          x.amount AS a
     FROM transact x
     JOIN transact y ON (x.whn>=y.whn)
     GROUP BY x.whn, x.description, x.amount) t

</div>

Personal tools
Namespaces

Variants
Actions
Reference
Toolbox
Google AdSense