In this MySQLi Server Behaviors tutorial, you will learn to use the data management server behaviors to give users the ability to insert, update, and delete data in a database from a PHP page. From the individual insert, update, and delete interfaces, you will also learn how to choose a trigger, such as a form post, and specify how to manipulate records in your database.
You'll find a linked index to the tutorials in the MySQLi Server Behaviors series at the bottom of this page.
- Dreamweaver CS4 or higher; Dreamweaver CS6 or higher to use the Query Builder
- MySQLi Server Behaviors installed and activated.
- Site defined in Dreamweaver. For assistance, watch this tutorial: Setting up a site in Dreamweaver.
- MySQL database. If you do not have one, you can download our free eCommerce MySQL database in this tutorial.
- Saved PHP page with a form that allows users to insert information, for example an email address.
- Connection in Dreamweaver to your database. For assistance, view this tutorial: Create a PHP database connection.
MySQL code is now deprecated so you must transition to MySQLi for your websites to continue to work when the next version of PHP is released.
Before we begin with the steps in this tutorial, let's discuss why WebAssist created the MySQLi Server Behaviors interface. The original MySQL library that the original Dreamweaver server behaviors is based on is now deprecated in PHP as well as Dreamweaver. Because MySQL will be removed in the future, we have taken the functionality that used to exist within Dreamweaver for MySQL and recreated it in the MySQLi Server Behaviors extension as both a replacement and an improvement.
To begin, your first step is to create a MySQLi database connection.
- Open a php page in your Dreamweaver site.
- Go to the Databases panel, click the + icon, and choose Dynamic MySQLi Connection.
- Fill in your connection name and choose the default Charset, as indicated.
- Continue filling in the fields for your MySQL server, User name, and Password.
- Use the Select button to search for and select your database.
- Test your connection and click OK.
- Click OK to close the Dynamic MySQLi Connection window.
- Now you can see the MySQLi connection in the Databases panel.
Next, you'll create a MySQLi recordset on your PHP page so that a specific set of data can be retrieved from your database.
- Open a saved PHP page on your site.
- In the Server Behaviors panel, click the + icon and go to WebAssist > MySQLi > MySQLi Recordset.
- If the recordset dialog is in Advanced mode, click the Simple button.
- Enter a recordset name in the recordset Name field.
- Select your MySQLi database connection.
- Select the database table from which you wish to pull records. In this tutorial, the example shown is users.
- Click the All Columns radio button and sort the records by one of your database columns. In this tutorial, the example shown is UserEmail.
- Test and click OK to generate your MySQLi recordset.
In this tutorial, we are adding simple recordsets. However, an upcoming tutorial in the MySQLi Server Behaviors series will walk you through the steps of using the advanced MySQLi Server Behaviors visual query building tool. See the last section on this page for a link to the tutorial.
- Now you will see the recordset added in the Server Behaviors panel.
- In code view, you can view the recordset added to the PHP page.
- Save the page (Ctrl or Cmd + S).
You can allow users to insert new records into a table in your database from a saved PHP page with the MySQLi Insert Record interface. The interface has two tabs, General and Column Bindings.
- Open the PHP page where you will grant users the ability to insert records, for example, a form that allows users to insert an email address.
- In the Server Behaviors panel, click the + icon and choose WebAssist > MySQLi > Data Management > Insert Record to open the WebAssist MySQLi Insert Record interface.
- Click on the General tab where you will select your general settings.
General tab
- Trigger: Click the Trigger select list to choose when and where to insert your record.
By adding triggers, you can control when the insert, update, or delete server behaviors take place.
- Any form post: The server behavior is applied to a form on the current page to trigger the data insert.
- Before page load: The server behavior is applied to the current page to trigger the data insert when the page loads.
- Current page submit: The server behavior is triggered when a page is submitted.
- Button: When the submit button is clicked, the server behavior is triggered.
- Rules: Multiple conditional rules based on other WebAssist Server Behaviors.
- Dynamic data lightning bolt: Instead of using a trigger in the select list, create a custom trigger by clicking the lightning bolt to open the interface where server-side code can be specified.
- Connection: Choose your MySQLi connection.
- Insert table: Specify the database table into which the record should be inserted.
- (Optional) Save id in session as: You can specify a session variable that will contain the record ID of the newly inserted record.
Think of "Save id in session as" as temporary storage. For example, your user types their email address into the form. The session variable temporarily stores the record ID in the session.
- After inserting, go to: Use this field to redirect to a specific page after the record is inserted, for example, a Thank You page confirming the submission is complete.
If you do not want users redirected to another page, you should leave this field blank.
- Move to the Column Bindings tab where you will designate a value to be inserted in the table selected in the General tab.
Column Bindings tab
WebAssist's MySQLi Insert Record interface offers the option to 1) type in a value or 2) bind a value to a session variable, form element, or recordset. You will find this is an enhancement to the native Dreamweaver insert record server behaviors which limits you to getting values from a form.
- Value: Select the column you wish to bind a value to.
- Now you will designate the value you want inserted into a table. You can enter either a static value or a variable. Alternately, you can use the dynamic data lightning bolt button to select a value from Bindings.
- Submit as: Make a selection in the Submit as list to designate the data type you will be inserting.
You may find that the data type has been preset based on the column type, for example, Text.
- Text
- Integer
- Double
- Date
- Checkbox Y,N
- Checkbox 1,0
- Checkbox -1,0
- Blank value: Select the type of value used in the event that the value you have selected is blank.
WebAssist's MySQLi Insert Record Interface allows you to specify a blank value, a new feature which in the past required hand coding.
- Empty String
- Null
- Db Default
- Current Date
- 0
- N
- Click OK to apply the Insert Record Server Behavior to the current page.
- If you'd like to make changes in the future, you can edit the MySQLi Insert Record Server Behavior from the Server Behaviors panel.
You can allow users to update records in a table in your database from a saved PHP page with the MySQLi Update Record interface. The interface has two tabs, General and Column Bindings.
WebAssist's MySQLi Update Record interface has enhancements as well. There are 7 choices of settings in the General tab. The Column Bindings tab offers the ability to ignore blank values. For example, if there is an email field, users can fill it in with an update. But if they leave it blank, the current email address will remain.
- Open the PHP page where you will allow users to update records.
- In the Server Behaviors panel, click the + icon and choose WebAssist > MySQLi > Data Management > Update Record to open the WebAssist MySQLi Update Record interface.
- Click on the General tab where you will select your general settings.
General tab
- Trigger: Click the Trigger select list to choose when and where to update the record.
By adding triggers, you can control when the insert, update, or delete server behaviors take place.
- Any form post: The server behavior is applied to a form on the current page to trigger the updated data insert.
- Before page load: The server behavior is applied to the current page to trigger the updated data insert when the page loads.
- Current page submit: The server behavior is triggered when a page is submitted.
- Button: When the submit button is clicked, the server behavior is triggered.
- Rules: Multiple conditional rules based on other WebAssist Server Behaviors.
- Dynamic data lightning bolt: Instead of using a trigger in the select list, create a custom trigger by clicking the lightning bolt to open the interface where server-side code can be specified.
- Connection: Choose your MySQLi connection.
- Update table: Specify the database table where the record will be updated.
- Lookup column: Specify the column to be used to locate the record being updated.
- Column Type: Specify the data type of the lookup column. You can select any of the following:
You may find that the data type has been preset based on the column type.
- Integer
- Text
- Date
- Floating point number
- Lookup value: You may find that the value field has been preset. Or you can click the dynamic data button to choose a value that will be used to select the record to be deleted.
- After updating, go to: Use this field to redirect to a specific page after the record is updated, for example, a Thank You page confirming the update is complete. You can locate the pathway by clicking the folder icon.
If you do not want users redirected to another page, you should leave this field blank.
Column Bindings tab
- Value: Select the column you wish to bind a value to.
- Now you will designate the value you want updated in a table. You can enter either a static value or a variable. Alternately, you can use the dynamic data lightning bolt button to select a value from Bindings.
- Submit as: Make a selection in the Submit as list to designate the data type you will be updating.
You may find that the data type has been preset based on the column type, for example, Text.
- Text
- Integer
- Double
- Date
- Checkbox Y,N
- Checkbox 1,0
- Checkbox -1,0
- Blank value: Select the type of value used in the event that the value you have selected is blank:
WebAssist's MySQLi Update Record Interface allows you to specify a blank value, a new feature which in the past required hand coding.
- Empty String
- Ignore
- Null
- Db Default
- Current Date
- 0
- N
- Click OK to apply the Update Record Server Behavior to the current page.
- If you'd like to make changes in the future, you can edit the MySQLi Update Record Server Behavior from the Server Behaviors panel.
You can allow users to delete records in a table in your database from a saved PHP page with the MySQLi Delete Record interface.
- In the Server Behaviors panel, click the + icon and choose WebAssist > MySQLi > Data Management > Delete Record to open the WebAssist MySQLi Delete Record window.
- Trigger: Click the Trigger select list to choose where to delete your record:
- Any form post: The server behavior is applied to a form on the current page to trigger the data insert.
- Before page load: The server behavior is applied to the current page to trigger the data insert when the page loads.
- Current page submit: The server behavior is triggered when a page is submitted.
- Rules: Multiple conditional rules based on other WebAssist Server Behaviors.
- Dynamic data lightning bolt: Instead of using a trigger in the select list, create a custom trigger by clicking the lightning bolt to open the interface where server-side code can be specified.
- Connection: Choose your MySQLi connection.
- Table: Specify the database table where the record will be deleted, in this example, users.
- Lookup column: Specify the column to be used to locate the record being deleted, in this example, UserEmail.
- Column Type: Specify the data type of the lookup column. You can select any of the following:
You may find that the data type has been preset based on the column type.
- Integer
- Text
- Date
- Floating point number
- Lookup value: You may find that the value field has been preset based on the table and column type. Or you can click the dynamic data button to choose a value that will be used to select the record to be deleted.
- After deleting, go to: Use this field to redirect to a specific page after the record is deleted, for example, a Thank You page. Find the pathway by clicking the folder icon.
If you do not want users redirected to another page, you should leave this field blank.
- Click OK to apply the Delete Record Server Behavior to the current page.
- To make changes in the future, edit the MySQLi Delete Record Server Behavior from the Server Behaviors panel.
In the MySQLi Delete (and Update) Record interfaces, only one value can be looked up at a time. But with simple hand coding, we can look up a record based on more than one value by duplicating the "bindParam" record server behavior.
- In this example, we will bind two parameters by adding a new value beneath the existing UserEmail value.
- In code view, copy (Ctrl or Cmd + C) the "bindParam" record server behavior (line 7) and paste it (Ctrl or Cmd + P) directly beneath (line 8).
- Create a multiple parameter, UserID, by replacing the "s" with "i" and 'UserEmail' with 'UserID' in the second line of code.
$DeleteQuery->bindParam("s","".($_GET['UserEmail']) ."");
$DeleteQuery->bindParam("i","".($_GET['UserID']) ."");
- This allows us to bind multiple parameters, in this example, UserEmail and UserID.
Now that you know how to manipulate records in your database using MySQLi insert, update, and delete server behaviors, learn how to use the WebAssist's MySQLi user authentication interfaces at User authentication.
With WebAssist's MySQLi Server Behaviors, you can quickly create various server behaviors to generate streamlined MySQLi code in Dreamweaver. The following tutorials in the MySQLi Server Behaviors series for websites with custom database driven pages demonstrate how to insert, update, and delete records, add user authentication, record count, pagination links, and show if statements. Additionally, you will learn how to use WebAssist's Data Modeling interface and Query Builder tool.
- MySQLi Server Behaviors series: An overview of four in-depth tutorials to help you transition to MySQLi so that your websites will continue to work when the next version of PHP is released.
- Insert, update, and delete records: The data management interface allows users to insert, update, and delete data in a database from a PHP page. From the individual insert, update, and delete interfaces, users can choose a trigger, such as a form post, and specify how to manipulate records in a database.
- User authentication: The MySQLi user authentication interface allows code to be generated on a PHP page to log in users stored in the database. You can also log out users, check if a username exists with the Check New Username server behavior and restrict access to a specific page based on user credentials.
- Data Modeling and Query Builder tool: Watch the video demonstrating how to use the stand alone Data Modeling interface that allows users to set up joins which will be automatically applied whenever tables are added in the MySQLi recordsets. The Query Builder tool allows users to drag and drop database tables onto a grid and create relationships between database tables to create advanced SQL statements.
- Getting started with MySQLi Server Behaviors: Learn how to generate a simple results page by creating a recordset, adding a binding to a PHP page, and wrapping a repeat region around that binding. Then you'll be walked through adding a record count, pagination links, and show if statement. Once you understand the concepts, you can build on your knowledge to create custom database driven pages for your website.
henrik441511: 10 Years, 1 Month, 2 Weeks, 5 Days, 2 Hours, 42 Minutes ago
For those - like me - who did not figure out what is going on, on the Insert records into a database section;
simply use a <form> </form>
as:
<form action="Name-of-four-file.php" method="post">
<input name="username" type="text" class="" placeholder="type name..."> <br />
<input name="userpassword" type="text" class="" placeholder="Type a Password...">
<input name="submit" type="submit" value="Login" class="" style="margin-bottom:0px;" />
</form>
The form is visible in the Bindings panel. Here your can see your variables. (in this example is: username and userpassword)
Now you can continue from:
Now you will designate the value you want inserted into a table. You can enter either a static value or a variable. Alternately, you can use the dynamic data lightning bolt button to select a value from Bindings.
Team WebAssist: 10 Years, 1 Month, 2 Weeks, 4 Days, 7 Hours, 51 Minutes ago
henrik441511, Great point. We added a little bit to the getting started section to make it clear that you need not just a php page, but an actual form. Thank you!
: 10 Years, 1 Week, 4 Days, 5 Hours, 27 Minutes ago
Hello, thanks for the tut...what about updating a user's password with encryption..i cannot see anything like that here..thanks
Team WebAssist: 10 Years, 1 Week, 2 Days, 3 Hours, 7 Minutes ago
Please click Help in the main website menu to have technical support assist you with how you want to encrypt passwords.
: 9 Years, 8 Months, 4 Weeks, 11 Hours, 37 Minutes ago
must i buy your sqli converter to use thiss code
melanie-p: 9 Years, 7 Months, 3 Weeks, 3 Days, 8 Hours, 48 Minutes ago
If you're using WA Validation on the form, should you select the column values from the validated or unvalidated form?
: 8 Years, 7 Months, 4 Weeks, 1 Day, 19 Hours, 25 Minutes ago
Excuse the question, performing these steps I prevent cross site scripting? thank you very much
: 7 Years, 5 Months, 3 Weeks, 2 Days, 8 Hours, 36 Minutes ago
Thanks for the wonderful tutorial, it did help. Please can you take us round how to update, insert and delete multiple database records
FPhu61701534: 6 Years, 7 Months, 1 Week, 10 Hours, 22 Minutes ago
Does MySQLi conflict with DataAssist or do they complement each other? Do I need both installed or am I to choose either one? Does MySQLi come with features found in DataAssist, such as the ability to create forms for inserting and updating records?
: 5 Years, 7 Months, 3 Weeks, 5 Days, 15 Hours, 22 Minutes ago
thanks for great help.
, here i found some tutorial on Code for Insert View Update Delete In Php MySQL for more detail <a href="http://www.sensible-computers.com/blog/Code-for-Insert-View-Update-Delete-In-Php-MySQL/17">Click Here</a>