Ger Cannoll
|
|
Group: StrataFrame Users
Posts: 430,
Visits: 507
|
How do I extract the Date Only from a SF DateBoxe.g. DateTime myDate = DateTime.Today.Date gets Date Only Part But I cant seem to do: DateTime myDatepart = MySfDateBox.Date
|
|
|
Edhy Rijo
|
|
Group: StrataFrame Users
Posts: 2.4K,
Visits: 23K
|
Hi Gerard, What is the code that is triggering the exception? posting the exception will help in finding out where exactly the code is failing. Also in your Client Code, pass the x.Date to the @DateFrom DateTime x = new DateTime(this.dateFrom.CurrentYear, this.dateFrom.CurrentMonth, this.dateFrom.CurrentDay); comm.Parameters.AddWithValue("@DateFrom", x.Date).SqlDbType= SqlDbType.Date;
Edhy Rijo
|
|
|
Ger Cannoll
|
|
Group: StrataFrame Users
Posts: 430,
Visits: 507
|
Hi Edhy.
Did as you suggested (comm.Parameters.AddWithValue("@DateFrom", x.Date).SqlDbType= SqlDbType.Date;..... still an error
I have attached the error in case i gives a clue.
Regards,
Gerard
|
|
|
Ger Cannoll
|
|
Group: StrataFrame Users
Posts: 430,
Visits: 507
|
Sorry previos post does not seem to have attachment....attachemnt now
|
|
|
Edhy Rijo
|
|
Group: StrataFrame Users
Posts: 2.4K,
Visits: 23K
|
Put a break in your code and do a screenshot of the code in the debugger where it breaks, also please copy and paste the code here. It looks like your date or the value you are sending is a string and not a date.
Edhy Rijo
|
|
|
Ger Cannoll
|
|
Group: StrataFrame Users
Posts: 430,
Visits: 507
|
Hi Edhy.... do you mean put a break in the Stored Procedure Code (Standard TSQL) where the error is happening ....didnt know you could do that ??
|
|
|
Edhy Rijo
|
|
Group: StrataFrame Users
Posts: 2.4K,
Visits: 23K
|
Ger Cannoll (8/10/2012) Hi Edhy.... do you mean put a break in the Stored Procedure Code (Standard TSQL) where the error is happening ....didnt know you could do that ??Nope, if the error is coming from the Stored Procedure, please paste the SP here or if it is too long, then copy it to a text document and attach it here. Also did you try running the sp in MSMS (Microsoft SQL Server Management Studio)? if so, did it give you an error there too?
Edhy Rijo
|
|
|
Ger Cannoll
|
|
Group: StrataFrame Users
Posts: 430,
Visits: 507
|
Hi Edhy. Main bits of my SProc is:
SELECT * from ITR WHERE ((@StageOperator = '=' AND ITR_STAGE = @StageQuery ) or (@StageOperator = '>=' and ITR_STAGE >= @StageQuery ) ) AND (ITR_POST = @PostQuery) AND (ITR_CUSREF >= @AccountFrom OR Len(LTRIM(RTRIM(@AccountFrom))) = 0) AND (ITR_CUSREF <= @AccountTo OR Len(LTRIM(RTRIM(@AccountTo))) = 0) AND (@TranQuery >= @TranFrom OR Len(Ltrim(Rtrim(@TranFrom))) = 0) AND (@TranQuery <= @TranTo OR Len(Ltrim(Rtrim(@TranTo))) = 0) AND (@DateQuery >= @DateFrom OR @DateFrom = '1800-01-01' ) AND (@DateQuery <= @DateTo OR @DateTo = '1800-01-01') OPTION (RECOMPILE)
Suspect the fact that have 'Datefrom = '1800-01-01' is causing it to be treated as a string, and I dont get error if I ensure date is this format when called from SSMS
|
|
|
Edhy Rijo
|
|
Group: StrataFrame Users
Posts: 2.4K,
Visits: 23K
|
Hi Gerard, I guess you want to be able to pass a date to filter the data, but if the date is 1800-1-1, then to ignore that condition. If that is the case, then try casting the '1800-01-01' to a date value as shown below and that should take care of the error. AND (@DateQuery >= @DateFrom OR @DateFrom = cast('1800-01-01' as date) AND @DateQuery <= @DateTo OR @DateTo = cast('1800-01-01' as date))
Also, pay attention to the open and close parenthesis, since you are trying to filter by a date condition, the whole expression should be enclosed in a parenthesis, so it will be a single condition.
Edhy Rijo
|
|
|
Ger Cannoll
|
|
Group: StrataFrame Users
Posts: 430,
Visits: 507
|
Hi Edhy. I have established what the problem here is , but dont know how to fix it.
In my Select Command, depending on a parameter passed into the stored procedure, i need to change the Field from the Table that is used. Sometimes it may be the Order date, sometimes the Despatch date and sometimes the Invoice date. I pass in a parmater and then have a series of Ifs to store the filed name into a variable. Then, because I am using the variable in the Select string, and not the actual Field name, this gives the error. Here is an example of a cut doen SP which will give an error:
ALTER PROCEDURE [dbo].[TestSPR] @Paramdate Date AS BEGIN SET NOCOUNT ON; --SELECT * FROM ITR WHERE ITR_ORDDAT >= @Paramdate (This command works Fine) DECLARE @Mydate VARCHAR set @MyDate = 'ITR_ORDDAT' SELECT * FROM ITR WHERE @MyDate >= @Paramdate // This Line gives an error END
So if I use SELECT * FROM ITR WHERE ITR_ORDDAT >= @Paramdate ...... works fine
If I store 'ITR_ORDDAT' into @MyDate and run the select (as above) , gives an conversion string to date/Time error.
|
|
|
Edhy Rijo
|
|
Group: StrataFrame Users
Posts: 2.4K,
Visits: 23K
|
Hi Gerard, Ger Cannoll (8/11/2012) Hi Edhy. I have established what the problem here is , but dont know how to fix it. In my Select Command, depending on a parameter passed into the stored procedure, i need to change the Field from the Table that is used. Sometimes it may be the Order date, sometimes the Despatch date and sometimes the Invoice date.Now I understand data:image/s3,"s3://crabby-images/9ef61/9ef61e1dd26cb2fdb8826d9d99b2a294f02a8199" alt="Smile" if you would have posted the whole stored procedure before, we would have figure this one out faster data:image/s3,"s3://crabby-images/9ad62/9ad6288c2b64abea476941e188894311209e7f79" alt="BigGrin" You have to use a CASE statement in your sp WHERE condition to manage this. In the sample code below, you have to populate the parameter @MyDateFieldName with the expected value used in the CASE WHEN of the sp. All this is nice, but be aware that you should test all possible conditions and make sure your table ITR has the recommended indexes to optimize these WHERE conditions. Have fun!!! data:image/s3,"s3://crabby-images/f79f6/f79f6a3ef80c5edac4af9723b64c4edb9a7ff802" alt="Hehe" ALTER PROCEDURE [dbo].[TestSPR] @Paramdate Date, @MyDateFieldName VARCHAR AS BEGIN SET NOCOUNT ON; SELECT * FROM ITR WHERE CASE @MyDateFieldName WHEN 'OrderDate' THEN ITR_ORDDAT WHEN 'InvoiceDate' THEN ITR_INVDAT END >= @ParamDate END
Edhy Rijo
|
|
|
Ger Cannoll
|
|
Group: StrataFrame Users
Posts: 430,
Visits: 507
|
Hi Edhy.
I have this working now. Thanks for all your help
I intially had though that Parameter Substitiution worked as I had also some Paranater Substitiution on for Character based Fields (as in @MyCharFieldName >= 'SomeString')
I 'thought' that this was workong as no error was beong generated, but now realise all that was happenong was that the Charcater String --> MyCahrFiledName was being compared to the sting ---> SomeString. I was locked in a VFP timewarp and assmed that SQL SProcs worked in a similar way to VFP Macro Substitution.
Regards,
Gerard
|
|
|
Edhy Rijo
|
|
Group: StrataFrame Users
Posts: 2.4K,
Visits: 23K
|
Hi Gerard, I am glad we clear this one out. data:image/s3,"s3://crabby-images/9ef61/9ef61e1dd26cb2fdb8826d9d99b2a294f02a8199" alt="Smile" Ger Cannoll (8/13/2012) I was locked in a VFP timewarp and assmed that SQL SProcs worked in a similar way to VFP Macro Substitution.Yeah, I loved VFP Macro Substitution, and it has been hard working without it in some situations but MS-SQL is a totally different animal than VFP when dealing with data, and the things that can be done with TSQL and SQL Engine are just amazing when compared with the way we did it back then with VFP.
Edhy Rijo
|
|
|