blob: 24a7fb5391a71f5687728292d1b80d378cdbfd4b [file] [log] [blame]
//
// Licensed to the Apache Software Foundation (ASF) under one
// or more contributor license agreements. See the NOTICE file
// distributed with this work for additional information
// regarding copyright ownership. The ASF licenses this file
// to you under the Apache License, Version 2.0 (the
// "License"); you may not use this file except in compliance
// with the License. You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing,
// software distributed under the License is distributed on an
// "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
// KIND, either express or implied. See the License for the
// specific language governing permissions and limitations
// under the License.
//
= Connecting to a MySQL Database
:jbake-type: tutorial
:jbake-tags: tutorials
:jbake-status: published
:syntax: true
:icons: font
:source-highlighter: pygments
:toc: left
:toc-title:
:description: Connecting to a MySQL Database - Apache NetBeans
:keywords: Apache NetBeans, Tutorials, Connecting to a MySQL Database
This document demonstrates how to set up a connection to a MySQL database from the NetBeans IDE. Once connected, you can begin working with MySQL in the IDE's Database Explorer by creating new databases and tables, populating tables with data, and running SQL queries on database structures and content. This tutorial is designed for beginners with a basic understanding of database management, who want to apply their knowledge to working with MySQL in NetBeans IDE.
link:http://www.mysql.com/[+MySQL+] is a popular Open Source relational database management system (RDBMS) commonly used in web applications due to its speed, flexibility and reliability. MySQL employs SQL, or _Structured Query Language_, for accessing and processing data contained in databases.
NOTE: This tutorial assumes that you already have the MySQL RDBMS installed and configured on your computer. If you are installing for the first time, please refer to the official link:http://dev.mysql.com/doc/refman/5.0/en/installing-cs.html[+MySQL documentation+] for help. You can also refer to link:install-and-configure-mysql-server.html[+Setting Up the MySQL Database Server in the Windows Operating System+].
== Configuring MySQL Server Properties
NetBeans IDE comes bundled with support for the MySQL RDBMS. Before you can access the MySQL Database Server in NetBeans IDE, you must configure the MySQL Server properties.
1. Right-click the Databases node in the Services window and choose Register MySQL Server to open the MySQL Server Properties dialog box.
image::images/mysql-props1.png[]
[start=2]
. Confirm that the server host name and port are correct.
Notice that the IDE enters `localhost` as the default server host name and `3306` as the default server port number.
[start=3]
. Enter the Administrator user name (if not displayed).
NOTE: You need administrative access to be able to create and remove databases.
[start=4]
. Enter the Administrator password. The default is set to blank.
NOTE: A blank password can also be a password.
[start=5]
. Click the Admin Properties tab at the top of the dialog box.
The Admin Properties tab is then displayed, allowing you to enter information for controlling the MySQL Server.
[start=6]
. In the Path/URL to admin tool field, type or browse to the location of your MySQL Administration application such as the MySQL Admin Tool, PhpMyAdmin, or other web-based administration tools.
NOTE: `mysqladmin` is the MySQL admin tool found in the `bin` folder of the MySQL installation directory. It is a command-line tool and not ideal for use with the IDE.
Type any arguments for the admin tool in the Arguments field.
[start=7]
. In the Path to start command, type or browse to the location of the MySQL start command. To find the start command, look for `mysqld` in the `bin` folder of the MySQL installation directory.
NOTE: The recommended binary for Unix and NetWare is `mysql_safe`. The start command may also vary if MySQL was installed as part of an AMP installation.
Type any arguments for the start command in the Arguments field.
[start=8]
. In the Path to stop command field, type or browse to the location of the MySQL stop command. This is usually the path to `mysqladmin` in the `bin` folder of the MySQL installation directory. If the command is `mysqladmin`, in the Arguments field, type `-u root stop` to grant `root` permissions for stopping the server.
[start=9]
. When finished, the Admin Properties tab should resemble the following figure. If you are satified with your configuration, click OK.
image::images/mysql-props2.png[]
== Starting the MySQL Server
Before you can connect to a MySQL Database Server, you must first ensure that the MySQL Database Server is running on your machine. If the database server is not connected you will see *(disconnected)* next to the user name in the MySQL Server node in the Service window and you will not be able to expand the node.
To connect to the database server, confirm that the MySQL Database Server is running on your machine, right-click the Databases > MySQL Server node in the Services window and choose Connect. You might be prompted to supply a password to connect to the server.
image::images/services-running.png[]
When the server is connected you will be able to expand the MySQL Server node and view the all available MySQL databases.
== Creating and Connecting to the Database Instance
A common way of interacting with databases is through an SQL editor. NetBeans IDE has a built-in SQL Editor for this purpose. The SQL Editor is generally accessible via the Execute Command option from the right-click menu of the connection node (or of the connection node's child nodes). Now that you are connected to the MySQL server, you can create a new database instance using the SQL Editor. For purposes of this tutorial, create an instance called ``MyNewDatabase`` :
1. In the IDE's Services window, right-click the MySQL Server node and choose Create Database.
The Create MySQL Database dialog box opens.
[start=2]
. In the Create MySQL Database dialog box, type the name of the new database. We will use `MyNewDatabase` for this tutorial. Leave the checkbox unselected at this time.
image::images/create-db-dbx.png[]
NOTE: You can also grant full access to a given user. By default, only the admin user has the permissions to perform certain commands. The drop down list lets you assign these permissions to a specified user.
[start=3]
. Click OK.
The new database appears under the MySQL Server node in the Services window.
[start=4]
. Right-click the new database node and choose Connect in the popup menu to open the connection to the database.
Database connections that are open are represented by a complete connection node (image::images/connection-node-icon.png[]) in the Services window.
== Creating Database Tables
Now that you have connected to ``MyNewDatabase`` , you can begin exploring how to create tables, populate them with data, and modify data maintained in tables. This allows you to take a closer look at the functionality offered by the Database Explorer, as well as NetBeans IDE's support for SQL files.
``MyNewDatabase`` is currently empty. In the IDE it is possible to add a database table by either using the Create Table dialog, or by inputting an SQL query and running it directly from the SQL Editor. In the following exercises you will use the SQL editor to create the `Counselor` table and the Create Table dialog box to create the `Subject` table. After you create the tables you will run an SQL script to populate the tables.
1. <<usingSQLEditor,Using the SQL Editor>>
2. <<usingCreateTable,Using the Create Table Dialog>>
[[usingSQLEditor]]
=== Using the SQL Editor
In this exercise you will use the SQL editor to create the `Counselor` table.
1. In the Database Explorer, expand the ``MyNewDatabase`` connection node (image::images/connection-node-icon.png[]) and note that there are three subfolders: Tables, Views and Procedures.
2. Right-click the Tables folder and choose Execute Command. A blank canvas opens in the SQL Editor in the main window.
3. In the SQL Editor, type in the following query. This is a table definition for the ``Counselor`` table you are about to create.
[source,sql]
----
CREATE TABLE Counselor (
id SMALLINT UNSIGNED NOT NULL AUTO_INCREMENT,
firstName VARCHAR (50),
nickName VARCHAR (50),
lastName VARCHAR (50),
telephone VARCHAR (25),
email VARCHAR (50),
memberSince DATE DEFAULT '0000-00-00',
PRIMARY KEY (id)
);
----
NOTE: Queries formed in the SQL Editor are parsed in Structured Query Language (SQL). SQL adheres to strict syntax rules which you should be familiar with when working in the IDE's Editor. Upon running a query, feedback from the SQL engine is generated in the Output window indicating whether execution was successful or not.
[start=4]
. To execute the query, either click the Run SQL (image::images/run-sql-button.png[]) button in the task bar at the top (Ctrl-Shift-E), or right-click within the SQL Editor and choose Run Statement. The IDE generates the ``Counselor`` table in the database, and you receive a message similar to the following in the Output window.
image::images/create-counselor-query.png[]
[start=5]
. To verify changes, right-click the Tables node in the Database Explorer and choose Refresh. The Refresh option updates the Database Explorer's UI component to the current status of the specified database. Note that the new ``Counselor`` table node (image:images/table-node.png[]) now displays under Tables in the Database explorer. If you expand the table node you can see the columns (fields) you created, starting with the primary key (image:images/primary-key-icon.png[]).
image::images/counselor-table.png[]
[[usingCreateTable]]
=== Using the Create Table Dialog
In this exercise you will use the Create Table dialog box to create the `Subject` table.
1. In the Database Explorer, right-click the Tables node and choose Create Table. The Create Table dialog opens.
2. In the Table name text field, type ``Subject`` .
3. Click Add Column.
4. For the Name of the column, enter ``id`` . Choose ``SMALLINT`` for data type from the Type drop-down list. Click OK.
image::images/add-column-dialog.png[]
[start=5]
. Select the Primary Key check box in the Add Column dialog box. You are specifying the primary key for your table. All tables found in relational databases must contain a primary key. Note that when you select the Key check box, the Index and Unique check boxes are also automatically selected and the Null check box is deselected. This is because primary keys are used to identify a unique row in the database, and by default form the table index. Because all rows need to be identified, primary keys cannot contain a Null value.
. Repeat this procedure by adding the remaining columns, as shown in the following table.
|===
|Key |Index |Null |Unique |Column Name |Data Type |Size
|[checked] |[checked] |[checked] |id |SMALLINT |0
|[checked] |name |VARCHAR |50
|[checked] |description |VARCHAR |500
|[checked] |FK_counselorID |SMALLINT |0
|===
You are creating a table named ``Subject`` that will hold data for each of the following records.
* *Name: *name of the subject
* *Description: *description of the subject
* *Counselor ID: *counselor ID that corresponds to an ID from the Counselor table
image::images/create-table-subject.png[]
Make sure that the fields in your Create Table dialog match those shown above, then click OK. The IDE generates the ``Subject`` table in the database, and you can see a new ``Subject`` table node (image:images/table-node.png[]) immediately display under Tables in the Database Explorer.
== Working with Table Data
In order to work with table data, you can make use of the SQL Editor in NetBeans IDE. By running SQL queries on a database, you can add, modify and delete data maintained in database structures. To add a new record (row) to the ``Counselor`` table, do the following:
1. Choose Execute Command from the Tables folder in the Database Explorer. A blank canvas opens in the SQL Editor in the main window.
2. In the SQL Editor, type in the following query.
[source,sql]
----
INSERT INTO Counselor
VALUES (1, 'Ricky', '"The Dragon"', 'Steamboat','334 612-5678', 'r_steamboat@ifpwafcad.com', '1996-01-01')
----
[start=3]
. To execute the query, right-click within the SQL Editor and choose Run Statement. In the Output window, you can see a message indicating that the query was successfully executed.
. To verify that the new record has been added to the ``Counselor`` table, in the Database Explorer, right-click the ``Counselor`` table node and choose View Data. A new SQL Editor pane opens in the main window. When you choose View Data, a query to select all the data from the table is automatically generated in the upper region of the SQL Editor. The results of the statement are displayed in a table view in the lower region. In this example, the ``Counselor`` table displays. Note that a new row has been added with the data you just supplied from the SQL query.
image::images/sql-results.png[]
== Running an SQL Script
Another way to manage table data in NetBeans IDE is by running an external SQL script directly in the IDE. If you have created an SQL script elsewhere, you can simply open it in NetBeans IDE and run it in the SQL Editor.
For demonstrative purposes, download link:https://netbeans.org/project_downloads/samples/Samples/Java%20Web/ifpwafcad.sql[+ifpwafcad.sql+] and save it to a location on your computer. This script creates two tables similar to what you just created above ( ``Counselor`` and ``Subject`` ), and immediately populates them with data.
Because the script overwrites these tables if they already exist, delete the ``Counselor`` and ``Subject`` tables now so it becomes obvious that new tables are being created when the script is run. To delete tables:
1. Right-click the ``Counselor`` and ``Subject`` table nodes in the Database Explorer and choose Delete.
2. Click Yes in the Confirm Object Deletion dialog box. Note that the dialog box lists the tables that will be deleted.
When you click Yes in the Confirm Object Deletion dialog box, the table nodes are automatically removed from the Database Explorer.
To run the SQL script on ``MyNewDatabase`` :
1. Choose File > Open File from the IDE's main menu. In the file browser navigate to the location where you previously saved ``ifpwafcad.sql`` and click Open. The script automatically opens in the SQL Editor.
2. Make sure your connection to ``MyNewDatabase`` is selected from the Connection drop-down box in the toolbar at the top of the Editor.
image::images/connection-drop-down.png[]
[start=3]
. Click the Run SQL (image::images/run-sql-button.png[]) button in the SQL Editor's task bar. The script is executed against the selected database, and any feedback is generated in the Output window.
. To verify changes, right-click the ``MyNewDatabase`` connection node in the Runtime window and choose Refresh. The Refresh option updates the Database Explorer's UI component to the current status of the specified database. Note that the two new tables from the SQL script now display as a table nodes under ``MyNewDatabase`` in the Database Explorer.
. Choose View Data from the right-click menu of a selected table node to see the data contained in the new tables. In this manner, you can compare the tabular data with the data contained in the SQL script to see that they match.
== Conclusion
This concludes the Connecting to a MySQL Database tutorial. This document demonstrated how to configure MySQL on your computer and set up a connection to the database server from NetBeans IDE. It also described how to work with MySQL in the IDE's Database Explorer by creating new database instances and tables, populating tables with data, and running SQL queries.