AccessPersonDao.cs
Description du code
AccessPersonDao.cs est un fichier du projet BiblioBrol.Ce fichier est situé dans /var/www/bin/sniplets/bibliobrol/src/.
Projet BiblioBrol :
Gestion de media en CSharp.
Pour plus d'infos, vous pouvez consulter la brève analyse.
Code source ou contenu du fichier
Code c# (AccessPersonDao.cs) (1401 lignes)
using System; using System.Collections; using System.Collections.Generic; using System.Text; using System.Data; using System.Data.OleDb; using System.Data.Common; using be.gaudry.bibliobrol.model; using be.gaudry.bibliobrol.model.dao; using be.gaudry.observer; using be.gaudry.bibliobrol.model.identity; using be.gaudry.bibliobrol.model.enums; using be.gaudry.model.exceptions; using be.gaudry.bibliobrol.config; namespace be.gaudry.bibliobrol.model.dao.msaccess { public sealed class AccessPersonDao : Observable, IPersonDao { private String conStr; private int bibliobrolItemId;//used to get the user role; private ActorRole userRole; #region singleton static AccessPersonDao instance = null; private DbProviderFactory dbpf; AccessPersonDao() { dbpf = ((AccessFactory)AccessFactory.Instance).getDbpf(); conStr = ((AccessFactory)AccessFactory.Instance).getConnectionString(); bibliobrolItemId = Config.BibliobrolId; } public static AccessPersonDao Instance { get { lock(padlock) { if(instance==null) { } return instance; } } } #endregion #region private methods /// <summary> /// Test if a person exists into the Access DataBase. /// Tests are done only on lastname and firstname fields /// </summary> /// <param name="person">(Person) person to test</param> /// <param name="dbDa">(DbDataAdapter) to avoid create a new connection</param> /// <param name="dbCon">(DbConnection) to avoid create a new connection</param> /// <returns>(int) id of the person found (-1 if not found)</returns> private int personExists(Person person, DbDataAdapter dbDa, DbConnection dbCon) { dbDa.SelectCommand = dbCon.CreateCommand(); /*StringBuilder str = new StringBuilder("SELECT id FROM person WHERE UCASE(lastName) = '"); Console.WriteLine("test sql 1 : " + str.ToString()); str.Append(AccessUtils.escapeAndTrim(person.LastName).ToUpper()); Console.WriteLine("test sql 2 : " + str.ToString()); str.Append("' AND UCASE(firstName)='"); Console.WriteLine("test sql 3 : " + str.ToString()); str.Append(AccessUtils.escapeAndTrim(person.FirstName).ToUpper()); Console.WriteLine("test sql 4 : " + str.ToString()); str.Append("'"); Console.WriteLine("test sql 5 : " + str.ToString()); dbDa.SelectCommand.CommandText = str.ToString();*/ string str = string.Format( "SELECT id FROM person WHERE UCASE(lastName) = '{0}' AND UCASE(firstName)='{1}'", AccessUtils.escapeAndTrim(person.LastName).ToUpper(), AccessUtils.escapeAndTrim(person.FirstName).ToUpper() ); dbDa.SelectCommand.CommandText = str; notify(new Notification(Notification.VERBOSE.persistentOperation, dbDa.SelectCommand.CommandText, this)); bool conOpen = dbCon.State.Equals(ConnectionState.Open); if (!conOpen) dbCon.Open(); int r = -1; try { object o = dbDa.SelectCommand.ExecuteScalar(); if (o != null) r = (int)o; } catch (OleDbException ode) { } dbCon.Close(); return r; } /// <summary> /// Test if a user exists into the Access DataBase. /// Tests are done on person id field /// </summary> /// <exception cref="System.Data.OleDb.OleDbException">OleDbException</exception> /// <remarks> /// Be carefull : a user with no id or default id (-1) will returns false... /// </remarks> /// <param name="person">(User) user to test</param> /// <param name="dbDa">(DbDataAdapter) to avoid create a new connection</param> /// <param name="dbCon">(DbConnection) to avoid create a new connection</param> /// <returns>true if user exists</returns> private bool userExists(User user, DbCommand com) { com.CommandText = string.Format("SELECT COUNT(personId) FROM [user] WHERE personId = {0}", user.Id); int r = (int)com.ExecuteScalar(); return r > 0; } /// <summary> /// Verify if some phones had been deleted, and delete it from the Access DataBase. /// Add new phones if exists. /// Update existing phones. /// </summary> /// <param name="person">(Person) person containing phones list</param> /// <param name="dbCon"></param> private void updatePersPhones(User user, DbConnection dbCon, DbDataAdapter dbDa) { dbDa.SelectCommand = dbCon.CreateCommand(); /*dbDa.InsertCommand = dbCon.CreateCommand(); dbDa.UpdateCommand = dbCon.CreateCommand(); dbDa.DeleteCommand = dbCon.CreateCommand();*/ DbCommand command = dbCon.CreateCommand(); dbDa.SelectCommand.CommandText = String.Format( "SELECT * FROM personPhone WHERE personId = {0}", user.Id ); notify(new Notification(Notification.VERBOSE.persistentOperation, dbDa.SelectCommand.CommandText, this)); dbDa.Fill(dt); try { foreach (DataRow phoneRow in dt.Rows) { phones.Add(getPhoneNbr(phoneRow)); } } catch (BuildObjectException boe) { notify(new Notification(Notification.VERBOSE.error, "Vérification des numéros de téléphone dans la DB", boe, this)); } foreach (Phone phone in phones) { if (!user.Phones.Contains(phone)) { deletePhone(phone, command); } } foreach (Phone phone in user.Phones) { if (phone.Id>0) { updatePhone(phone, command); } else { insertPhone(phone, user.Id, command); } } } private Person getPerson(DataRow row) { try { { p.FirstName = (String)row["firstName"]; } { p.Pseudo = (String)row["pseudo"]; } { p.Edited = !row["personLocked"].ToString().Equals("False"); } { SEX sex; try { } catch (Exception) { sex = SEX._; } p.Sex = sex; } { p.Birthdate = (DateTime)row["birthdate"]; } } catch (Exception e) { } return p; } private Phone getPhoneNbr(DataRow row) { { Phone.TYPE t; try { } catch (Exception) { t = Phone.TYPE._; } p.Type = t; } return p; } /// <summary> /// Used only to store phones from a new person /// </summary> /// <param name="p">Person</param> /// <param name="dbDa">DbDataAdapter</param> /// <returns>-1 if person is not a new person, or number of inserted otherwise</returns> private int insertPhones(User user, DbDataAdapter dbDa) { if (user.Id < 0) return -1; int i = 0; foreach (Phone phone in user.Phones) { insertPhone(phone, user.Id, dbDa.InsertCommand); } return i; } private bool insertPhone(Phone phone, int persId, DbCommand com) { com.CommandText = String.Format( "INSERT INTO personPhone (personId, phoneNum, phoneType) VALUES({0},'{1}','{2}');", persId, phone.Number, ); return (com.ExecuteNonQuery() == 1); } private bool deletePhone(Phone phone, DbCommand com) { com.CommandText = "DELETE FROM personPhone WHERE id = " + phone.Id; return (com.ExecuteNonQuery() == 1); } /// <summary> /// Update a phone. /// Don't update person id in the DB because moving a phone from a person to another is not implemented. /// </summary> /// <param name="phone">(Phone) phone to update</param> /// <param name="com">(DbCommand) command to use</param> /// <returns>true if updated</returns> private bool updatePhone(Phone phone, DbCommand com) { com.CommandText = String.Format( "UPDATE personPhone SET phoneNum='{0}',phoneType='{1}' WHERE id={2}", phone.Number, phone.Id ); return (com.ExecuteNonQuery() == 1); } /// <summary> /// Used to load persons with their ids. /// </summary> /// <param name="ids">Array of persons'ids (int values)</param> /// <returns>A list of persons</returns> private List<Person> loadSelectedPersons(int[] ids) { if (ids.Length < 1) return persons; DbConnection dbCon = dbpf.CreateConnection(); DbDataAdapter dbDa = dbpf.CreateDataAdapter(); dbDa.SelectCommand = dbCon.CreateCommand(); dbCon.ConnectionString = conStr; //build persons datatable StringBuilder str = new StringBuilder("SELECT id ,lastName, firstName, pseudo, birthdate, sex, personLocked FROM person"); if (ids[0]!=-1) {//load all persons if we have -1 value str.Append(" WHERE id IN ("); for (int i = 0; i < ids.Length; i++) { if (i > 0) str.Append(","); str.Append(ids[i]); } str.Append(")"); } dbDa.SelectCommand.CommandText = str.ToString(); notify(new Notification(Notification.VERBOSE.persistentOperation, dbDa.SelectCommand.CommandText, this)); try { dbDa.Fill(ds, "persons"); //build person objects foreach (DataRow persRow in ds.Tables["persons"].Rows) { try { persons.Add(getPerson(persRow)); } catch (BuildObjectException boe) { } } } catch (Exception fillPersEx) { return persons; } finally { dbCon.Close(); } return persons; } private bool lockUnlockPerson(int id, bool toLocked) { DbConnection dbCon = dbpf.CreateConnection(); DbDataAdapter dbDa = dbpf.CreateDataAdapter(); dbDa.UpdateCommand = dbCon.CreateCommand(); dbCon.ConnectionString = conStr; dbCon.Open(); str.Append((toLocked)?"TRUE":"FALSE"); str.Append(" WHERE id="); str.Append(id); dbDa.UpdateCommand.CommandText = str.ToString(); notify(new Notification(Notification.VERBOSE.persistentOperation, dbDa.UpdateCommand.CommandText, this)); int r = dbDa.UpdateCommand.ExecuteNonQuery(); dbCon.Close(); return (r == 1); } #endregion #region IPersonDao Members public String getConStr() { return conStr; } #region person /// <summary> /// Test if a person exists with the same name and firstname /// </summary> /// <param name="person">(Person) person to test</param> /// <returns>(int) id of the person found (-1 if not found)</returns> public int personExists(Person person) { DbConnection dbCon = dbpf.CreateConnection(); DbDataAdapter dbDa = dbpf.CreateDataAdapter(); dbDa.InsertCommand = dbCon.CreateCommand(); dbCon.ConnectionString = conStr; return personExists(person, dbDa, dbCon); } /// <summary> /// Lock person to avoid concurent modifications. /// </summary> /// <param name="id">person's id to lock</param> /// <returns>false if a problem occurs (todo : if already locked)</returns> public bool lockPerson(int id) { return lockUnlockPerson(id, true); } /// <summary> /// unlock person to allow modifications. /// </summary> /// <param name="id">person's id to unlock</param> public bool unlockPerson(int id) { return lockUnlockPerson(id, false); } /// <summary> /// Insert a person into the Access DataBase /// </summary> /// <param name="person">(Person) person to insert</param> /// <returns>(int) id of the new person (-1 if a problem occurs)</returns> public int insertPerson(Person person) { strDisp.Append(person.ToString()); int lastId = -1; if (person.Id <= 0) { DbConnection dbCon = dbpf.CreateConnection(); DbDataAdapter dbDa = dbpf.CreateDataAdapter(); dbDa.InsertCommand = dbCon.CreateCommand(); dbCon.ConnectionString = conStr; dbCon.Open(); lastId = insertPerson(person, dbCon, dbDa, strDisp); dbCon.Close(); } strDisp.Append((lastId > 0) ? " est ajoutée." : " ne peut être ajoutée."); return lastId; } public int insertBibliobrolUser(Person person) { } internal int insertPerson(Person person, DbConnection dbCon, DbDataAdapter dbDa, StringBuilder strDisp) { int lastId = -1; /*if (personExists(person, dbDa, dbCon)>0) { strDisp.Append(" existe déjà dans la base de données, "); return lastId; }*/ str.Append("INSERT INTO person (lastName, firstName, pseudo, sex, personLocked, birthdate) VALUES('"); str.Append(AccessUtils.escapeAndTrim(person.LastName)); str.Append("','"); str.Append(AccessUtils.escapeAndTrim(person.FirstName)); str.Append("','"); str.Append(AccessUtils.escapeAndTrim(person.Pseudo)); str.Append("','"); str.Append("', FALSE,"); { str.Append("NULL"); } else { str.Append(AccessUtils.getAccessDate(person.Birthdate)); } str.Append(");"); dbDa.InsertCommand.CommandText = str.ToString(); int r = 0; try { r = dbDa.InsertCommand.ExecuteNonQuery(); if (r > 1) //bad smell code : may not work with concurent acces dbDa.InsertCommand.CommandText = "SELECT @@IDENTITY"; lastId = (int)dbDa.InsertCommand.ExecuteScalar(); person.Id = lastId; } catch (OleDbException ode) { } return lastId; } /// <summary> /// Load a person from the Access DB with an id arg. /// If this person shoud be modified, editing bool arg is true /// to avoid concurent modifications (nobody else can save this person). /// </summary> /// <param name="id">Id of the selected person</param> /// <param name="editing">(bool) Shoud be modified or not</param> /// <returns>Selected person, or a new person if _ found</returns> public Person loadPerson(int id, bool editing) { Person p; if (persons.Count > 0) { p = persons[0]; if (editing && !p.Edited) lockPerson(id); } return p; } /// <summary> /// Load a person from the persistant layer with a lastname and a firstname. /// Search case insensitive. /// </summary> /// <param name="lastName">(string) lastname of the searched person</param> /// <param name="firstName">(string) firstname of the searched person</param> /// <returns>Persons found, or empty list</returns> public List<Person> loadPersons(string lastName, string firstName) { str.Append(lastName.ToUpper().Trim()); str.Append("%') AND UCASE(firstName) LIKE ('%"); str.Append(firstName.ToUpper().Trim()); str.Append("%')"); DbConnection dbCon = dbpf.CreateConnection(); DbDataAdapter dbDa = dbpf.CreateDataAdapter(); dbDa.SelectCommand = dbCon.CreateCommand(); dbCon.ConnectionString = conStr; dbDa.SelectCommand.CommandText = str.ToString(); notify(new Notification(Notification.VERBOSE.persistentOperation, dbDa.SelectCommand.CommandText, this)); try { dbDa.Fill(persDt); } catch (Exception e) { Notification.VERBOSE.error, String.Format("Chargement de la liste de personnes correspondant à {0} {1}", lastName, firstName), e, this )); } foreach (DataRow row in persDt.Rows) { ids.Add((int)row["id"]); } persDt.Dispose(); dbCon.Close(); return loadSelectedPersons(ids.ToArray()); } /// <summary> /// Load all persons matches (case insensitive) lastName /// </summary> /// <param name="lastName">(String) lastName to match</param> /// <returns>List of persons with the same lastName</returns> public List<Person> loadPersons(String lastName) { if (lastName == null || lastName.Equals(String.Empty)) return persons; DbConnection dbCon = dbpf.CreateConnection(); DbDataAdapter dbDa = dbpf.CreateDataAdapter(); //DataRelation dr; dbDa.SelectCommand = dbCon.CreateCommand(); dbCon.ConnectionString = conStr; //build persons datatable StringBuilder str = new StringBuilder("SELECT id ,lastName, firstName, pseudo, birthdate, sex, personLocked FROM person"); str.Append(" WHERE UCASE(lastName) = '"); str.Append(AccessUtils.escapeAndTrim(lastName.ToUpper())); str.Append("'"); dbDa.SelectCommand.CommandText = str.ToString(); notify(new Notification(Notification.VERBOSE.persistentOperation, dbDa.SelectCommand.CommandText, this)); try { dbDa.Fill(ds, "persons"); //build person objects foreach (DataRow persRow in ds.Tables["persons"].Rows) { try { persons.Add(getPerson(persRow)); } catch (BuildObjectException boe) { } } } catch (Exception fillPersEx) { return persons; } finally { dbCon.Close(); } return persons; } /// <summary> /// Load all persons from the Access DataBase /// </summary> /// <returns>List of Persons</returns> public List<Person> loadPersons() { } /// <summary> /// Load persons value objects (only display and id) /// </summary> /// <returns>List of PersonVos</returns> public List<PersonLO> loadVos() { } /// <summary> /// Load persons value objects with selected role (only display and id) /// If role id is less or equals than 0, all persons are loaded /// </summary> /// <param name="editing">(ActorRole) person's role</param> /// <returns>List of PersonVos</returns> public List<PersonLO> loadPersonsVos(ActorRole role) { StringBuilder str = new StringBuilder("SELECT DISTINCT (person.id) ,person.lastName, person.firstName, person.pseudo"); if (role.RoleId > 0) { str.Append(", actor.roleId FROM person"); str.Append(" LEFT JOIN actor ON actor.personId = person.id "); str.Append(" WHERE roleId = "); str.Append(role.RoleId); } else { str.Append(" FROM person"); } return loadPersonsVosByQuery(str.ToString()); } /// <summary> /// Load persons value objects with same lastname /// </summary> /// <param name="name">(string) person's lastname</param> /// <returns>List of PersonVos</returns> public List<PersonLO> loadPersonsVos(string name) { string str = string.Format( "SELECT id ,lastName, firstName, pseudo, birthdate, sex, personLocked FROM person WHERE UCASE(lastName) LIKE('{0}')", AccessUtils.escapeAndTrim(name.ToUpper()) ); return loadPersonsVosByQuery(str); } /// <summary> /// Load persons value objects with specific query /// </summary> /// <param name="query">(string) sql query</param> /// <returns>List of PersonVos</returns> private List<PersonLO> loadPersonsVosByQuery(string query) { DbConnection dbCon = dbpf.CreateConnection(); DbDataAdapter dbDa = dbpf.CreateDataAdapter(); dbDa.SelectCommand = dbCon.CreateCommand(); dbCon.ConnectionString = conStr; dbDa.SelectCommand.CommandText = query; notify(new Notification(Notification.VERBOSE.persistentOperation, dbDa.SelectCommand.CommandText, this)); try { dbDa.Fill(persDt); PERSON_DISPLAY persDisp = Config.PersonDisplay; switch (persDisp) { case PERSON_DISPLAY.firstname_lastname: addPersonsVos_firstname_lastname(persDt.Rows, persons); break; case PERSON_DISPLAY.lastname_firstname: addPersonsVos_lastname_firstname(persDt.Rows, persons); break; case PERSON_DISPLAY.lastname_firstname_pseudo: addPersonsVos_firstname_lastname_pseudo(persDt.Rows, persons); break; case PERSON_DISPLAY.pseudo: addPersonsVos_pseudo(persDt.Rows, persons); break; case PERSON_DISPLAY.pseudo_lastname_firstname: addPersonsVos_pseudo_lastname_firstname(persDt.Rows, persons); break; default: addPersonsVos_pseudo(persDt.Rows, persons); break; } //addPersonsVos(persDt.Rows, persons); } catch (Exception e) { notify(new Notification(Notification.VERBOSE.error, "Chargement de la liste de personnes selon la requête suivante :\n\r" + query, e, this)); } persDt.Dispose(); dbCon.Close(); return persons; } private void addPersonsVos_pseudo_lastname_firstname(DataRowCollection dataRowCollection, List<PersonLO> persons) { StringBuilder persDisplay; foreach (DataRow row in dataRowCollection) { { { persDisplay.Append((String)row["pseudo"]); } { persDisplay.Append(" ("); persDisplay.Append((String)row["lastName"]); } { persDisplay.Append(" "); persDisplay.Append((String)row["firstName"]); persDisplay.Append(")"); } if (persDisplay.Length > 0) { } } } } private void addPersonsVos_pseudo(DataRowCollection dataRowCollection, List<PersonLO> persons) { StringBuilder persDisplay; foreach (DataRow row in dataRowCollection) { { { persDisplay.Append((String)row["pseudo"]); } else { persDisplay.Append("Sans pseudo"); persDisplay.Append(" ("); { persDisplay.Append((String)row["lastName"]); } { persDisplay.Append(" "); persDisplay.Append((String)row["firstName"]); } persDisplay.Append(")"); } if (persDisplay.Length > 0) { } } } } private void addPersonsVos_firstname_lastname_pseudo(DataRowCollection dataRowCollection, List<PersonLO> persons) { StringBuilder persDisplay; foreach (DataRow row in dataRowCollection) { { { persDisplay.Append((String)row["firstName"]); } { persDisplay.Append(" "); persDisplay.Append((String)row["lastName"]); } { persDisplay.Append(" ("); persDisplay.Append((String)row["pseudo"]); persDisplay.Append(")"); } if (persDisplay.Length > 0) { } } } } private void addPersonsVos_lastname_firstname(DataRowCollection dataRowCollection, List<PersonLO> persons) { StringBuilder persDisplay; foreach (DataRow row in dataRowCollection) { { { persDisplay.Append((String)row["lastName"]); } { persDisplay.Append(" "); persDisplay.Append((String)row["firstName"]); } if (persDisplay.Length > 0) { } } } } private void addPersonsVos_firstname_lastname(DataRowCollection dataRowCollection, List<PersonLO> persons) { StringBuilder persDisplay; foreach (DataRow row in dataRowCollection) { { { persDisplay.Append((String)row["firstName"]); } { persDisplay.Append(" "); persDisplay.Append((String)row["lastName"]); } if (persDisplay.Length > 0) { } } } } private void addPersonsVos(DataRowCollection dataRowCollection, List<PersonLO> persons) { StringBuilder persDisplay; foreach (DataRow row in dataRowCollection) { { { { persDisplay.Append((String)row["pseudo"]); persDisplay.Append("\t"); } persDisplay.Append((String)row["lastName"]); } else { { persDisplay.Append((String)row["lastName"]); persDisplay.Append("\t"); persDisplay.Append((String)row["firstName"]); persDisplay.Append(" "); persDisplay.Append((String)row["pseudo"]); } else persDisplay.Append((String)row["lastName"] + "\t" + (String)row["firstName"]); } } } } /// <summary> /// Store new values for a person. /// Verify if some phones had been deleted, and delete it from the Access DataBase. /// Add new phones if exists. /// Update existing phones. /// </summary> /// <param name="person">Person with new values to store</param> /// <returns>true if update is done</returns> public bool updatePerson(Person person) { strDisp.Append(person.ToString()); if (person.Edited) { strDisp.Append("\" ne peut être mise à jour car elle est verrouillée."); return false; } DbConnection dbCon = dbpf.CreateConnection(); DbDataAdapter dbDa = dbpf.CreateDataAdapter(); dbDa.UpdateCommand = dbCon.CreateCommand(); dbCon.ConnectionString = conStr; dbCon.Open(); int result = updatePerson(person, dbCon, dbDa); dbCon.Close(); strDisp.Append((result == 1) ? "\" est mise à jour." : "\" ne peut être mise à jour."); return result == 1; } private int updatePerson(Person person, DbConnection dbCon, DbDataAdapter dbDa) { str.Append("UPDATE person SET lastName='"); str.Append(AccessUtils.escapeAndTrim(person.LastName)); str.Append("', firstName='"); str.Append(AccessUtils.escapeAndTrim(person.FirstName)); str.Append("', pseudo='"); str.Append(AccessUtils.escapeAndTrim(person.Pseudo)); str.Append("', sex='"); str.Append("', birthdate="); { str.Append("NULL"); } else { str.Append(AccessUtils.getAccessDate(person.Birthdate)); } str.Append(", personLocked=FALSE WHERE id="); str.Append(person.Id); dbDa.UpdateCommand.CommandText = str.ToString(); notify(new Notification(Notification.VERBOSE.persistentOperation, dbDa.UpdateCommand.CommandText, this)); int result = 0; try { result = dbDa.UpdateCommand.ExecuteNonQuery(); } catch (Exception dbe) { unlockPerson(person.Id); } return result; } /// <summary> /// Delete a person from the Access DataBase, /// and delete all associated tables !!! /// </summary> /// <param name="p">(Person) person to delete</param> /// <returns>true if deleted</returns> public bool deletePerson(Person p) { if (p.Id.Equals(Config.Owner.Id)) { notify(new Notification(Notification.VERBOSE.opsResult, "On ne peut supprimer le propriétaire de l'application...", this)); return false; } strDisp.Append(p.ToString()); DbConnection dbCon = dbpf.CreateConnection(); DbDataAdapter dbDa = dbpf.CreateDataAdapter(); dbDa.DeleteCommand = dbCon.CreateCommand(); dbCon.ConnectionString = conStr; dbCon.Open(); //delete mail String str = "DELETE FROM personMail WHERE personId=" + p.Id; dbDa.DeleteCommand.CommandText = str; dbDa.DeleteCommand.ExecuteNonQuery(); //delete phones str = "DELETE FROM personPhone WHERE personId=" + p.Id; dbDa.DeleteCommand.CommandText = str; dbDa.DeleteCommand.ExecuteNonQuery(); //delete actor str = "DELETE FROM actor WHERE personId=" + p.Id; dbDa.DeleteCommand.CommandText = str; dbDa.DeleteCommand.ExecuteNonQuery(); //delete user str = "DELETE FROM [user] WHERE personId=" + p.Id; dbDa.DeleteCommand.CommandText = str; dbDa.DeleteCommand.ExecuteNonQuery(); //delete person str = "DELETE FROM person WHERE id=" + p.Id; dbDa.DeleteCommand.CommandText = str; int result = dbDa.DeleteCommand.ExecuteNonQuery(); dbCon.Close(); strDisp.Append((result == 1) ? "\" est supprimée." : "\" ne peut être supprimée."); return result == 1; } #endregion #region user public User loadUser(int persId) { User user = null; DbConnection dbCon = dbpf.CreateConnection(); DbDataAdapter dbDa = dbpf.CreateDataAdapter(); DataRelation dr; dbDa.SelectCommand = dbCon.CreateCommand(); dbCon.ConnectionString = conStr; //build user datatable str.Append(" LEFT JOIN [user] AS u ON p.id = u.personId "); str.Append(" WHERE p.id = "); str.Append(persId); dbDa.SelectCommand.CommandText = str.ToString(); notify(new Notification(Notification.VERBOSE.persistentOperation, dbDa.SelectCommand.CommandText, this)); try { dbDa.Fill(ds, "persons"); //build phones datatable str = new StringBuilder("SELECT id , personId, phoneNum, phoneType FROM personPhone WHERE personId = "); str.Append(persId); dbDa.SelectCommand.CommandText = str.ToString(); notify(new Notification(Notification.VERBOSE.persistentOperation, dbDa.SelectCommand.CommandText, this)); dbDa.Fill(ds, "phones"); //build relation "pers-phones", ds.Tables["persons"].Columns["id"], ds.Tables["phones"].Columns["personId"] ); try { ds.Relations.Add(dr); } catch (Exception dre) { notify(new Notification(Notification.VERBOSE.error, "Liaison entre les personnes et les téléphones", dre, this)); } //build person objects foreach (DataRow row in ds.Tables["persons"].Rows) { try { //get person data try { { user.FirstName = (String)row["firstName"]; } { user.Pseudo = (String)row["pseudo"]; } { user.Edited = !row["personLocked"].ToString().Equals("False"); } { SEX sex; try { } catch (Exception) { sex = SEX._; } user.Sex = sex; } { user.Birthdate = (DateTime)row["birthdate"]; } } catch (Exception e) { } Address adress = user.Address; //get user data try { { user.FirstName2 = (String)row["firstName2"]; } { user.FirstName3 = (String)row["firstName3"]; } { user.BirthPlace = (String)row["birthplace"]; } { user.Nationality = (String)row["nationality"]; } { adress.Street = (String)row["street"]; } { adress.HouseNumber = (String)row["housenumber"]; } { adress.BoxNumber = (String)row["boxnumber"]; } { adress.ZipCode = (String)row["zipcode"]; } { adress.Municipality = (String)row["municipality"]; } { adress.Country = (String)row["country"]; } { user.NationalNumber = (String)row["nationalnumber"]; } } catch (Exception e2) { } foreach (DataRow phoneRow in row.GetChildRows(dr)) { user.addPhone(getPhoneNbr(phoneRow)); } } catch (BuildObjectException boe) { } } } catch (Exception fillPersEx) { notify(new Notification(Notification.VERBOSE.error, "Chargement de la personne", fillPersEx, this)); } finally { dbCon.Close(); } return user; } /// <summary> /// Updates a <code>be.gaudry.bibliobrol.model.User</code> if exists or creates it (and sets role). /// </summary> /// <param name="user"></param> /// <returns>Person Id</returns> public int saveUser(User user) { DbConnection dbCon = dbpf.CreateConnection(); DbDataAdapter dbDa = dbpf.CreateDataAdapter(); dbDa.InsertCommand = dbCon.CreateCommand(); dbDa.UpdateCommand = dbCon.CreateCommand(); dbCon.ConnectionString = conStr; dbCon.Open(); if (user.Id < 0) { user.Id = insertPerson(user, dbCon, dbDa, strDisp); } else { updatePerson(user, dbCon, dbDa); } bool testUserExists; try { testUserExists = userExists(user, dbDa.InsertCommand); } catch (OleDbException e) { dbCon.Close(); notify(new Notification(Notification.VERBOSE.error, "Impossible de tester l'utilisateur", e, this)); return -1; } if (testUserExists) { updateUser(user, dbCon, dbDa, strDisp); dbCon.Close(); notify(new Notification(Notification.VERBOSE.opsResult, "Mise à jour d'un utilisateur", strDisp.ToString(), this)); return user.Id; } else { if (insertPhones(user, dbDa) == -1) notify(new Notification(Notification.VERBOSE.error, "ERREUR d'insertion des N° de Tf pour " + user.ToString(), this)); str = new StringBuilder("INSERT INTO [user] (personId,firstName2,firstName3,birthplace,nationality"); str.Append(",street,housenumber,boxnumber,zipcode,municipality,country,nationalnumber)"); str.Append(" VALUES("); Address adress = user.Address; str.Append(user.Id); str.Append(", '"); str.Append(AccessUtils.escapeAndTrim(user.FirstName2)); str.Append("', '"); str.Append(AccessUtils.escapeAndTrim(user.FirstName3)); str.Append("', '"); str.Append(AccessUtils.escapeAndTrim(user.BirthPlace)); str.Append("', '"); str.Append(AccessUtils.escapeAndTrim(user.Nationality)); str.Append("', '"); str.Append(AccessUtils.escapeAndTrim(adress.Street)); str.Append("', '"); str.Append(AccessUtils.escapeAndTrim(adress.HouseNumber)); str.Append("', '"); str.Append(AccessUtils.escapeAndTrim(adress.BoxNumber)); str.Append("', '"); str.Append(AccessUtils.escapeAndTrim(adress.ZipCode)); str.Append("', '"); str.Append(AccessUtils.escapeAndTrim(adress.Municipality)); str.Append("', '"); str.Append(AccessUtils.escapeAndTrim(adress.Country)); str.Append("', '"); str.Append(AccessUtils.escapeAndTrim(user.NationalNumber)); str.Append("')"); dbDa.InsertCommand.CommandText = str.ToString(); notify(new Notification(Notification.VERBOSE.persistentOperation, dbDa.InsertCommand.CommandText, this)); try { dbDa.InsertCommand.ExecuteNonQuery(); } catch (OleDbException odbe) { notify(new Notification(Notification.VERBOSE.error, "Erreur dans la requête suivante :\n\r" + str.ToString(), odbe, this)); } //insert role String req = String.Format("INSERT INTO actor (itemId, personId, roleId) VALUES({0},{1},{2});", bibliobrolItemId, user.Id, userRole.RoleId); dbDa.InsertCommand.CommandText = req; try { dbDa.InsertCommand.ExecuteNonQuery(); } catch (OleDbException odbe2) { notify(new Notification(Notification.VERBOSE.error, "Erreur dans la requête suivante :\n\r" + str.ToString(), odbe2, this)); } } dbCon.Close(); notify(new Notification(Notification.VERBOSE.opsResult, string.Format("{0}\n\rL'utilisateur {1} {2} est ajouté dans bibliobrol.", strDisp.ToString(), user.FirstName, user.LastName), this)); return user.Id; } /// <summary> /// Update user data. Attention : don't care for update Person data /// </summary> /// <param name="user"></param> /// <param name="dbCon"></param> /// <param name="dbDa"></param> /// <param name="strDisp"></param> /// <returns>(bool) true if update is complete</returns> private bool updateUser(User user, DbConnection dbCon, DbDataAdapter dbDa, StringBuilder strDisp) { strDisp.Append("L'utilisateur \""); strDisp.Append(user.ToString()); if (user.Edited) { strDisp.Append("\" ne peut être mis à jour car il est verrouillé."); return false; } int result = 0; try { result = dbDa.UpdateCommand.ExecuteNonQuery(); if (result == 1) { //update user Address address = user.Address; str.Append("UPDATE [user] SET firstName2='"); str.Append(AccessUtils.escapeAndTrim(user.FirstName2)); str.Append("', firstName3='"); str.Append(AccessUtils.escapeAndTrim(user.FirstName3)); str.Append("', birthplace='"); str.Append(AccessUtils.escapeAndTrim(user.BirthPlace)); str.Append("', nationality='"); str.Append(AccessUtils.escapeAndTrim(user.Nationality)); str.Append("', street='"); str.Append(AccessUtils.escapeAndTrim(address.Street)); str.Append("', housenumber='"); str.Append(AccessUtils.escapeAndTrim(address.HouseNumber)); str.Append("', boxnumber='"); str.Append(AccessUtils.escapeAndTrim(address.BoxNumber)); str.Append("', zipcode='"); str.Append(AccessUtils.escapeAndTrim(address.ZipCode)); str.Append("', municipality='"); str.Append(AccessUtils.escapeAndTrim(address.Municipality)); str.Append("', country='"); str.Append(AccessUtils.escapeAndTrim(address.Country)); str.Append("', nationalnumber='"); str.Append(AccessUtils.escapeAndTrim(user.NationalNumber)); str.Append("' WHERE personId="); str.Append(user.Id); dbDa.UpdateCommand.CommandText = str.ToString(); notify(new Notification(Notification.VERBOSE.persistentOperation, dbDa.UpdateCommand.CommandText, this)); try { result = dbDa.UpdateCommand.ExecuteNonQuery(); updatePersPhones(user, dbCon, dbDa); } catch (Exception dbe) { } } } catch (Exception dbe) { } strDisp.Append((result == 1) ? "\" est mis à jour." : "\" ne peut être mis à jour."); return (result == 1); } public void deleteUser(User user, bool deletePerson) { if (user.Id.Equals(Config.Owner.Id)) { notify(new Notification(Notification.VERBOSE.opsResult, "On ne peut supprimer le propriétaire de l'application...", this)); return; } strDisp.Append(user.ToString()); DbConnection dbCon = dbpf.CreateConnection(); DbDataAdapter dbDa = dbpf.CreateDataAdapter(); dbDa.DeleteCommand = dbCon.CreateCommand(); dbCon.ConnectionString = conStr; dbCon.Open(); //delete user String str = "DELETE FROM [user] WHERE personId=" + user.Id; dbDa.DeleteCommand.CommandText = str; int result = dbDa.DeleteCommand.ExecuteNonQuery(); //delete phones str = "DELETE FROM personPhone WHERE personId=" + user.Id; dbDa.DeleteCommand.CommandText = str; dbDa.DeleteCommand.ExecuteNonQuery(); //delete mails str = "DELETE FROM personMail WHERE personId=" + user.Id; dbDa.DeleteCommand.CommandText = str; dbDa.DeleteCommand.ExecuteNonQuery(); if (deletePerson) { //delete person str = "DELETE FROM person WHERE id=" + user.Id; dbDa.DeleteCommand.CommandText = str; dbDa.DeleteCommand.ExecuteNonQuery(); } dbCon.Close(); strDisp.Append((result == 1) ? "\" est supprimé." : "\" ne peut être supprimé."); } #endregion public ActorRole getUserRole() { return userRole; } #endregion } }
Structure et Fichiers du projet
Afficher/masquer...Icône | Nom | Taille | Modification |
Icône | Nom | Taille | Modification |
| _ | Répertoire parent | 0 octets | 1736382126 09/01/2025 01:22:06 |
| _ | utils | 0 octets | 1541007203 31/10/2018 18:33:23 |
Utilisation de l'explorateur de code
- Navigation :
- Un clic sur une icône de répertoire ouvre ce répertoire pour en afficher les fichiers.
- Lorsque le répertoire en cours ne contient pas de sous-répertoires il est possible de remonter vers le répertoire parent.
- La structure de répertoires en treetable (tableau en forme d'arborescence) n'est plus possibledans cette version.
- Un clic sur une icône de fichier ouvre ce fichier pour en afficher le code avec la coloration syntaxique adaptée en fonction du langage principal utilisé dans le fichier.
- Affichage :
- Il est possible de trier les répertoires ou les fichiers selon certains critères (nom, taille, date).
- Actions :
- Les actions possible sur les fichiers dépendent de vos droits d'utilisateur sur le site. Veuillez activer le mode utilisateur pour activer les actions.
English translation
You have asked to visit this site in English. For now, only the interface is translated, but not all the content yet.If you want to help me in translations, your contribution is welcome. All you need to do is register on the site, and send me a message asking me to add you to the group of translators, which will give you the opportunity to translate the pages you want. A link at the bottom of each translated page indicates that you are the translator, and has a link to your profile.
Thank you in advance.
Document created the 16/10/2009, last modified the 26/10/2018
Source of the printed document:https://www.gaudry.be/en/cs-bibliobrol-source-rf-model/dao/msaccess//AccessPersonDao.cs.html
The infobrol is a personal site whose content is my sole responsibility. The text is available under CreativeCommons license (BY-NC-SA). More info on the terms of use and the author.