December 9, 2012 at 2:42 am
Hi pros out there,
I am introduced to SSIS to do ETL for repporting in SSRS very recently. I am given a task to analyse employees working hours and pattern through the use of data gathered from access point. I have done something similar to do with QlikView(through use of several sql statements and residents table) however SSIS is totally a stranger to me. I do not uds how i can achieve what this using SSIS. Cant even get the logic and work flow. I need some serious help here. The first table is somewhat my source table data:
PASS_MEVENT_DEVENT_TMESSAGE_X
Staff A30/04/201218:10:00Exit
Staff B01/05/201208:30:10Access
Staff B01/05/201218:31:20Exit
Staff C30/04/201222:00:17Access
Staff C30/04/201222:01:28Access
Staff C01/05/201205:31:00Exit
Staff D30/04/201210:00:00Access
Staff D30/04/201216:00:00Exit
Staff D30/04/201216:03:00Exit
Staff D01/05/201219:50:00Access
Staff D02/05/201203:50:00Exit
Staff D02/05/201212:00:00Access
Staff D02/05/201218:00:00Exit
Staff E02/05/201219:00:00Access
This is what i want to achieve, my target table:
PASS_MENTRY_DTEXIT_DTWORKED_HRSCONSECUTIVE_D
Staff B01/05/2012 08:30:1001/05/2012 18:31:2010:011
Staff C30/04/2012 22:00:1701/05/2012 05:31:0007:311
Staff D30/04/2012 10:00:0030/04/2012 16:03:0006:031
Staff D01/05/2012 19:50:0002/05/2012 03:50:0008:002
Staff D02/05/2012 12:00:0002/05/2012 18:00:0006:003
Assumptions:
If there are multiple access for one exit, take the earliest access date and time. If there are multiple exit for an access, take the latest exit date time. Not able to take earliest access or latest exit base on the date itself as some legit access maybe during late evenings and some exits may be early in the morning. Secondly, for those accesses with no exit or exit with any access, do not include it in first.
I know many will feel i am asking alot over here, i do agree but i really need serious help. For those who know how, and willing to help please give some advice.
Attached is a nicer view of my table.
Greatly appreciate any help given.
Thanks,
10e5x
December 9, 2012 at 4:46 am
May I ask how you think that SSIS can help you with this problem?
Based on the data provided, it looks like a stored proc would be suffucient to provide the info to the SSRS report.
The absence of evidence is not evidence of absence.
Martin Rees
You can lead a horse to water, but a pencil must be lead.
Stan Laurel
December 9, 2012 at 8:25 am
Phil Parkin (12/9/2012)
May I ask how you think that SSIS can help you with this problem?Based on the data provided, it looks like a stored proc would be suffucient to provide the info to the SSRS report.
Hi Phil,
Firstly i want to thank you for replying. Thanks. Oh i am sorry if my way of asking is way too lousy, i am quite new to forums, i will read on the link provided. U mentioned about how can i think SSIS can help me with my problem? actually i am not even sure myself. This task was just throw to me without further guidance and i was just told "study the data and requirement, Use SSIS to perform the etl process and then use SSRS to do a report" I have done a few SSIS tutorials and i realize SSIS always work with data flow. So in order to achieve what i want, how will my flow look like? i know my first step is get alll my date and time fields into correct ssis data type. Then maybe i can do some select bla bla bla from table order by staff name, event_d and event_t... how shall i do this?
You mentioned about stored procedure, can it be done at SSIS or?
Sorry if i sound too noob but i am really confused.
December 9, 2012 at 10:06 am
So what do you want to do if there's an access late in the day and no exit until the next day?
Also, what do you want CONSECUTIVE_D to be if it spans a weekend?
Last but not least, I disagree with the rule of using the earliest entry date for this. Someone could come in and immediately turn around and walk out without closing the door and still have "hours worked" accrued. Same thing with the latest exit. They could exit and then later follow someone in and exit "for real and have "hours worked" accrued the whole time they're gone.
For sure, this system should NOT be used for a timekeeping system of [font="Arial Black"]any [/font]type.
--Jeff Moden
Change is inevitable... Change for the better is not.
December 9, 2012 at 12:05 pm
guoxiang1610 (12/9/2012)
Phil Parkin (12/9/2012)
May I ask how you think that SSIS can help you with this problem?Based on the data provided, it looks like a stored proc would be suffucient to provide the info to the SSRS report.
Hi Phil,
Firstly i want to thank you for replying. Thanks. Oh i am sorry if my way of asking is way too lousy, i am quite new to forums, i will read on the link provided. U mentioned about how can i think SSIS can help me with my problem? actually i am not even sure myself. This task was just throw to me without further guidance and i was just told "study the data and requirement, Use SSIS to perform the etl process and then use SSRS to do a report" I have done a few SSIS tutorials and i realize SSIS always work with data flow. So in order to achieve what i want, how will my flow look like? i know my first step is get alll my date and time fields into correct ssis data type. Then maybe i can do some select bla bla bla from table order by staff name, event_d and event_t... how shall i do this?
You mentioned about stored procedure, can it be done at SSIS or?
Sorry if i sound too noob but i am really confused.
No need to apologise, I can tell that you are trying to get this resolved.
Can you first of all confirm the source of the data - is it a SQL Server table?
If it is (and leaving aside Jeff's comments around the proposed business rules - which also need to be resolved), this not an SSIS problem. What you need is a stored proc - of whatever complexity - which returns the data in the form you have shown. This proc will be your report's data source, simple as that.
If your data is coming from, for example, a text file, we're back in SSIS territory. But in this case, there would be at least two processes involved:
1) A regular SSIS package to import the data into SQL Server
2) One or more SSRS reports which use stored procs, as necessary, to access and present the imported data.
The absence of evidence is not evidence of absence.
Martin Rees
You can lead a horse to water, but a pencil must be lead.
Stan Laurel
December 9, 2012 at 12:54 pm
Here's one possible answer...
Assuming the "ACCESS_SOURCE" is a table, we need to first combine the Event_D and Event_T columns into a single, sortable, calculable column. This should have been done when the table was imported by SSIS instead of in the code below.
We also take the opportunity to build a working table with some extra columns to make it easier to calculate and aggregate entry and exit times. Here's the code to build the working table. As always, the details are in the comments. The clustered index applied to this table is absolutely required for the next step to work correctly.
--===== Set the date format for the given data
SET DATEFORMAT DMY
;
--===== Conditionally drop the temp table to make reruns in SSMS easier.
IF OBJECT_ID('tempdb..#Corrected','U') IS NOT NULL
DROP TABLE #Corrected
;
--===== Create a table with combined dates/times.
-- This should have been done during the SSIS load.
SELECT Pass_M = CAST(PASS_M AS VARCHAR(10)),
Event_DT = CAST(EVENT_D AS DATETIME)
+ CAST(EVENT_T AS DATETIME),
Message_X = CAST(MESSAGE_X AS VARCHAR(6)),
Entry_DT = CAST(NULL AS DATETIME),
Exit_DT = CASE
WHEN MESSAGE_X = 'Exit'
THEN CAST(EVENT_D AS DATETIME)+CAST(EVENT_T AS DATETIME)
ELSE CAST(NULL AS DATETIME)
END
INTO #Work
FROM (--==== This whole section would just be FROM dbo.ACCESS_SOURCE
SELECT 'Staff A','30/04/2012','18:10:00','Exit' UNION ALL
SELECT 'Staff B','01/05/2012','08:30:10','Access' UNION ALL
SELECT 'Staff B','01/05/2012','18:31:20','Exit' UNION ALL
SELECT 'Staff C','30/04/2012','22:00:17','Access' UNION ALL
SELECT 'Staff C','30/04/2012','22:01:28','Access' UNION ALL
SELECT 'Staff C','01/05/2012','05:31:00','Exit' UNION ALL
SELECT 'Staff D','30/04/2012','10:00:00','Access' UNION ALL
SELECT 'Staff D','30/04/2012','16:00:00','Exit' UNION ALL
SELECT 'Staff D','30/04/2012','16:03:00','Exit' UNION ALL
SELECT 'Staff D','01/05/2012','19:50:00','Access' UNION ALL
SELECT 'Staff D','02/05/2012','03:50:00','Exit' UNION ALL
SELECT 'Staff D','02/05/2012','12:00:00','Access' UNION ALL
SELECT 'Staff D','02/05/2012','18:00:00','Exit' UNION ALL
SELECT 'Staff E','02/05/2012','19:00:00','Access'
) source (PASS_M, EVENT_D, EVENT_T, MESSAGE_X)
;
--===== Add the quintessential clustered index for the Quirky Update
CREATE UNIQUE CLUSTERED INDEX IX_#Work_QU
ON #Work (Pass_M, Event_DT)
;
I'm pretty sure that someone could figure this all out just using some prestidigitation with ROW_NUMBER() but I decided to do it a different way. This is known as the "Quirky Update" method and it emulates the same method that you would use if you were doing this in front-end code. It will blow the doors off of any recursive CTE, Cursor, or While loop method that you'll be able to come up with. I must warn you that the method is NOT supported by Microsoft but has been a viable method even in the earliest versions of SQL Server and continues to be viable even in SQL Server 2012. It does not support partitioned tables but the Temp Table takes care of that little problem.
The table and option "hints" are absolutely required.
--===== Declare some obviously named variables just like you would do in the front end
DECLARE @PrevPass_M VARCHAR(10),
@PrevEntry_DT DATETIME,
@PrevMessage_X VARCHAR(6),
@SafetyCounter INT
;
--===== Assuming there's at least one row to be process,
-- preset the safety counter to "1"
SELECT @SafetyCounter = 1
;
--===== "Smear" the "first" entry dates down to other rows.
-- See the embedded comments on the CASE function for details.
WITH
cteSafetyRowNumber AS
( --=== Adds a "counter" to the rows in the expected processing order.
SELECT RowNumber = ROW_NUMBER() OVER (ORDER BY Pass_M, Event_DT),
Pass_M, Event_DT, Message_X, Entry_DT
FROM #Work
)
UPDATE srn
SET @PrevEntry_DT = CASE --This CASE does the safety check
WHEN RowNumber = @SafetyCounter --Checks sequence of processing
THEN
CASE --This CASE does the data "smear"
--== Finds first "Access" after "Exit" for same Pass_M
WHEN Pass_M = @PrevPass_M
AND @PrevMessage_X = 'Exit'
AND Message_X = 'Access'
THEN Event_DT
--== Finds first "Access" for new Pass_M
WHEN Pass_M <> @PrevPass_M
AND Message_X = 'Access'
THEN Event_DT
--== "Data smear" the current date for everything else
ELSE @PrevEntry_DT
END
ELSE 1/0 --Forces an error if out of sequence
END,
--== Setup for next "iteration"
Entry_Dt = @PrevEntry_DT,
@PrevPass_M = Pass_M,
@PrevMessage_X = Message_X,
@SafetyCounter = @SafetyCounter + 1
FROM cteSafetyRowNumber AS srn WITH (TABLOCKX)
OPTION (MAXDOP 1)
;
--===== This will create the final required output
WITH
ctePreAggregate AS
( --=== Find the max exit date for every smeared PASS_M/entry date group.
SELECT Pass_M,
Entry_DT,
Exit_DT = MAX(Exit_Dt)
FROM #Work
WHERE Entry_DT IS NOT NULL
AND Exit_DT IS NOT NULL
GROUP BY Pass_M, Entry_Dt
) --=== This simply calculates the columns that require calculations.
SELECT Pass_M,
Entry_Dt,
Exit_Dt,
Worked_Hrs = CAST(DATEDIFF(hh,0,Exit_DT-Entry_DT) AS VARCHAR(10))
+ ':'
+ SUBSTRING(CONVERT(CHAR(5),DATEADD(ss,30,Exit_DT-Entry_DT),108),4,2),
Consecutive_D = ROW_NUMBER() OVER (PARTITION BY Pass_M ORDER BY Entry_DT)
FROM ctePreAggregate
ORDER BY Pass_M, Entry_DT
;
That produces the requested output as follows.
Pass_M Entry_Dt Exit_Dt Worked_Hrs Consecutive_D
------- ----------------------- ----------------------- ---------- -------------
Staff B 2012-05-01 08:30:10.000 2012-05-01 18:31:20.000 10:01 1
Staff C 2012-04-30 22:00:17.000 2012-05-01 05:31:00.000 7:31 1
Staff D 2012-04-30 10:00:00.000 2012-04-30 16:03:00.000 6:03 1
Staff D 2012-05-01 19:50:00.000 2012-05-02 03:50:00.000 8:00 2
Staff D 2012-05-02 12:00:00.000 2012-05-02 18:00:00.000 6:00 3
[font="Arial Black"]Again and as a reminder, if this is meant to be some form of timekeeping system, there are some serious faults with the logic of the original requirements. Unless door entry and exit can be guaranteed recorded events and that every entry will have one and only one exit, this data must NOT be used for keeping time especially for pay![/font]
--Jeff Moden
Change is inevitable... Change for the better is not.
December 9, 2012 at 5:53 pm
Hi Jeff,
HOLY MAMA!!! Omg how did that even come about? Its my third time reading your method and i am still like circling around the forest. Thats way too high level for me:-D I shall read a few more times to digest before starting to try it out. Answering to your earlier qns, if there is a late access is the night with maybe exit only the following day? E.g:if one access at 01/05/2012 23:40:00 and with exit only the next day 02/05/2012 06:00:00, i would pair these two up as a valid record. If there are no exit yet, therefore nth to pair with, we shall ignore this entry record first. Ya we are not using these hrs to pay our workers, we are using these to track how long have they worked. We are concern about their health, we do not want them to overwork, resulting to be sick or neglecting their family. This system will only act as a guideline. We really hope we will be able to start first phase testing next week.
And warning.... Dumb QNS AHEAD:
I feel guilty asking these following qns:
1) where should all these codes goes to? SSIS have a place to place all this codes? (mind to give steps details?)
2) i do not need to have those tutorial steps putting data flow task in control bla bla bla?
3) thirdly:
INTO #Work
FROM (--==== This whole section would just be FROM dbo.ACCESS_SOURCE
SELECT 'Staff A','30/04/2012','18:10:00','Exit' UNION ALL
SELECT 'Staff B','01/05/2012','08:30:10','Access' UNION ALL
SELECT 'Staff B','01/05/2012','18:31:20','Exit' UNION ALL
SELECT 'Staff C','30/04/2012','22:00:17','Access' UNION ALL
SELECT 'Staff C','30/04/2012','22:01:28','Access' UNION ALL
SELECT 'Staff C','01/05/2012','05:31:00','Exit' UNION ALL
SELECT 'Staff D','30/04/2012','10:00:00','Access' UNION ALL
SELECT 'Staff D','30/04/2012','16:00:00','Exit' UNION ALL
SELECT 'Staff D','30/04/2012','16:03:00','Exit' UNION ALL
SELECT 'Staff D','01/05/2012','19:50:00','Access' UNION ALL
SELECT 'Staff D','02/05/2012','03:50:00','Exit' UNION ALL
SELECT 'Staff D','02/05/2012','12:00:00','Access' UNION ALL
SELECT 'Staff D','02/05/2012','18:00:00','Exit' UNION ALL
SELECT 'Staff E','02/05/2012','19:00:00','Access'
) source (PASS_M, EVENT_D, EVENT_T, MESSAGE_X)
CREATE UNIQUE CLUSTERED INDEX IX_#Work_QU
ON #Work (Pass_M, Event_DT)
This i totaly dont uds. I though i should get all the data from the source table? how will unique clustered index looks like? sounds alien to me.
OMG I AM SO NOOB, seriously felt inferior right now:(
Thanks and Sorry,
10e5x
December 9, 2012 at 7:20 pm
Hi phil,
My source is an SQL table from SQL server 2005. So you are suggesting me to leave everything till the SSRS side, then do a stored procedure? In my opinion which will be most prob wrong, would be getting the EVENT_DT column out in the correct format then followed by filtering the data that i want using condition split. After getting this two done. i shall do a order by, then store it in a destination table. Then i will be able to use the destination table at SSRS with the stored procedure methods u mention. Am i right to assume that?
Thanks,
10e5x
December 10, 2012 at 5:56 am
10e5x (12/9/2012)
Hi Jeff,HOLY MAMA!!! Omg how did that even come about? Its my third time reading your method and i am still like circling around the forest. Thats way too high level for me:-D I shall read a few more times to digest before starting to try it out. Answering to your earlier qns, if there is a late access is the night with maybe exit only the following day? E.g:if one access at 01/05/2012 23:40:00 and with exit only the next day 02/05/2012 06:00:00, i would pair these two up as a valid record. If there are no exit yet, therefore nth to pair with, we shall ignore this entry record first. Ya we are not using these hrs to pay our workers, we are using these to track how long have they worked. We are concern about their health, we do not want them to overwork, resulting to be sick or neglecting their family. This system will only act as a guideline. We really hope we will be able to start first phase testing next week.
And warning.... Dumb QNS AHEAD:
I feel guilty asking these following qns:
1) where should all these codes goes to? SSIS have a place to place all this codes? (mind to give steps details?)
2) i do not need to have those tutorial steps putting data flow task in control bla bla bla?
3) thirdly:
INTO #Work
FROM (--==== This whole section would just be FROM dbo.ACCESS_SOURCE
SELECT 'Staff A','30/04/2012','18:10:00','Exit' UNION ALL
SELECT 'Staff B','01/05/2012','08:30:10','Access' UNION ALL
SELECT 'Staff B','01/05/2012','18:31:20','Exit' UNION ALL
SELECT 'Staff C','30/04/2012','22:00:17','Access' UNION ALL
SELECT 'Staff C','30/04/2012','22:01:28','Access' UNION ALL
SELECT 'Staff C','01/05/2012','05:31:00','Exit' UNION ALL
SELECT 'Staff D','30/04/2012','10:00:00','Access' UNION ALL
SELECT 'Staff D','30/04/2012','16:00:00','Exit' UNION ALL
SELECT 'Staff D','30/04/2012','16:03:00','Exit' UNION ALL
SELECT 'Staff D','01/05/2012','19:50:00','Access' UNION ALL
SELECT 'Staff D','02/05/2012','03:50:00','Exit' UNION ALL
SELECT 'Staff D','02/05/2012','12:00:00','Access' UNION ALL
SELECT 'Staff D','02/05/2012','18:00:00','Exit' UNION ALL
SELECT 'Staff E','02/05/2012','19:00:00','Access'
) source (PASS_M, EVENT_D, EVENT_T, MESSAGE_X)
CREATE UNIQUE CLUSTERED INDEX IX_#Work_QU
ON #Work (Pass_M, Event_DT)
This i totaly dont uds. I though i should get all the data from the source table? how will unique clustered index looks like? sounds alien to me.
OMG I AM SO NOOB, seriously felt inferior right now:(
Thanks and Sorry,
10e5x
The Quirky Update really isn't that special. It's the same way you'd do things in front-end code except that SQL Server does all the row reading and writing in it's own little loop (a "pseudo cursor") behind the scenes. The "loop" is all done by the UPDATE and the order is controlled by the ORDER BY of the safety counter with a major assist for the order of the Clustered Index. It'll do things like this on a million rows in just a couple of seconds or less on most machines.
As for the intended use your company has for the code, well done. It's nice to see a company that values its people.
As for what to do with the first part of the code to make it look at your table, just replace the stuff in parenthesis with the table name. Like this...
--===== Set the date format for the given data
SET DATEFORMAT DMY
;
--===== Conditionally drop the temp table to make reruns in SSMS easier.
IF OBJECT_ID('tempdb..#Corrected','U') IS NOT NULL
DROP TABLE #Corrected
;
--===== Create a table with combined dates/times.
-- This should have been done during the SSIS load.
SELECT Pass_M = CAST(PASS_M AS VARCHAR(10)),
Event_DT = CAST(EVENT_D AS DATETIME)
+ CAST(EVENT_T AS DATETIME),
Message_X = CAST(MESSAGE_X AS VARCHAR(6)),
Entry_DT = CAST(NULL AS DATETIME),
Exit_DT = CASE
WHEN MESSAGE_X = 'Exit'
THEN CAST(EVENT_D AS DATETIME)+CAST(EVENT_T AS DATETIME)
ELSE CAST(NULL AS DATETIME)
END
INTO #Work
FROM dbo.Access_Source
;
--===== Add the quintessential clustered index for the Quirky Update
CREATE UNIQUE CLUSTERED INDEX IX_#Work_QU
ON #Work (Pass_M, Event_DT)
;
As for what to do with it in SSIS, I don't really have a clue. SSIS was built to supposedly make ETL easier than trying to do it in T-SQL. I've only worked with it once because I know how to do all of the same stuff pretty easily in T-SQL. That, notwithstanding, I believe this would go into something like an "Execute TSQL" task and you'd probably have to route the output of my code to some other type of file task. I believe that Phil Parkin may be able to help you more in that area because I don't know for sure.
Last but not least, the code will handle the "late entry" stuff as you described just fine as it is. I figured that you'd want it that way but it can reall get the numbers out of whack if there's an entry at something like 1PM without an exit and they "sneak in" the next day and then final have an exit.
--Jeff Moden
Change is inevitable... Change for the better is not.
December 10, 2012 at 6:03 am
This is a most entertaining thread.
I could help with the SSIS stuff (thanks Jeff!) - if it were needed, but it is not.
First task: write the proc to return the data in the required format. With parameters to limit selection, based on requirements.
Second task: develop whatever SSRS reports are needed, using the proc as a data source.
The absence of evidence is not evidence of absence.
Martin Rees
You can lead a horse to water, but a pencil must be lead.
Stan Laurel
December 10, 2012 at 7:20 am
Hi Phil,
I shall try your approach first since u sounds very confident. And I believe u totally know your stuff. But sad to say, I am not up till the standard to achieve what I need just by looking at your two 1 line instruction. I shall start small. Just let me know if I am heading the right way. So now my first task will be go google research on how to write stored procedure in SSIS? Am I right? Btw I have wrote some script transformation to concat and convert my EVENT_D and EVENT_T to date time format.
Willing to learn but need slightly more guidance. I no I am not skillful enough but I have spent hrs on this proj.
Thanks
December 10, 2012 at 7:32 am
10e5x (12/10/2012)
So now my first task will be go google research on how to write stored procedure in SSIS? Am I right?
Oh my. As you said, you really are new to all of this. I have to hand it to your for taking on such a task with so little knowledge of SQL Server.
To begin learning about stored procedures, I guess I'd have you open SSMS (SQL Server Management Studio) and press the {f1} key to get into the free help system known as "Books Online". Once that shows up on the screen, paste the following lookup innto the "Look for:" box and press enter. Follow your nose from there. Go throught the links in the order given.
stored procedures [SQL Server]
--Jeff Moden
Change is inevitable... Change for the better is not.
December 10, 2012 at 7:33 am
Hi Jeff,
Thank you for all te effort u have put in. I just felt very wasted not be able to implement what u taught. But I shall not give up. When I get better, I will find out ways to have ur code in my project. Just that I dk where to put it now.
Just to know so what u are teaching are using TSQL? I will research on that with SSIS.
Now I shall listen and try Phil method
With greatest thanks,
10e5x
December 10, 2012 at 7:41 am
The reason why I use T-SQL for this is because it's frequently much better to do things there. So much so that a lot of people will build "Execute T-SQL" tasks into their SSIS packages because it's either impossible to do in SSIS or a whole lot easier to do in T-SQL.
Since I work with some companies that don't even allow for an SSIS instance, I better know how to do it all in T-SQL. I've even setup systems that log onto FTP sites, down load information, import to stagig table(s), validate the data, move to the final tables, and report it all... and all if it done without ever going near either SSIS or SSRS.
It does take time to learn enough to get to that point, though. That's why they invented things like SSIS... some of the tasks I mentioned are canned and ready to use and you don't necessarily need much knowledge to do such things.
And, no... I don't believe that you could do what we've done in code in SSIS. I could be wrong, though because, like I said, I don't use SSIS. 😀
--Jeff Moden
Change is inevitable... Change for the better is not.
December 10, 2012 at 8:41 am
10e5x (12/10/2012)
Hi Phil,I shall try your approach first since u sounds very confident. And I believe u totally know your stuff. But sad to say, I am not up till the standard to achieve what I need just by looking at your two 1 line instruction. I shall start small. Just let me know if I am heading the right way. So now my first task will be go google research on how to write stored procedure in SSIS? Am I right? Btw I have wrote some script transformation to concat and convert my EVENT_D and EVENT_T to date time format.
Willing to learn but need slightly more guidance. I no I am not skillful enough but I have spent hrs on this proj.
Thanks
Not quite. Stored procedures are written in T-SQL (Transact SQL) and are stored as part of a database's definition.
SSIS is usually used to move data from one server, or platform (eg, a text file or a spreadsheet) to another. It can do a lot of other things too, but that's enough for now, as you have a lot to learn. Can you get help from someone more knowledgeable? The task that you have taken on is not what I would call a simple introduction 🙂
In your case, as far as I can tell, SSIS will NOT be part of the solution at all. I suggest that you focus first on writing your T-SQL and building your stored procedure, then go on from there.
The absence of evidence is not evidence of absence.
Martin Rees
You can lead a horse to water, but a pencil must be lead.
Stan Laurel
Viewing 15 posts - 1 through 15 (of 31 total)
You must be logged in to reply to this topic. Login to reply