Připojení k databázi JSP
Připojení k databázi v JSP
Databáze slouží k ukládání různých typů dat, která jsou obrovská a mají úložnou kapacitu v gigabajtech. JSP se může připojit k takovým databázím a vytvářet a spravovat záznamy.
V tomto tutoriálu se naučíme, jak vytvořit tabulku v databázi a jak vytvořit záznamy v těchto tabulkách prostřednictvím JSP.
Vytvořit tabulku
In databáze MYSQL, můžeme vytvořit tabulku v databázi pomocí libovolného klienta MYSQL. Zde používáme PHPMyadminclient a tam máme možnost „nový“ pro vytvoření nové tabulky pomocí níže uvedeného snímku obrazovky.
V tomto musíme zadat název tabulky jako guru_test a vytvoříme dvě pole'emp_id a emp_name.
Emp_idis má datový typ jako int
Emp_name má datový typ jako varchar
Další možností je použití příkazového řádku a změn v adresáři MYSQL:
C:\> C:\>cd Program Files\MY SQL\bin C:\>Program Files\MySql\bin>
Do databáze se můžeme přihlásit následovně:
C:\Program Files\MYSQL\bin>mysql –u gururoot –p Enter Password: ******* Mysql>
Vytvořte tabulku guru_test v databázi s názvem GuruOtestujte následující v příkazovém řádku MYSQL:
Mysql> use GuruTest;
MySql> create table guru_test(
Emp_idint NOT NULL,
Emp_namevarchar(11),
);
Once you execute this you get the following:
Query OK, 0 rows affected(0.10 sec)
MySQl> select * from guru_test;
Query OK, 0 rows affected(0.10 sec)
Nejprve se záznamy vloží pomocí INSERT dotaz a pak můžeme použít SELECT dotaz pro kontrolu, zda je tabulka vytvořena nebo ne.
Vytvářejte záznamy
Po vytvoření tabulky musíme vytvořit záznamy do tabulky guru_test pomocí vkládacího dotazu, který je zobrazen níže:
Zde uvedené záznamy jsou:
- 1 a guru emp1
- 2 a guru emp2
MySql>INSERT INTO `couch_tomato_db`.`guru_test` (`emp_id`, `emp_name`) VALUES ('1', 'guru emp1');
Query OK, 1 row affected (0.05 sec)
MySQL>INSERT INTO `couch_tomato_db`.`guru_test` (`emp_id`, `emp_name`) VALUES ('2', 'guru emp2');
Query OK, 1 row affected (0.05 sec)
JSP Operafunkce: Vložit, Aktualizovat, Smazat, Vybrat
Pomocí JSP můžeme s databází provádět více operací. Můžeme vkládat záznamy a také můžeme mazat záznamy, které nepotřebujeme. Pokud je potřeba nějaký záznam upravit, můžeme to udělat pomocí aktualizace. Operace Select pomůže načíst požadované záznamy.
vybrat
Operace Select slouží k výběru záznamů z tabulky.
Příklad:
V tomto příkladu se seznámíme s operací výběru načítání záznamů z tabulky guru_test, která byla vytvořena ve výše uvedené části.
<%@ page import="java.io.*,java.util.*,java.sql.*"%>
<%@ page import="javax.servlet.http.*,javax.servlet.*" %>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/sql" prefix="sql"%>
<%@ page language="java" contentType="text/html; charset=ISO-8859-1"
pageEncoding="ISO-8859-1"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
<title>Guru Database JSP1</title>
</head>
<body>
<sql:setDataSource var="snapshot" driver="com.mysql.jdbc.Driver"
url="jdbc:mysql://localhost/GuruTest"
user="gururoot" password="guru"/>
<sql:query dataSource="${snapshot}" var="result">
SELECT * from guru_test;
</sql:query>
<table>
<tr>
<th>Guru ID</th>
<th>Name</th>
</tr>
<c:forEach var="row" items="${result.rows}">
<tr>
<td><c:out value="${row.emp_id}"/></td>
<td><c:out value="${row.emp_name}"/></td>
</tr>
</c:forEach>
</table>
</body>
</html>
Vysvětlení kódu:
Code Řádek 1: Zde importujeme io, uti a SQL java knihovny.
Code Řádek 3: Zde importujeme základní knihovnu JSTL a dáváme její předponu jako gurucore, což pomůže získat výstup.
Code Řádek 4: Zde importujeme SQL knihovnu jstl a dáváme její předponu jako gurusql, což pomůže provádět operace SQL.
Code Řádek 15–17: Zde pomocí gurusql připojujeme zdroj dat pojmenováním proměnné jako „guru“ a ovladače jako ovladače JDBC. Také přidání uživatelského jména a hesla s „gururoot“ a „guru“.
Code Řádek 19–21: Zde používáme SQL dotaz výběrového dotazu.
Code Řádek 31–32: Tiskneme výstup pro emp id a emp jméno, které jsou načteny z výsledků dotazu a pomocí smyčky foreach vytiskneme výstup.
Když spustíte výše uvedený kód, dostaneme výstup, jak je uvedeno níže;
Výstup:
Zde budou oba záznamy načteny z databáze
1 guru emp1
2 guru emp2
Vložit
Operátor Insert slouží k vložení záznamů do databáze.
Příklad:
V tomto příkladu se naučíme vkládat záznamy do tabulky guru_test
<%@ page import="java.io.*,java.util.*,java.sql.*"%>
<%@ page import="javax.servlet.http.*,javax.servlet.*" %>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="gurucore"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/sql" prefix="gurusql"%>
<%@ page language="java" contentType="text/html; charset=ISO-8859-1"
pageEncoding="ISO-8859-1"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
<title>Guru Database JSP1</title>
</head>
<body>
<gurusql:setDataSource var="guru" driver="com.mysql.jdbc.Driver"
url="jdbc:mysql://localhost/GuruTest"
user="gururoot" password="guru"/>
<gurusql:update dataSource="${guru}" var="guruvar">
INSERT INTO guru_test VALUES (3, 'emp emp3');
</gurusql:update>
</body>
</html>
Vysvětlení kódu:
Code Řádek 19–20: Zde vkládáme záznamy do tabulky guru_test of GuruTestdatabáze. Vložené záznamy jsou: empID – 3 a empname – emp emp3. Tyto záznamy budou vloženy do tabulky. Po spuštění kódu se záznamy vloží do tabulky jako guru_test s hodnotou 3 a emp emp3.
Poznámka: Zde neukazujeme výstup, pouze vkládáme záznam do tabulky. Záznam můžeme získat pomocí výběrového dotazu jako 'select * from guru_test'. Pokud by byl záznam vložen tehdy, dostali bychom hodnotu 3 a emp3. Pokud záznam nevložíte, 3 se v záznamech v tabulce nezobrazí.
Vymazat
Toto je operace mazání, kdy mažeme záznamy z tabulky guru_test.
Příklad:
Zde smažeme dotaz pro smazání záznamu z tabulky guru_test. Záznam, který má být smazán, musí být nastaven v proměnné „guruid“ a příslušný záznam je smazán z databáze.
<%@ page import="java.io.*,java.util.*,java.sql.*"%>
<%@ page import="javax.servlet.http.*,javax.servlet.*" %>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="gurucore"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/sql" prefix="gurusql"%>
<%@ page language="java" contentType="text/html; charset=ISO-8859-1"
pageEncoding="ISO-8859-1"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
<title>Guru Database JSP1</title>
</head>
<body>
<gurusql:setDataSource var="guru" driver="com.mysql.jdbc.Driver"
url="jdbc:mysql://localhost/GuruTest"
user="gururoot" password="guru"/>
<gurucore:set var="guruid" value="3"/>
<gurusql:update dataSource="${guru}" var="guruvar">
DELETE FROM guru_test WHERE emp_id = ?
<gurusql:param value="${guruid}" />
</gurusql:update>
</body>
</html>
Vysvětlení kódu:
Code Řádek 18: Nastavujeme proměnnou guruid, jejíž hodnota je 3, která musí být smazána z databáze. Toto je vždy primární klíč tabulky. V tomto případě je primárním klíčem emp_id.
Code Řádek 19–22: Zde používáme odstraňovací dotaz, který nastavuje parametr v klauzuli where. Zde je parametrem guruid, který se nastavuje na řádku kódu 18. Odpovídající záznam je smazán.
Výstup:
Když spustíte výše uvedený kód, záznam s emp_id jako 3 se odstraní.
Poznámka: V tomto příkladu nemůžeme zobrazit výstup, protože odstraňujeme záznam z tabulky. Chcete-li zkontrolovat, zda je tento záznam smazán, musíme použít výběrový dotaz „select * from guru_test“. V takovém případě, pokud dostaneme 3 jako emp id, pak dotaz na odstranění selhal, jinak byl záznam úspěšně odstraněn.
Aktualizace
Aktualizace slouží k úpravě záznamů v tabulce.
Příklad:
<%@ page import="java.io.*,java.util.*,java.sql.*"%>
<%@ page import="javax.servlet.http.*,javax.servlet.*" %>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="gurucore"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/sql" prefix="gurusql"%>
<%@ page language="java" contentType="text/html; charset=ISO-8859-1"
pageEncoding="ISO-8859-1"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
<title>Guru Database JSP1</title>
</head>
<body>
<gurusql:setDataSource var="guru" driver="com.mysql.jdbc.Driver"
url="jdbc:mysql://localhost/GuruTest"
user="gururoot" password="guru"/>
<gurucore:set var="guruid" value="2"/>
<gurusql:update dataSource="${guru}" var="guruvar">
UPDATE guru_test SET emp_name='emp guru99'
<gurusql:param value="${guruid}" />
</gurusql:update>
</body>
</html>
Vysvětlení kódu:
Code Řádek 18: Zde nastavujeme proměnnou guruid na 2. Toto je ID, kde chceme aktualizovat záznam.
Code Řádek 19–22: Zde používáme aktualizační dotaz k aktualizaci záznamu v tabulce guru_test záznamu, který je nastaven v bodě 18. Zde je emp guru2 nahrazeno emp guru99
Výstup:
Když spustíte výše uvedený kód, záznam withemp_id 2 se změní na 99. Nyní tedy výstup zobrazí emp”guru99″ místo emp “guru2”.
Shrnutí
V tomto tutoriálu jsme se dozvěděli o připojení JSP k databázi a přístupu k databázi. Také jsme se dozvěděli o různých operacích prováděných na tabulce v databázi, jako je vytvoření, odstranění, aktualizace atd.


