123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431 |
- <?php
- /*
- @nom: SQLiteEntity
- @auteur: Idleman (idleman@idleman.fr)
- @description: Classe parent de tous les modèles (classe entitées) liées a la base de donnée,
- cette classe est configuré pour agir avec une base SQLite, mais il est possible de redefinir ses codes SQL pour l'adapter à un autre SGBD sans affecter
- le reste du code du projet.
- */
- class SQLiteEntity extends SQLite3
- {
-
- private $debug = false;
-
- function __construct($tag="rw"){
- switch($tag){
- case 'r' : $tag = SQLITE3_OPEN_READONLY; break;
- default: $tag = SQLITE3_OPEN_READWRITE | SQLITE3_OPEN_CREATE; break;
- }
- $this->open(__ROOT__.'/'.DB_NAME,$tag);
- }
- function __destruct(){
- $this->close();
- }
- function sgbdType($type){
- $return = false;
- switch($type){
- case 'string':
- case 'timestamp':
- case 'date':
- $return = 'VARCHAR(255)';
- break;
- case 'longstring':
- $return = 'longtext';
- break;
- case 'key':
- $return = 'INTEGER NOT NULL PRIMARY KEY';
- break;
- case 'object':
- case 'integer':
- $return = 'bigint(20)';
- break;
- case 'boolean':
- $return = 'INT(1)';
- break;
- default;
- $return = 'TEXT';
- break;
- }
- return $return ;
- }
-
-
-
- public function closeDatabase(){
- $this->close();
- }
- // GESTION SQL
- /**
- * Verifie l'existence de la table en base de donnée
- * @author Valentin CARRUESCO
- * @category manipulation SQL
- * @param <String> créé la table si elle n'existe pas
- * @return true si la table existe, false dans le cas contraire
- */
- public function checkTable($autocreate = false){
- $query = 'SELECT count(*) as numRows FROM sqlite_master WHERE type="table" AND name="'.MYSQL_PREFIX.$this->TABLE_NAME.'"';
- $statement = $this->query($query);
- if($statement!=false){
- $statement = $statement->fetchArray();
- if($statement['numRows']==1){
- $return = true;
- }
- }
- if($autocreate && !$return) $this->create();
- return $return;
- }
- /**
- * Transforme l'objet en tableau attribut -> valeur
- * @author Valentin CARRUESCO
- * @return retourne un array attribut -> valeur correspondant à l'objet
- */
- public function toArray(){
- $array = array();
- foreach($this->object_fields as $field=>$type)
- $array[$field] = $this->$field;
- return $array;
- }
-
- /**
- * Transforme le tableau fournis en objet, le nommage attribut -> valeur doit être respecté
- * @author Valentin CARRUESCO
- * @param <Array> tableau contenant les clé/valeur de l'objet
- * @return retourne un objet attribut -> valeur correspondant à l'array fournis
- */
- public function fromArray($array){
- $object = new $this->CLASS_NAME();
- foreach($this->object_fields as $field=>$type)
- $object->$field = $array[$field];
-
- return $object;
- }
-
- /**
- * Methode de creation de l'entité
- * @author Valentin CARRUESCO
- * @category manipulation SQL
- * @param <String> $debug='false' active le debug mode (0 ou 1)
- * @return Aucun retour
- */
- public function create($debug='false'){
- $query = 'CREATE TABLE IF NOT EXISTS `'.MYSQL_PREFIX.$this->TABLE_NAME.'` (';
- $i=false;
- foreach($this->object_fields as $field=>$type){
- if($i){$query .=',';}else{$i=true;}
- $query .='`'.$field.'` '. $this->sgbdType($type).' NOT NULL';
- }
- $query .= ');';
- if($this->debug)echo '<hr>'.$this->CLASS_NAME.' ('.__METHOD__ .') : Requete --> '.$query;
- if(!$this->exec($query)) echo $this->lastErrorMsg();
- }
- public function drop($debug='false'){
- $query = 'DROP TABLE `'.MYSQL_PREFIX.$this->TABLE_NAME.'`;';
- if($this->debug)echo '<hr>'.$this->CLASS_NAME.' ('.__METHOD__ .') : Requete --> '.$query;
- if(!$this->exec($query)) echo $this->lastErrorMsg();
- }
- public function massiveInsert($events,$forceId = false){
- $query = 'INSERT INTO `'.MYSQL_PREFIX.$this->TABLE_NAME.'`(';
- $i=false;
- foreach($this->object_fields as $field=>$type){
- if($type=='key' && !$forceId) continue;
- if($i){$query .=',';}else{$i=true;}
- $query .='`'.$field.'`';
-
- }
- $query .=') select';
- $u = false;
- foreach($events as $event){
- if($u){$query .=' union select ';}else{$u=true;}
-
- $i=false;
- foreach($event->object_fields as $field=>$type){
- if($type=='key' && !$forceId) continue;
- if($i){$query .=',';}else{$i=true;}
- $query .='"'.eval('return htmlentities($event->'.$field.');').'"';
- }
-
- }
- $query .=';';
- //echo '<i>'.$this->CLASS_NAME.' ('.__METHOD__ .') : Requete --> '.$query.'<br>';
- if(!$this->exec($query)) echo $this->lastErrorMsg().'</i>';
- }
- /**
- * Methode d'insertion ou de modifications d'elements de l'entité
- * @author Valentin CARRUESCO
- * @category manipulation SQL
- * @param Aucun
- * @return Aucun retour
- */
- public function save(){
-
- if(isset($this->id)){
- $query = 'UPDATE `'.MYSQL_PREFIX.$this->TABLE_NAME.'`';
- $query .= ' SET ';
- $i = false;
- foreach($this->object_fields as $field=>$type){
- if($i){$query .=',';}else{$i=true;}
- $id = eval('return htmlentities($this->'.$field.');');
- $query .= '`'.$field.'`="'.$id.'"';
- }
- $query .= ' WHERE `id`="'.$this->id.'";';
- }else{
- $query = 'INSERT INTO `'.MYSQL_PREFIX.$this->TABLE_NAME.'`(';
- $i=false;
- foreach($this->object_fields as $field=>$type){
- if($type!='key'){
- if($i){$query .=',';}else{$i=true;}
- $query .='`'.$field.'`';
- }
- }
- $query .=')VALUES(';
- $i=false;
- foreach($this->object_fields as $field=>$type){
- if($type!='key'){
- if($i){$query .=',';}else{$i=true;}
- $query .='"'.eval('return htmlentities($this->'.$field.');').'"';
- }
- }
- $query .=');';
- }
- if($this->debug)echo '<i>'.$this->CLASS_NAME.' ('.__METHOD__ .') : Requete --> '.$query.'<br>';
- //var_dump ($query);
- if(!$this->exec($query)) echo $this->lastErrorMsg().'</i>';
- $this->id = (!isset($this->id)?$this->lastInsertRowID():$this->id);
- }
- /**
- * Méthode de modification d'éléments de l'entité
- * @author Valentin CARRUESCO
- * @category manipulation SQL
- * @param <Array> $colonnes=>$valeurs
- * @param <Array> $colonnes (WHERE) =>$valeurs (WHERE)
- * @param <String> $operation="=" definis le type d'operateur pour la requete select
- * @param <String> $debug='false' active le debug mode (0 ou 1)
- * @return Aucun retour
- */
- public function change($columns,$columns2=null,$operation='=',$debug='false'){
- $query = 'UPDATE `'.MYSQL_PREFIX.$this->TABLE_NAME.'` SET ';
- $i=false;
- foreach ($columns as $column=>$value){
- if($i){$query .=',';}else{$i=true;}
- $query .= '`'.$column.'`="'.$value.'" ';
- }
- if($columns2!=null){
- $query .=' WHERE ';
- $i=false;
- foreach ($columns2 as $column=>$value){
- if($i){$query .='AND ';}else{$i=true;}
- $query .= '`'.$column.'`'.$operation.'"'.$value.'" ';
- }
- }
- //echo '<hr>'.$this->CLASS_NAME.' ('.__METHOD__ .') : Requete --> '.$query.'<br>';
- if(!$this->exec($query)) echo $this->lastErrorMsg();
- }
- /**
- * Méthode de selection de tous les elements de l'entité
- * @author Valentin CARRUESCO
- * @category manipulation SQL
- * @param <String> $ordre=null
- * @param <String> $limite=null
- * @param <String> $debug='false' active le debug mode (0 ou 1)
- * @return <Array<Entity>> $Entity
- */
- public function populate($order='null',$limit='null',$debug='false'){
- eval('$results = '.$this->CLASS_NAME.'::loadAll(array(),\''.$order.'\','.$limit.',\'=\','.$debug.');');
- return $results;
- }
- /**
- * Méthode de selection multiple d'elements de l'entité
- * @author Valentin CARRUESCO
- * @category manipulation SQL
- * @param <Array> $colonnes (WHERE)
- * @param <Array> $valeurs (WHERE)
- * @param <String> $ordre=null
- * @param <String> $limite=null
- * @param <String> $operation="=" definis le type d'operateur pour la requete select
- * @param <String> $debug='false' active le debug mode (0 ou 1)
- * @return <Array<Entity>> $Entity
- */
- public function loadAll($columns,$order=null,$limit=null,$operation="=",$debug='false',$selColumn='*'){
- $objects = array();
- $whereClause = '';
-
- if($columns!=null && sizeof($columns)!=0){
- $whereClause .= ' WHERE ';
- $i = false;
- foreach($columns as $column=>$value){
- if($i){$whereClause .=' AND ';}else{$i=true;}
- $whereClause .= '`'.$column.'`'.$operation.'"'.$value.'"';
- }
- }
- $query = 'SELECT '.$selColumn.' FROM `'.MYSQL_PREFIX.$this->TABLE_NAME.'` '.$whereClause.' ';
- if($order!=null) $query .='ORDER BY '.$order.' ';
- if($limit!=null) $query .='LIMIT '.$limit.' ';
- $query .=';';
-
- $execQuery = $this->query($query);
- if(!$execQuery)
- echo $this->lastErrorMsg();
- while($queryReturn = $execQuery->fetchArray() ){
- $object = new $this->CLASS_NAME();
- foreach($this->object_fields as $field=>$type)
- if(isset($queryReturn[$field])) $object->$field= html_entity_decode( addslashes($queryReturn[$field]));
-
- $objects[] = $object;
- unset($object);
- }
- return $objects;
- }
- public function loadAllOnlyColumn($selColumn,$columns,$order=null,$limit=null,$operation="=",$debug='false'){
- eval('$objects = $this->loadAll($columns,\''.$order.'\',\''.$limit.'\',\''.$operation.'\',\''.$debug.'\',\''.$selColumn.'\');');
- if(count($objects)==0)$objects = array();
- return $objects;
- }
- /**
- * Méthode de selection unique d'élements de l'entité
- * @author Valentin CARRUESCO
- * @category manipulation SQL
- * @param <Array> $colonnes (WHERE)
- * @param <Array> $valeurs (WHERE)
- * @param <String> $operation="=" definis le type d'operateur pour la requete select
- * @param <String> $debug='false' active le debug mode (0 ou 1)
- * @return <Entity> $Entity ou false si aucun objet n'est trouvé en base
- */
- public function load($columns,$operation='=',$debug='false'){
- eval('$objects = $this->loadAll($columns,null,\'1\',\''.$operation.'\',\''.$debug.'\');');
- if(!isset($objects[0]))$objects[0] = false;
- return $objects[0];
- }
- /**
- * Méthode de selection unique d'élements de l'entité
- * @author Valentin CARRUESCO
- * @category manipulation SQL
- * @param <Array> $colonnes (WHERE)
- * @param <Array> $valeurs (WHERE)
- * @param <String> $operation="=" definis le type d'operateur pour la requete select
- * @param <String> $debug='false' active le debug mode (0 ou 1)
- * @return <Entity> $Entity ou false si aucun objet n'est trouvé en base
- */
- public function getById($id,$operation='=',$debug='false'){
-
- return $this->load(array('id'=>$id),$operation,$debug);
- }
- /**
- * Methode de comptage des éléments de l'entité
- * @author Valentin CARRUESCO
- * @category manipulation SQL
- * @param <String> $debug='false' active le debug mode (0 ou 1)
- * @return<Integer> nombre de ligne dans l'entité'
- */
- public function rowCount($columns=null)
- {
- $whereClause ='';
- if($columns!=null){
- $whereClause = ' WHERE ';
- $i=false;
- foreach($columns as $column=>$value){
- if($i){$whereClause .=' AND ';}else{$i=true;}
- $whereClause .= '`'.$column.'`="'.$value.'"';
- }
- }
- $query = 'SELECT COUNT(id) FROM '.MYSQL_PREFIX.$this->TABLE_NAME.$whereClause;
- //echo '<hr>'.$this->CLASS_NAME.' ('.__METHOD__ .') : Requete --> '.$query.'<br>';
- $execQuery = $this->querySingle($query);
- //echo $this->lastErrorMsg();
- return (!$execQuery?0:$execQuery);
- }
-
- /**
- * Méthode de supression d'elements de l'entité
- * @author Valentin CARRUESCO
- * @category manipulation SQL
- * @param <Array> $colonnes (WHERE)
- * @param <Array> $valeurs (WHERE)
- * @param <String> $operation="=" definis le type d'operateur pour la requete select
- * @param <String> $debug='false' active le debug mode (0 ou 1)
- * @return Aucun retour
- */
- public function delete($columns,$operation='=',$debug='false',$limit=null){
- $whereClause = '';
- $i=false;
- foreach($columns as $column=>$value){
- if($i){$whereClause .=' AND ';}else{$i=true;}
- $whereClause .= '`'.$column.'`'.$operation.'"'.$value.'"';
- }
- $query = 'DELETE FROM `'.MYSQL_PREFIX.$this->TABLE_NAME.'` WHERE '.$whereClause.' '.(isset($limit)?'LIMIT '.$limit:'').';';
- //echo '<hr>'.$this->CLASS_NAME.' ('.__METHOD__ .') : Requete --> '.$query.'<br>';
- if(!$this->exec($query)) echo $this->lastErrorMsg();
- }
-
- public function customExecute($request){
- $this->exec($request);
- }
- public function customQuery($request){
- return $this->query($request);
- }
- // ACCESSEURS
- /**
- * Méthode de récuperation de l'attribut debug de l'entité
- * @author Valentin CARRUESCO
- * @category Accesseur
- * @param Aucun
- * @return <Attribute> debug
- */
-
- public function getDebug(){
- return $this->debug;
- }
-
- /**
- * Méthode de définition de l'attribut debug de l'entité
- * @author Valentin CARRUESCO
- * @category Accesseur
- * @param <boolean> $debug
- */
- public function setDebug($debug){
- $this->debug = $debug;
- }
- public function getObject_fields(){
- return $this->object_fields;
- }
- }
- ?>
|