Friday, May 17, 2013
Where are the databasefiles on disk?
A fast way to see where the databasefiles is placed on disk is to use the sys.master_files. With this you can get a view over the database and where their files reside.
select d.name, m.name, m.type_desc, m.physical_name
from sys.master_files m
inner join sys.databases d
on (m.database_id = d.database_id)
order by m.name
Tuesday, March 26, 2013
Windowing functions - stochastic oscillator
Last time I was looking on the
calculation of simple moving average using the new windowing features in
transact SQL. I was curious how to do some deeper calculation in the stock
analysis area. So today I shall see how we calculate the Stockhastic oscillator.
This function use two inputs. D% and K% and the formula are:
%K = 100*(C - L14)/(H14 - L14). C = the most recent closing price L14 = the low of the 14 previous trading sessions H14 = the highest price traded during the same 14-day period.
%D = 3 or 8-day period moving average of
%K
CREATE table
#calculation (
[id] [int],
[aktie] [nchar](10) NULL,
[datum]
[date] NULL,
[stang] [decimal](18, 2) NULL,
[K] [decimal](18, 2) NULL
CONSTRAINT [PK_calculation] PRIMARY
KEY CLUSTERED
(
[id] ASC
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE
= OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
) ON [PRIMARY]
GO
SET ARITHABORT OFF
SET ANSI_WARNINGS
OFF
GO
INSERT INTO
#calculation
SELECT id, aktie, datum, stang
,K = (100*((stang - MIN(stang) OVER (PARTITION BY aktie ORDER BY datum ROWS BETWEEN 13 PRECEDING AND CURRENT ROW))) / ((MAX(stang) OVER (PARTITION BY aktie ORDER BY datum ROWS BETWEEN 13 PRECEDING AND CURRENT ROW)) - (MIN(stang) OVER (PARTITION BY aktie ORDER BY datum ROWS BETWEEN 13 PRECEDING AND CURRENT ROW))))
FROM dbo.borsdata
GO
SELECT id, aktie, datum, stang
,AVG(stang) OVER (PARTITION BY aktie ORDER BY datum ROWS BETWEEN 199 PRECEDING AND CURRENT ROW) as '200 SMA'
,AVG(stang) OVER (PARTITION BY aktie ORDER BY datum ROWS BETWEEN 49 PRECEDING AND CURRENT ROW) as '50 SMA'
,AVG(stang) OVER (PARTITION BY aktie ORDER BY datum ROWS BETWEEN 19 PRECEDING AND CURRENT ROW) as '20 SMA'
,K
,D = (AVG(K) OVER (PARTITION BY aktie ORDER BY datum ROWS BETWEEN 2 PRECEDING AND CURRENT ROW))
FROM #calculation
drop table #calculation
Friday, March 8, 2013
High number of LATCH_EX waits
During an
implementation of a new SQL environment for a customer I went into some problem
with high nr of waits of LATCH_EX type when they run some heavy batches. I was
not sure what this really was. I quite familiar with PAGELATCH and so on. Those
are much more common, at least in server I have seen.
The customer asked
me to investigate what the problem was. First I read the
whitepaper “Diagnosing and Resolving
Latch Contention on SQL Server” from Microsoft.
There
were some ideas coming up after that. The server did have many CPU cores, 32 to
be exact. The database had only one datafile.
First
I tried to add more files to the database. I tried to use 4 but there was no
big change. I went down from 32 ms in average to 27ms. After investigate sys.dm_os_latch_stats is was quite obvious what the problem was.
ACCESS_METHODS_DATASET_PARENT was huge.
Regarding BOL it means Used to synchronize child dataset access to the parent dataset
during parallel operations.
I did some try to set the Max Degree of
Parallelism from default 0 to 4 or 8. This change had the desired effect. In the
graf below we can see the effect very clearly on the black line. We see the batch starts, then a
change to 8 for the Max Degree of Parallelism. Then I change it back, and then
to 4 and then to 8.
Monday, February 4, 2013
Play around with new windowing functions
Im not an developer
but off courseI like to try new features and get knowledge in the transact
language anyway. I have been interested in stocks for many years and was
playing around with Excel to do some simple classic stock analysis. Then it come
to my mind if these calculations is possible direct in SQL.
Here was a must try
scenario to learn some more transact. In my example I have a simple table with
date, high, low, close columns. The data is from OMX30 index beginning from
year 2005 to now.
In the first case I
would like to calculate Moving average for a period of 200 days. One of the
most simple analysis in stock analysis are when the price pass over 200 days
moving average there is a buy situation. When going down under this value you shall sell. If its
tru or not I don’t know. But it’s a good indication if the market is positive
or negative.
How can we use the new
windowing function in transact then? Here is an example:
SELECT id, stock, date, close
,AVG(close) OVER (PARTITION BY stock ORDER BY date ROWS BETWEEN 199 PRECEDING AND CURRENT ROW) as '200 SMA'
Really simple.
Actually I don’t even know how to do when you don´t have this grate functions. Here is the result.
Stock Date Close 200 SMA
omx30 2013-01-28 1160.25 1057.748500
I will investigate those function more and try use them for more advanced calculations. That would be another post.
Subscribe to:
Posts (Atom)