my mysqlデータベースに含まれる医師のリスト(medecin in french)を、hibernateフレームワークとstruts2を介して表示するjspページを作成しました。Struts2とHibernateを使用してデータを削除および変更する方法
私は医者を削除するための削除ボタンsupprimer
(フランス語)と、医師のデータを編集するためのボタンmodifier
を持っています。
編集ボタンmodifier
は、選択された医師のすべてのデータ(id、nom、prenomなど)を受け取り、フォームに入れて更新することができます。
ListedesMedecins.jsp
<%@page contentType="text/html" pageEncoding="UTF-8"%>
<%@ taglib prefix="s" uri="/struts-tags"%>
<%@ taglib prefix="sb" uri="/struts-bootstrap-tags"%>
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Listes des Medecins</title>
</head>
<body>
<jsp:include page="accueil.jsp"/>
<h1>Listes des Medecins</h1>
<s:if test="Medecin.size() > 0">
<table border="1px" cellpadding="8px">
<tr>
<th>id</th>
<th>Nom</th>
<th>Prenom</th>
<th>contact</th>
<th>specialite</th>
</tr>
<s:iterator value="Medecin">
<tr>
<td><s:property value="idmed" /></td>
<td><s:property value="nom" /></td>
<td><s:property value="prenom" /></td>
<td><s:property value="contact" /></td>
<td><s:property value="specialite"/></td>
<td><a href="<s:url action="Modmed" namespace="/Modmed"/>"> Modifier </a> </td>
<td><a href="<s:url action="Supmed" namespace="/Supmed"/>"> Supprimer </a> </td>
</tr>
</s:iterator>
</s:if>
</table>
</body>
</html>
必要なメソッド(、更新、削除を選択し、リスト)
public Medecin getMedecin(Integer idMedecin) {
log.info("********** Debut getMedecin MedecinDAO **********");
Medecin Medecin = null;
Session session = SessionFactoryUtil.getInstance().openSession();
try {
Medecin = (Medecin) session.get(Medecin.class, idMedecin);
return Medecin;
} catch (Exception e) {
e.printStackTrace();
log.fatal(e.getMessage());
return null;
} finally {
session.close();
log.info("********** Fin getMedecin MedecinDAO **********");
}
}
public boolean saveMedecin(Medecin Medecin) {
log.info("********** Debut saveMedecin MedecinDAO **********");
Session session = SessionFactoryUtil.getInstance().openSession();
Transaction trans = session.beginTransaction();
try {
session.save(Medecin);
trans.commit();
return true;
} catch (Exception e) {
e.printStackTrace();
log.fatal(e.getMessage());
trans.rollback();
return false;
} finally {
session.close();
log.info("********** Fin saveMedecin MedecinDAO **********");
}
}
public boolean updateMedecin(Medecin Medecin) {
log.info("********** Debut updateMedecin MedecinDAO **********");
Session session = SessionFactoryUtil.getInstance().openSession();
Transaction trans = session.beginTransaction();
try {
session.update(Medecin);
trans.commit();
return true;
} catch (Exception e) {
e.printStackTrace();
log.fatal(e.getMessage());
return false;
} finally {
session.close();
log.info("********** Fin updateMedecin MedecinDAO **********");
}
}
public boolean deleteMedecin(Medecin Medecin) {
log.info("********** Debut deleteMedecin MedecinDAO **********");
Session session = SessionFactoryUtil.getInstance().openSession();
try {
Transaction trans = session.beginTransaction();
session.delete(Medecin);
trans.commit();
return true;
} catch (Exception e) {
e.printStackTrace();
log.fatal(e.getMessage());
return false;
} finally {
session.close();
log.info("********** Fin deleteMedecin MedecinDAO **********");
}
}
public List<Medecin> allmedecin(){
List<Medecin> medecin = null;
Session session = SessionFactoryUtil.getInstance().openSession();
String registr = "from Medecin";
Query query = session.createQuery(registr);
medecin=query.list();
return medecin;
}
そして最後に、私のアクションクラスで私のクラスMedecinDAO、formMedAction.java
//getters,setters...
//this method is for adding Medecin/doctors
public String Ajoutmed() {
MedecinDAO medDAO= MedecinDAO.getInstance();
Medecin M = new Medecin();
M.setIdmed(idmed);
M.setNom(nom);
M.setPrenom(prenom);
M.setContact(contact);
M.setSpecialite(specialite);
medDAO.saveMedecin(M);
return SUCCESS;
}
// return list of all medecin in the table
public String Listmed() throws Exception {
MedecinDAO medDAO = MedecinDAO.getInstance();
Medecin = medDAO.allmedecin();
return SUCCESS;
}
// Method I created to delete the data, but I'm not sure if it correct
public String Supmed() {
MedecinDAO medDAO = MedecinDAO.getInstance();
Medecin M = new Medecin();
M.getIdmed();
M.getNom();
M.getPrenom();
M.getContact();
M.getSpecialite();
medDAO.deleteMedecin(M);
return SUCCESS;
}
public string Modmed() {
//dont know what to do for the modifier/edit action , need your help
return SUCCESS;
}
ありがとうございました
EDIT!
はMedecinDAOにこのコードで医者を削除する方法を見つける:
public Medecin deleteMedecin(Integer idmed) {
log.info("********** Debut deleteMedecin MedecinDAO **********");
Session session = SessionFactoryUtil.getInstance().openSession();
Transaction trans = session.beginTransaction();
Medecin m = (Medecin) session.load(Medecin.class, idmed);
session.delete(m);
trans.commit();
return m;
}
そして、アクションクラス
public String Supmed() {
MedecinDAO medDAO = MedecinDAO.getInstance();
Medecin m = new Medecin();
m = medDAO.deleteMedecin(getIdmed());
return SUCCESS;
}
とJSPボタンアクション
<td><a href="<s:url action="Supmed" namespace="/pages"><s:param name="idmed" value="%{idmed}"></s:param></s:url>"> Supprimer </a> </td>
中でこれを追加します
今、私は編集方法を知る必要があります
thxしかし、新しいJSPページ、フォーム、idmed、nomなどの値を設定するには、選択したMedecinオブジェクトの値をどのように設定するのですか? –
私の投稿を編集しました@ KaneSamba – fiskra
Ok thxですが、まだ問題に直面しています。私は編集アクションでエラーを起こしたと思います。 public String edit() { 文字列param = ServletActionContext.getRequest()。getParameter( "idmed"); 返信SUCCESS; }これは私がやったことですが、私は空白のページを持っています、私はタイトルしか持っていません、フォームは表示されていません。私は別のJSPページを作成し、編集アクションをとparamに設定し、あなたが行ったようにフォームに記入します。しかし、残っている唯一のことは、Actionクラスのメソッドを編集することだと思います。 –