?
Solved

Check for no records or only one record in Access DB

Posted on 2004-10-19
2
Medium Priority
?
202 Views
Last Modified: 2010-04-24
Hello,

I am working on a project that takes input data and saves it to a database in Access using ADO.
I have the program working correctly until I take out the records and check for no records. It crashes on the totals. Please see below



Dim pintRecords As Integer
        Dim pbndTemp As Binding

        lblDisplay.Visible = True
        lblAddMode.Visible = False
        lblEditMode.Visible = False
        pintRecords = oledbCustomers1.Fill(DsCustomers1)
        btnPrevious.Enabled = False

        ' Populate the DataSet with records using the DataAdapter. This DataAdapter was
        ' configured using the Wizard supplied by the OleDbDataAdapter control.

        ' Set up the bindings for each control instance. For each control instance, create
        ' a Binding object. Specify the property to bind (Text), the DataSet, and the
        ' navigation path to the field. Scond, add the binding the the control instance's
        ' DataBindings collection.

       
           

            pbndTemp = New Binding("Text", DsCustomers1, "tblCustomers.fldCustomerID")
            txtCustID.DataBindings.Add(pbndTemp)

            pbndTemp = New Binding("Text", DsCustomers1, "tblCustomers.fldFirstName")
            txtFirst.DataBindings.Add(pbndTemp)

            pbndTemp = New Binding("Text", DsCustomers1, "tblCustomers.fldLastName")
            txtLast.DataBindings.Add(pbndTemp)

            pbndTemp = New Binding("Text", DsCustomers1, "tblCustomers.fldAddress")
            txtAddress.DataBindings.Add(pbndTemp)

            pbndTemp = New Binding("Text", DsCustomers1, "tblCustomers.fldCity")
            txtCity.DataBindings.Add(pbndTemp)

            pbndTemp = New Binding("Text", DsCustomers1, "tblCustomers.fldState")
            txtState.DataBindings.Add(pbndTemp)

            pbndTemp = New Binding("Text", DsCustomers1, "tblCustomers.fldZipCode")
            txtZip.DataBindings.Add(pbndTemp)

            pbndTemp = New Binding("Text", DsCustomers1, "tblCustomers.fldAnnualSales")
            txtAnnSales.DataBindings.Add(pbndTemp)

            pbndTemp = New Binding("Text", DsCustomers1, "tblCustomers.fldBalanceDue")
            txtBalDue.DataBindings.Add(pbndTemp)

            pbndTemp = New Binding("Text", DsCustomers1, "tblCustomers.fldCreditLimit")
        txtCredit.DataBindings.Add(pbndTemp)
        Call EditState(cblnNotEditing)
        Call Totals()

        If txtCustID.Text = "" Then
            MessageBox.Show("There are no records currently in this database")
            grpNavigate.Hide()
            lblOverLimit.Visible = False
            tmrInvalid.Stop()
            btnAdd.Enabled = False
            btnEdit.Enabled = True
            btnsave.Enabled = True
            btnCancel.Enabled = False
            btnDelete.Enabled = False

            Exit Sub
        End If
        End Sub

****For the totals I have the following:

Private Sub Totals()
        Dim mdblmonthSal As Double
        Dim mdblannualSales As Double
        Dim mdblCreditLimit As Double
        Dim mdblBalDue As Double
        Dim mdblAvailBal As Double


        mdblannualSales = ToDouble(txtAnnSales.Text)  ***************CRASHES ON THIS LINE
        mdblmonthSal = mdblannualSales / 12
        txtMonth.Text = mdblmonthSal.ToString("###,###.##")

        mdblCreditLimit = ToDouble(txtCredit.Text)
        mdblBalDue = ToDouble(txtBalDue.Text)

        mdblAvailBal = mdblCreditLimit - mdblBalDue
        txtBalAvail.Text = mdblAvailBal.ToString("###,###.##")

        If mdblCreditLimit = mdblBalDue Then
            txtBalAvail.Text = "Zero Balance"
        End If
        Call Overlimit()
    End Sub

*********The Form Load is looking at the temp holding variable (mdblCreditLimit)  and telling me the input text is incorrect. Should be ToString.
Also how would I check for only one record in the Access DB.

Thanks for your help.
0
Comment
Question by:itcopt
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
2 Comments
 
LVL 27

Expert Comment

by:planocz
ID: 12351067
You could do something like this....

Dim pintRecords As Integer
        Dim pbndTemp As Binding

        lblDisplay.Visible = True
        lblAddMode.Visible = False
        lblEditMode.Visible = False
        pintRecords = oledbCustomers1.Fill(DsCustomers1)
        btnPrevious.Enabled = False

        if DsCustomers1.Tables(0).Rows.Count <= 1 then
              messagebox("I have only one or less records")
              exit sub
       end if
0
 
LVL 4

Accepted Solution

by:
eozz_2000 earned 500 total points
ID: 12351854
I would change the code above with the name of the table, becaouse I wouldn't know if the table with the index 0 is the table that itcopt wants to check:

Select Case DsCustomers1.Tables("Table_Name").Rows.Count
  case 0:
    msgbox("The table is empty")
  case 1:
    msgbox("You have only 1 record")
  case Else:
    'The execution will be here if you have 2 or more records
End Select
0

Featured Post

Technology Partners: We Want Your Opinion!

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

Question has a verified solution.

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

Creating an analog clock UserControl seems fairly straight forward.  It is, after all, essentially just a circle with several lines in it!  Two common approaches for rendering an analog clock typically involve either manually calculating points with…
The ECB site provides FX rates for major currencies since its inception in 1999 in the form of an XML feed. The files have the following format (reducted for brevity) (CODE) There are three files available HERE (http://www.ecb.europa.eu/stats/exch…
In this video we outline the Physical Segments view of NetCrunch network monitor. By following this brief how-to video, you will be able to learn how NetCrunch visualizes your network, how granular is the information collected, as well as where to f…
Michael from AdRem Software outlines event notifications and Automatic Corrective Actions in network monitoring. Automatic Corrective Actions are scripts, which can automatically run upon discovery of a certain undesirable condition in your network.…
Suggested Courses
Course of the Month11 days, 22 hours left to enroll

752 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