Plateforme Level Extreme
Abonnement
Profil corporatif
Produits & Services
Support
Légal
English
SQL Stored Procedure
Message
De
26/07/2010 13:38:50
Andy Roth
Neyenesch Printers
Californie, États-Unis
 
 
À
24/07/2010 17:50:28
Information générale
Forum:
Visual FoxPro
Catégorie:
Codage, syntaxe et commandes
Divers
Thread ID:
01473624
Message ID:
01473940
Vues:
51
>>>>>>I have 3 parameters I am trying to pass to a stored procedure
>>>>>>They are date fields in the parameters, not date time.
>>>>>>The SP variables are string.
>>>>>>
>>>>>>Is this the correct syntax in Foxpro 9?
>>>>>>I am not getting a cursor to be generated.
>>>>>>The SP works when I enter 01/01/2009 and 02/01/2009 in QA
>>>>>>
>>>>>>ldStartDate={}
>>>>>>ldEndDate={}
>>>>>>ldStartDate=thisform.startdate.value
>>>>>>ldEndDate=thisform.enddate.value
>>>>>>
>>>>>> lcSQLCMD="exec get_invoices ?ldStartDate,?ldEndDate"
>>>>>> SQLEXEC(gnConnect,lcSQLCMD,'jobcost')
>>>>>>
>>>>>>
>>>>>>the parameters in the SP are this
>>>>>>
>>>>>>Alter PROCEDURE get_invoices
>>>>>> @ldStartDate Char(12) = '',
>>>>>> @ldEndDate Char(12) = ''
>>>>>>AS
>>>>>
>>>>>Andy,
>>>>>Why are you not using date or datetime in your SP to prevent ambigiuties? Anyway if you want them as strings you can have them as strings like that. First decide what does '02/01/2009' mean. Say, if it is Feb 1, 2009 and you have set date to mdy then you could construct the string in VFP like this:
>>>>>
>>>>>
ldStartDate=thisform.startdate.value
>>>>>ldEndDate=thisform.enddate.value
>>>>>
>>>>>lcStartDate = dtoc(m.ldStartDate)
>>>>>lcEndDate  = dtoc(m.ldEndDate)
>>>>>lcSQLCMD="exec get_invoices ?m.lcStartDate,?m.lcEndDate"
>>>>>SQLEXEC(gnConnect,lcSQLCMD,'jobcost')
>>>>>
>>>>>PS: It is better to have date/datetimes as date/datetime on both sides instead of doing character conversions.
>>>>>Cetin
>>>>
>>>>Thanks
>>>>
>>>>so it should be this?
>>>>Alter PROCEDURE get_invoices
>>>> @ldStartDate DateTime,
>>>> @ldEndDate DateTime
>>>>What happens if there is a time in the database but I am only getting the date as a prompt?
>>>
>>>I am not sure I understand. A date would be passed as a datetime parameter. Internally a date like 1/1/2000 is considered to be a datetime value of 1/1/2000 00:00:00 (or 12:00:00 AM).
>>>Cetin
>>
>>Correct but i in the database the end date was greater than 1/1/2000 00:00:00 (or 12:00:00 AM).
>>say 1/1/2000 10:00:00 it would not be in the report
>>
>>the query uses invdate between startdate and end date 01/01/2000 10:00:00 is greater than 1/1/2000 00:00:00
>>and would not be in the results
>>
>>but if it was al just date it would be
>
>I seem to recall having a similar problem. I was not using a stored procedure and got the data via SPT. The query was something like
>SQLEXEC(nHandle,"SELECT * FROM myTable WHERE DATE(datetimeField) BETWEEN ?ldStartDate AND ?ldEndDate)
>
>Would it be possible to modify the SP to do something like that?
no stored procedure to large.
thanks
Précédent
Suivant
Répondre
Fil
Voir

Click here to load this message in the networking platform