Solved

How do I convert an sql parameter value into datetime?

Posted on 2009-05-08
11
505 Views
Last Modified: 2013-12-17
I have written the attached C# code for my web site using visual studio 2008. I have created a dataset for my reportviewer control that is getting filled from the results of a stored procedure. The results from that stored procedure are of the smalldatetime value. Everytime I run my web site I get the error: "Cannot convert string to datetime" on the line:

da.Fill(thisDataSet)

I guess I need to do a conversion somewhere? I also want to show my smalldatetime data as just the date without a time value attached, is this possible?

Thanks.
ReportViewer1.Visible = true;
        SqlConnection thisConnection = new SqlConnection(thisConnectionString);
        SqlCommand cmd = new SqlCommand("CrucialDates.proc_ShowCrucialByDate", thisConnection);
        cmd.CommandType = CommandType.StoredProcedure;
        cmd.Parameters.AddWithValue("@DueDateFrom", tbCrucialSearchDateFrom.Text);
        cmd.Parameters.AddWithValue("@DueDateTo".ToString(), tbCrucialSearchDateTo.Text);
        SqlDataAdapter da = new SqlDataAdapter(cmd);
        System.Data.DataSet thisDataSet = new System.Data.DataSet();
        da.Fill(thisDataSet);
 
        ReportDataSource datasource = new ReportDataSource("CrucialDatesDataSet_proc_ShowCrucialByDate", thisDataSet.Tables[0]);
 
        ReportViewer1.LocalReport.DataSources.Clear();
        ReportViewer1.LocalReport.DataSources.Add(datasource);
        if (thisDataSet.Tables[0].Rows.Count == 0)
        {
            lblMessage.Text = "No Crucial Dates are due!";
        }
 
        ReportViewer1.LocalReport.Refresh();

Open in new window

0
Comment
Question by:Shepwedd
  • 4
  • 4
  • 2
  • +1
11 Comments
 
LVL 8

Expert Comment

by:arhame
ID: 24335882
Hmm, this is the syntax I use when doing a SQL datetime insert:

insertCommand.Parameters.Add("LaborDate", Data.SqlDbType.DateTime).Value = tbDateWorked.Text
0
 
LVL 75

Expert Comment

by:käµfm³d 👽
ID: 24335968
Have you tried
        cmd.Parameters.AddWithValue("@DueDateFrom", Convert.ToDateTime(tbCrucialSearchDateFrom.Text));
        cmd.Parameters.AddWithValue("@DueDateTo".ToString(), Convert.ToDateTime(tbCrucialSearchDateTo.Text));

Open in new window

0
 
LVL 62

Expert Comment

by:Fernando Soto
ID: 24336069
Hi Shepwedd;

Try changing the two lines in the code snippet.

Fernando
cmd.Parameters.AddWithValue("@DueDateFrom", DateTime.Parse(tbCrucialSearchDateFrom.Text));
cmd.Parameters.AddWithValue("@DueDateTo", DateTime.Parse(tbCrucialSearchDateTo.Text));

Open in new window

0
PRTG Network Monitor: Intuitive Network Monitoring

Network Monitoring is essential to ensure that computer systems and network devices are running. Use PRTG to monitor LANs, servers, websites, applications and devices, bandwidth, virtual environments, remote systems, IoT, and many more. PRTG is easy to set up & use.

 

Author Comment

by:Shepwedd
ID: 24336098
kaufmed,

That worked, great!

I also want to show my smalldatetime data as just the date without a time value attached, is this possible?

Thanks.
0
 

Author Comment

by:Shepwedd
ID: 24336118
That worked as well Fernando.

Can you help me with my other question stated above?
0
 
LVL 75

Expert Comment

by:käµfm³d 👽
ID: 24336136
DateTime objects have an overloaded ToString() method that takes a formatting parameter:
DateTime d = DateTime.Now;
 
d.ToString("MM/dd/yyyy");   // Note 'M' as opposed to 'm'; 'm' is for minutes

Open in new window

0
 
LVL 62

Expert Comment

by:Fernando Soto
ID: 24336256
Hi Shepwedd;

I am not a ASP .Net programmer and am not sure about ReportViewer for the web. Let me look at the documentation and will post in a little while.

Fernando
0
 

Author Comment

by:Shepwedd
ID: 24336275
Thanks Fernando.
0
 

Author Comment

by:Shepwedd
ID: 24336287
kaufmed,

How do I use your suggested code so my reportviewer control shows the correctly formatted date?
0
 
LVL 62

Accepted Solution

by:
Fernando Soto earned 500 total points
ID: 24336745
Hi Shepwedd;

Try the following:

When you design your MicrosoftReportViewer and have it all defined, Page, Group and Columns click on the Row with the Date Field, the text box should start with =Field!... Once the text box is selected right click on it and select Properties from the context menu. When the TextBox Properties windows open select the Format tab at the top of the page. To the right of the "Format code:" textbox their is a button with the text "...", click on it. When the Choose Format window opens select date in the left list box and in the right listbox select 5/8/2009. Then click on "OK" button, Then click on "OK" button again in the other window and that should do it.

Fernando
0
 
LVL 62

Expert Comment

by:Fernando Soto
ID: 24337354
Hi Shepwedd;

Try the following:

When you design your MicrosoftReportViewer and have it all defined, Page, Group and Columns click on the Row with the Date Field, the text box should start with =Field!... Once the text box is selected right click on it and select Properties from the context menu. When the TextBox Properties windows open select the Format tab at the top of the page. To the right of the "Format code:" textbox their is a button with the text "...", click on it. When the Choose Format window opens select date in the left list box and in the right listbox select 5/8/2009. Then click on "OK" button, Then click on "OK" button again in the other window and that should do it.

Fernando
0

Featured Post

Ransomware-A Revenue Bonanza for Service Providers

Ransomware – malware that gets on your customers’ computers, encrypts their data, and extorts a hefty ransom for the decryption keys – is a surging new threat.  The purpose of this eBook is to educate the reader about ransomware attacks.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

Title # Comments Views Activity
EF5: Question about Metadata Artifact Processing 4 15
.NET 2008 VB and C# 6 27
Find results from sql within a time span 11 29
Sort GridView by ID Descending 1 10
Problem Hi all,    While many today have fast Internet connection, there are many still who do not, or are connecting through devices with a slower connect, so light web pages and fast load times are still popular.    If your ASP.NET page …
A long time ago (May 2011), I have written an article showing you how to create a DLL using Visual Studio 2005 to be hosted in SQL Server 2005. That was valid at that time and it is still valid if you are still using these versions. You can still re…
In a recent question (https://www.experts-exchange.com/questions/28997919/Pagination-in-Adobe-Acrobat.html) here at Experts Exchange, a member asked how to add page numbers to a PDF file using Adobe Acrobat XI Pro. This short video Micro Tutorial sh…
Email security requires an ever evolving service that stays up to date with counter-evolving threats. The Email Laundry perform Research and Development to ensure their email security service evolves faster than cyber criminals. We apply our Threat…

776 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question