Friday, January 10, 2020

How to Connect a Database and Add/Update/Delete/Record

How to Connect to a Database and Add/Update/Delete Record In this tutorial I will explain to you on how to connect to an Access database and allow you to Add/Update/Delete  a record. To fully understand these tutorials please  download  the source code  How to Add/Update/Delete Record using MS Access Database. This source code is part of the  Hotel Reservation System  that I am currently working. At the end of this tutorial you will learn the basic of database programming. I would like, however, to emphasize especially for beginners that one way to learn programming is to know how to debug a program and devote some of your time to reading.Don't be frightened on how short or long an article should be. The important is at the end of the tutorial you will learn something NEW! If you already know the topic, then don’t bother to study this again. Table of Contents 1. Introduction 2. Let’s get started 3. Database Connection 4. Add and Update a Record 5. Delete a R ecord 6. Final Thoughts Introduction Before I started learning VB. NET one of the topic that I search for in the internet is on how to connect to the database and make some changes to the table. Although there’s a lot of results, but I cannot find one that suit to my needs.Most of the tutorial is using drag and drop features of vb. net editor. Well, this is okay in most cases but what if you’d like to manipulate the data by code? So, I created this tutorial so that beginner programmer will learn from this. Let’s get started It is very important that you use your common sense to understand the logic of database programming. There’s a lot of features built-in to Visual Basic Editor that most programmer especially beginner who overlook it. One of the favorite tools I usually used is the  DEBUGGER. If you only knew how important a debugger is, then you do not even need to study this tutorial.Why? Because you can jump right away to the source code and start firing the F8 command from your keyboard and analyze every line as you step through the code. Anyway beginner is a beginner. You need to start from scratch. If you have already downloaded the source code, then open it in the visual basic . net editor by double clicking the â€Å"HowtoAddUpdateDeleteRecord. sln†. If you want to know what is the object that runs the first time you start the program (by pressing F5) then double click the â€Å"My Project† at the Solution Explorer. Look at the Startup Form.You will see that the value is â€Å"frmCustomersList†. Now, click this object in the Solution Explorer and click the View Code at the toolbar. Look for the Load event similar below: Private  Sub  frmCustomersList_Load(ByVal  sender  As  System. Object,  ByVal  e  As  System. EventArgs)Handles  MyBase. Load   Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚   sSql =  Ã¢â‚¬Å"SELECT CustomerID, CompanyName, ContactName, ContactTitle, Address FROM Customers ORDER BY Cu stomerID ASC†   Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Call  FillList() FillListView(lvList, GetData(sSql)) End  Sub frmCustomersList_Load is the second procedure that runs when you hit the F5 Key from your keyboard.If you’d like to know how this code is executed then press F8. Believe it or not F8 is the answer to all your programming question. And I really mean it. When I started programming all I do is to search for free source code and start using the debugging tool. That’s why Visual Basic is being named as Rapid Application Development or RAD. If you follow the debugger the first line it executes is the  Private  Sub  frmCustomersList_Resize(ByVal  senderAs  Object,  ByVal  e  As  System. EventArgs)  then followed by  frmCustomersList_Load  which is actually the important procedure to note here.Another important debugging tool is â€Å"Toggle Breakpoint†. You will be prompted to your code if one of the line is marked by toggle brea k point. This can be done by pressing the F9 key or clicking the Debug menu then Toggle Breakpoint. This tool is important if the form is already loaded and you want to tract the execution of a code say within a command button. For example. Open the form  frmCustomersList  and double click the add button and move the up arrow key once and press F9. You willl have a picture as shown below: [inline:Toggle Breakpoint. jpg]Now, when you run the program and click the Add button you will be directed to the code editor window. This case you will see what is happening when you are executing the program. Isn’t it nice? Database Connection In order to connect to the database you need a connection string like this: Public  Const  cnString  As  String  =  Ã¢â‚¬Å"Provider=Microsoft. Jet. OLEDB. 4. 0;Persist Security Info=False;Data Source=.. /data/sample. mdb† Then open it by using this command: Dim  cnHotel  As  OleDbConnection cnHotel =  New  OleDbConnect ion With  cnHotel If  . State = ConnectionState.Open  Then  . Close() .ConnectionString = cnString .Open() End  With You need this whether you use  OleDbDataReader, ExecuteNonQuery or OleDbCommandBuilder  to read or write into the database table. To know more about this class just click this command and press F1 key to open the help files. Be sure you installed the MSDN. Since you have already open the connection to your database this is now the time to fill the ListView with data. This can be done by calling a function like: FillListView(lvList, GetData(sSql)) The line of code will then execute a function: Fill ListView control with data Public  Sub  FillListView(ByRef  lvList  As  ListView,  ByRef  myData  As  OleDbDataReader)   Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Dim  itmListItem  As  ListViewItem Dim  strValue  As  String Do  While  myData. Read itmListItem =  New  ListViewItem() strValue = IIf(myData. IsDBNull(0),  Ã¢â‚¬Å"†, myData. GetValue(0))   Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚   itmListItem. Text = strValue For  shtCntr = 1  To  myData. FieldCount() – 1   Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  If  myData. IsDBNull(shtCntr)  Then   Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚   itmListItem. SubItems. Add(â€Å"†)   Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Else itmListItem. SubItems. Add(myData. GetString(shtCntr))   Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  End  IfNext  shtCntr lvList. Items. Add(itmListItem) Loop End  Sub Again in order to see how this code is being executed just run the program using the debugging tool (either F8 or F9). The rest of the procedure is executed only when they are called. For example, the code below is executed only when you click the Add button. Private  Sub  btnAdd_Click(ByVal  sender  As  System. Object,  ByVal  e  As  S ystem. EventArgs)  HandlesbtnAdd. Click   Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Dim  CustomerID  As  String frmCustomers. State = gModule. FormState. adStateAddMode   Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  For  Each  sItem  As  ListViewItem  In  lvList.SelectedItems   Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚   CustomerID = sItem. Text Next frmCustomers. CustomerID = CustomerID frmCustomers. ShowDialog() Call  FillList() End  Sub This code will open the form  frmCustomers  in add mode and will execute also its own Load Event. If you want to open the form  frmCustomers  in edit mode, then just double click the item in a ListView. The code being executed are: Private  Sub  lvList_DoubleClick(ByVal  sender  As  Object,  ByVal  e  As  System. EventArgs)  HandleslvList. DoubleClick   Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Dim  CustomerID  As  String For  Each  sItem  As  ListViewItem  In  lvList.SelectedItems   Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚     Ã‚   CustomerID = sItem. Text Next With  frmCustomers .State = gModule. FormState. adStateEditMode   Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚   . CustomerID = CustomerID .ShowDialog() Call  FillList() End  With frmCustomers =  Nothing End  Sub The two procedure seems carry the same concept, by opening a form, except they vary on the button invoke for execution. The line frmCustomers. State = gModule. FormState. adStateAddMode will tell the target form to open the connection to the database in add mode and frmCustomers. State = gModule. FormState. adStateEditMode ill open the database in edit mode. Add and Update a Record Now, how to save the data in textboxes within the form? This can be done by calling a procedure calledbtnSave_Click. This procedure is fired when the Save button is clicked. Private  Sub  btnSave_Click(ByVal  sender  As  System. Object,  ByVal  e  As  System. EventArgs)  HandlesbtnSave. Click   Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Dim  d t  As  DataTable = dsCustomers. Tables(â€Å"Customers†)   Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  If  txtCustomerID. Text =  Ã¢â‚¬Å"†Ã‚  Or  txtCompanyName. Text =  Ã¢â‚¬Å"†Ã‚  Then   Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚   MsgBox(â€Å"Please fill up Customer ID or Company Name information. â€Å", MsgBoxStyle.Critical)   Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Exit  Sub End  If Try If  State = gModule. FormState. adStateAddMode  Then   Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã¢â‚¬Ëœ add a row Dim  newRow  As  DataRow newRow = dt. NewRow() newRow(â€Å"CustomerID†) = txtCustomerID. Text   Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚   dt. Rows. Add(newRow) End  If With  dt .Rows(0)(â€Å"CustomerID†) = txtCustomerID. Text   Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚   . Rows(0)(â€Å"CompanyName†) = txtCompanyName. Text   Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚     Ã‚  Ã‚  Ã‚   . Rows(0)(â€Å"ContactName†) = IIf(txtContactName. Text =  Ã¢â‚¬Å"†, System. DBNull. Value, txtContactName. Text)   Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚   . Rows(0)(â€Å"ContactTitle†) = IIf(txtContactTitle. Text =  Ã¢â‚¬Å"†, System.DBNull. Value, txtContactTitle. Text)   Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚   . Rows(0)(â€Å"Address†) = IIf(txtAddress. Text =  Ã¢â‚¬Å"†, System. DBNull. Value, txtAddress. Text)   Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚   . Rows(0)(â€Å"City†) = IIf(txtCity. Text =  Ã¢â‚¬Å"†, System. DBNull. Value, txtCity. Text)   Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚   . Rows(0)(â€Å"Region†) = IIf(txtRegion. Text =  Ã¢â‚¬Å"†, System. DBNull. Value, txtRegion. Text)   Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚   . Rows(0)(â€Å"PostalCode†) = IIf(txtPostalCode. Text =  Ã¢â‚ ¬Å"†, System. DBNull. Value, txtPostalCode. Text)   Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚   . Rows(0)(â€Å"Country†) = IIf(txtCountry. Text =  Ã¢â‚¬Å"†, System. DBNull. Value, txtCountry.Text)   Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚   . Rows(0)(â€Å"Phone†) = IIf(txtPhone. Text =  Ã¢â‚¬Å"†, System. DBNull. Value, txtPhone. Text)   Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚   . Rows(0)(â€Å"Fax†) = IIf(txtFax. Text =  Ã¢â‚¬Å"†, System. DBNull. Value, txtFax. Text)   Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚   daCustomers. Update(dsCustomers,  Ã¢â‚¬Å"Customers†)   Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚   MsgBox(â€Å"Record successfully saved. â€Å", MsgBoxStyle. Information)   Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  End  With Catch  ex  As  OleDbException MsgBox(ex. ToString) End  Try End  Sub The code for adding and u pdating a table is the same except that if you are in add mode you just simply add this command: If  State = gModule.FormState. adStateAddMode  Then ‘ add a row Dim  newRow  As  DataRow newRow = dt. NewRow() newRow(â€Å"CustomerID†) = txtCustomerID. Text dt. Rows. Add(newRow) End If This way you do not need to create a separate command to insert and update a table. Delete a Record Let us go back to  frmCustomersList  form and delete a record. The procedure before will be fired after clicking a Delete button: Private  Sub  btnDelete_Click(ByVal  sender  As  System. Object,  ByVal  e  As  System. EventArgs)  HandlesbtnDelete. Click   Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Dim  CustomerID  As  String For  Each  sItem  As  ListViewItem  In  lvList.SelectedItems   Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚   CustomerID = sItem. Text Next If  CustomerID ;;  Ã¢â‚¬Å"†Ã‚  Then ‘Delete the selected record Dim  strDeleted   As  Boolean strDeleted = ExecNonQuery(â€Å"DELETE Customers. CustomerID FROM Customers WHERE CustomerID= ‘†Ã‚  & CustomerID &  Ã¢â‚¬Å"‘†)   Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  If  strDeleted =  Ã¢â‚¬Å"True†Ã‚  Then MsgBox(â€Å"Record's deleted. â€Å", MsgBoxStyle. Information)   Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Call  FillList() Else MsgBox(strDeleted) End  If Else MsgBox(â€Å"Please select record to delete. â€Å", MsgBoxStyle. Critical)   Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  Ã‚  End  If End  Sub The important line here is the strDeleted = ExecNonQuery(â€Å"DELETE Customers.CustomerID FROM Customers WHERE CustomerID= ‘†Ã‚  & CustomerID &  Ã¢â‚¬Å"‘†) which call the function  ExecNonQuery  and deletes a record based on the SQL Statement. Final Thoughts The above tutorial will simply teach you on how to connect to a database and make some changes to the database table. It is very important that you read first some tutorials about programming before you dive into the source code if you’re just starting out. If you really wanted to learn faster, then I recommend a book which is my reference also with this article. This book is called  Beginning VB 2008 Databases: From Novice to Professional (Beginning:

No comments:

Post a Comment

Note: Only a member of this blog may post a comment.