[PHP] Créer un objet à partir de plusieurs résultats SQL, puis envoyer ça au front end

Intro :

On peut envoyer soit un array, soit un objet, ici c’est un objet :

Code exemple :

Le web service :


function GetActivite() {
	$filtres 		= json_decode(file_get_contents("php://input")); 
	$suiviPersonnel = new SuiviPersonnel();
	$result		 	= $suiviPersonnel->GetActivite($filtres);
	if($result){
		echo(json_encode($result));  
	}
}

La méthode qui retourne un objet à partir de résultats SQL



/**
 * Fenetre Activité de la vue suivi_activite
 * @param $filtres => mois | annee| id_user
 * @return array | false
 */
public function GetActivite($filtres)
	{
	try
		{
		$total = new stdClass(); // Cet objet va contenir tous les resultats puis on l'envoit à la fin au front end angularjs

		// $total->property = 'Here we go'; // Exemple d'injection de resultat dans l'objet ...
		// PHASE 1 : CALCUL DU TEMPS DAPPEL TOTAL

		$sql = "
                  SELECT
                  TO_CHAR((SUM(duration) || ' second')::interval, 'HH24:MI:SS') AS temps_appel
                  FROM " . self::TABLE . "
                  WHERE 1=1
                   ";
		if ($filtres->mois)
			{
			$sql.= " AND EXTRACT(MONTH FROM calldate) = " . $filtres->mois;
			}

		if ($filtres->annee)
			{
			$sql.= " AND EXTRACT(YEAR FROM calldate) = " . $filtres->annee;
			}

		if ($filtres->id_utilisateurs)
			{
			$sql.= " AND id_utilisateurs = " . $filtres->id_utilisateurs;
			}

		$req = $this->bdd->prepare($sql);
		$req->execute($tab_value);
		$result = $req->Fetch(PDO::FETCH_ASSOC);
		$req->closeCursor();
		$total->temps_appel = $result[temps_appel];

		// PHASE 2 : CALCUL DU NOMBRE APPEL MOYEN PAR HEURES

		$sql = "
                SELECT
              AVG(*) AS nombre_appels_moyen
              FROM " . self::TABLE . "
             WHERE 1=1
                ";
		if ($filtres->mois)
			{
			$sql.= " AND EXTRACT(MONTH FROM calldate) = " . $filtres->mois;
			}

		if ($filtres->annee)
			{
			$sql.= " AND EXTRACT(YEAR FROM calldate) = " . $filtres->annee;
			}

		if ($filtres->id_utilisateurs)
			{
			$sql.= " AND id_utilisateurs = " . $filtres->id_utilisateurs;
			}

		$req = $this->bdd->prepare($sql);
		$req->execute($tab_value);
		$result2 = $req->Fetch(PDO::FETCH_ASSOC);
		$req->closeCursor();
		$total->nombre_appels_moyen = $result2[nombre_appels_moyen];

		// PHASE 3 : CALCUL DU NOMBRE DE FICHES TRAITEES

		$sql = "
                SELECT
                COUNT(*) AS fiches_traitees
                FROM " . self::TABLE . "
                WHERE 1=1
                ";
		if ($filtres->mois)
			{
			$sql.= " AND EXTRACT(MONTH FROM calldate) = " . $filtres->mois;
			}

		if ($filtres->annee)
			{
			$sql.= " AND EXTRACT(YEAR FROM calldate) = " . $filtres->annee;
			}

		if ($filtres->id_utilisateurs)
			{
			$sql.= " AND id_utilisateurs = " . $filtres->id_utilisateurs;
			}

		$req = $this->bdd->prepare($sql);
		$req->execute($tab_value);
		$result3 = $req->Fetch(PDO::FETCH_ASSOC);
		$req->closeCursor();
		$total->fiches_traitees = $result3[fiches_traitees];

		// PHASE 4 : CALCUL DU NOMBRE DE CONTACTS

		$sql = "
                SELECT
                DISTINCT(COUNT('appeler')) AS nb_contacts
               FROM " . self::TABLE . "
               WHERE 1=1
                ";
		if ($filtres->mois)
			{
			$sql.= " AND EXTRACT(MONTH FROM calldate) = " . $filtres->mois;
			}

		if ($filtres->annee)
			{
			$sql.= " AND EXTRACT(YEAR FROM calldate) = " . $filtres->annee;
			}

		if ($filtres->id_utilisateurs)
			{
			$sql.= " AND id_utilisateurs = " . $filtres->id_utilisateurs;
			}

		$req = $this->bdd->prepare($sql);
		$req->execute($tab_value);
		$result4 = $req->Fetch(PDO::FETCH_ASSOC);
		$req->closeCursor();
		$total->nb_contacts = $result4[nb_contacts];

		// PHASE 5 : CALCUL DU NOMBRE APPEL TOTAL

		$sql = "
                SELECT
                 COUNT(*) AS nombre_appels
                 FROM " . self::TABLE . "
                WHERE 1=1
                ";
		if ($filtres->mois)
			{
			$sql.= " AND EXTRACT(MONTH FROM calldate) = " . $filtres->mois;
			}

		if ($filtres->annee)
			{
			$sql.= " AND EXTRACT(YEAR FROM calldate) = " . $filtres->annee;
			}

		if ($filtres->id_utilisateurs)
			{
			$sql.= " AND id_utilisateurs = " . $filtres->id_utilisateurs;
			}

		$req = $this->bdd->prepare($sql);
		$req->execute($tab_value);
		$result5 = $req->Fetch(PDO::FETCH_ASSOC);
		$req->closeCursor();
		$total->nombre_appels = $result5[nombre_appels];
		return $total;
		}

	catch(Exception $e)
		{
		die('Erreur : ' . $e->getMessage());
		}
	}


 

Puis, si on veut condenser les filtres dans une fonction :

	 public function GetActivite($filtres) {
        
		try {
			
			$total = new stdClass(); // Cet objet va contenir tous les resultats puis on l'envoit à la fin au front end angularjs
			// $total->property = 'Here we go'; // Exemple d'injection de resultat dans l'objet ...
			
			//  CALCUL DU TEMPS DAPPEL TOTAL 
			$sql  = "
				SELECT 
				TO_CHAR((SUM(duration) || ' second')::interval, 'HH24:MI:SS')  AS temps_appel 
				FROM " . self::TABLE . "
				WHERE 1=1 
			";
			
			$sql = $this->addFiltres($filtres,$sql);
			
			$req = $this->bdd->prepare($sql);
            $req->execute($tab_value);
            $result = $req->Fetch(PDO::FETCH_ASSOC);
            $req->closeCursor();
			
			$total->temps_appel = $result[temps_appel] ; 
			
			// CALCUL DU DUREE MOYENNE PAR APPEL
			 $sql  = "
				 SELECT 
				 ROUND(AVG(duration),2) AS duree_appel_moyen  
				 FROM " . self::TABLE . "
				 WHERE 1=1 
			 ";
			 $sql = $this->addFiltres($filtres,$sql);
			
			 $req = $this->bdd->prepare($sql);
             $req->execute($tab_value);
             $result = $req->Fetch(PDO::FETCH_ASSOC);
             $req->closeCursor();
			
			$total->duree_appel_moyen = $result[duree_appel_moyen]; 
			
			
			// CALCUL DU NOMBRE APPEL MOYEN PAR HEURES
			 $sql  = "
				 SELECT 
				 AVG(duration) AS nombre_appels_moyen_heure  
				 FROM " . self::TABLE . "
				 WHERE 1=1 
			 ";
			 $sql = $this->addFiltres($filtres,$sql);
			
			 $req = $this->bdd->prepare($sql);
             $req->execute($tab_value);
             $result = $req->Fetch(PDO::FETCH_ASSOC);
             $req->closeCursor();
			
			$total->nombre_appels_moyen_heure = $result[nombre_appels_moyen_heure]; 
			
			// CALCUL DU NOMBRE DE FICHES TRAITEES 
			$sql  = "
				SELECT 
				COUNT(*)  AS fiches_traitees 
				FROM " . self::TABLE . "
				WHERE 1=1 
			";
			$sql = $this->addFiltres($filtres,$sql);
			
			$req = $this->bdd->prepare($sql);
            $req->execute($tab_value);
            $result = $req->Fetch(PDO::FETCH_ASSOC);
            $req->closeCursor();
			
			$total->fiches_traitees = $result[fiches_traitees]; 
            
			//  CALCUL DU NOMBRE DE CONTACTS 
			$sql  = "
				SELECT 
				DISTINCT(COUNT('appeler'))  AS nb_contacts 
				FROM " . self::TABLE . "
				WHERE 1=1 
			";
			$sql = $this->addFiltres($filtres,$sql);
			
			$req = $this->bdd->prepare($sql);
            $req->execute($tab_value);
            $result = $req->Fetch(PDO::FETCH_ASSOC);
            $req->closeCursor();
			
			$total->nb_contacts  = $result[nb_contacts]; 
			
			
			// CALCUL DU NOMBRE APPEL TOTAL
			$sql  = "
				SELECT 
				COUNT(*) AS nombre_appels 
				FROM " . self::TABLE . "
				WHERE 1=1 
			";
			$sql = $this->addFiltres($filtres,$sql);
			
			$req = $this->bdd->prepare($sql);
            $req->execute($tab_value);
            $result = $req->Fetch(PDO::FETCH_ASSOC);
            $req->closeCursor();
			
			$total->nombre_appels = $result[nombre_appels]; 
			
			
			
			
			return $total; 
			
        } catch(Exception $e) {
            die('Erreur : '.$e->getMessage());
        }
    }
    }

Les filtres sont désormais contenus dans cette function :

private function addFiltres($filtres,$sql){
		
		if ($filtres->mois) {
			$sql  .= " AND EXTRACT(MONTH FROM  calldate) = 	".$filtres->mois ; 
		} 	

		if ($filtres->annee) {
			$sql  .= " AND EXTRACT(YEAR FROM  calldate) = 	".$filtres->annee; 
		} 
		
		if ($filtres->id_utilisateurs) {
			$sql  .= " AND id_utilisateurs = ".$filtres->id_utilisateurs;
		}
		
		return $sql;
		
	}

Publicités

[www.openode.io] Enfin, un bon hébergeur pour publier ULTRA facilement des applications NODE.JS

nodeeeeee

Introduction


Avant 2018, on pouvait créer nos applications NODE.JS assez facilement en LOCAL .

Mais lorsque venait le moment de publier notre application en ligne, c’était assez la galère,il fallait soit acheter un serveur dédié assez cher, soit effectuer des méthodes complexes avec cloudant ou autres Aws pour arriver à placer son app en ligne .

Openode.io : Une seule commande, cela fonctionne de suite !


Depuis 2018, openode.io est arrivé, et enfin, ça marche et c’est facile !! Depuis le temps qu’on attendait ça !!

On s’inscrit sur openode.io, on a de suite un environnement prêt, suffit juste de lui donner un nom, c’est vraiment TROP SIMPLE ! Cette société serait basée au Texas.

En local, dans notre pc, on se rends dans le répertoire de notre site node.js .

Ensuite, on télécharge avec GIT leur programme de gestion hyper simple qui nous donne quelques commandes supplémentaires dans CMD(La ligne de commande Windows).

Une fois qu’on a installé leur programme, il suffit de taper dans notre répertoire :

openode deploy

pour envoyer l’intégralité de notre site en ligne, ça marche de suite !

Voici un exemple de moi, qui envoie mon application node.js en ligne :

deploy.jpg

Le programme deploy surveille que notre fichier package.json contient de bonnes versions de librairies :

Exemple :

{
"name": "socket-chat-example",
"version": "0.0.1",
"description": "my first socket.io app",
"dependencies": {
"express": "^4.15.2",
"mysql": "^2.16.0",
"mongoose": "^5.2.6",
"morgan": "^1.1.1"

},
"scripts": {
"start": "node index.js"
}
}

Ici , je charge la lib mongoose pour pouvoir me connecter à un base de données MONGODB et la lib mysql pour pouvoir aussi me connecter à une base de données MYSQL, tout cela en JS (le langage le plus coool et flexiiible!).

Et oui, cela veut dire qu’on peut désormais coder tout en JS, aborder des bdd relationnelles quand même, et déployer de façon ultra simple, c’est carrément TROP COOL !

Voici les 2 autres fichiers de mon app, just pour info (On voit que j’exécute des requêtes SQL dans le Javascript …)  :

index.js :


 var app = require('express')();
 var http = require('http').Server(app);
 var port = process.env.PORT || 3000;
 var mongoose = require('mongoose');
 var mysql = require('mysql');
 var morgan = require('morgan'); // log requests to the console (express4)</code>

 var connection = mysql.createConnection({
     host: 'sql.free.fr',
     user: 'nicolas.huleux',
     password: 'xxxxxxx',
     database: 'nicolas_huleux'
 });

 connection.connect(function(err) {
     // connected! (unless `err` is set)

 });

 connection.query('SELECT * from acteurs', function(err, rows, fields) {
     if (!err)
         console.log('The solution is: ', rows);
     else
         console.log('Error while performing Query.');
 });

 app.get('/', function(req, res) {
     res.sendFile(__dirname + '/index.html');
 });

 http.listen(port, function() {
     console.log('listening on *:' + port);
 });

Et là, index.html, un formulaire bateau, pas encore fonctionnel

<!doctype html>
<html>
  <head>
    <title>form</title>

  </head>
  <body>
    <ul id="messages"></ul>
    <form action="">
      <input id="m" autocomplete="off" /><button>Send</button>
    </form>
    <script src="https://cdn.socket.io/socket.io-1.2.0.js"></script>
    <script src="https://code.jquery.com/jquery-1.11.1.js"></script>
	
	 <form action="action_page.php">
		  <div class="imgcontainer">
			<img src="img_avatar2.png" alt="Avatar" class="avatar">
		  </div>

		  <div class="container">
			<label for="uname"><b>Username</b></label>
			<input type="text" placeholder="Enter Username" name="uname" required>

			<label for="psw"><b>Password</b></label>
			<input type="password" placeholder="Enter Password" name="psw" required>

			<button type="submit">Login</button>
			<label>
			  <input type="checkbox" checked="checked" name="remember"> Remember me
			</label>
		  </div>

		  <div class="container" style="background-color:#f1f1f1">
			<button type="button" class="cancelbtn">Cancel</button>
			<span class="psw">Forgot <a href="#">password?</a></span>
		  </div>
		</form> 

  </body>
</html>

Conclusion :
On peut désormais coder tout en NODE.JS et publier des démos sur son blog super facilement, sans acheter une serveur dédié, c’est TROP BIEN . Si on veut, plus besoin d’utiliser PHP en back end il existe des tas de libs qui permette à node de se connecter aux bases relationnelles, y compris sans faire de SQL avec par exemple KNEX.JS (https://stackoverflow.com/questions/5818312/mysql-with-node-js) :

KNEX.JS

KnexJs can be used as an SQL query builder in both Node.JS and the browser. I find it easy to use. Let try it – Knex.js

$ npm install knex--save# Then add one of the following(adding a--save) flag:
  $ npm install pg
$ npm install sqlite3
$ npm install mysql
$ npm install mysql2
$ npm install mariasql
$ npm install strong - oracle
$ npm install oracle
$ npm install mssql


var knex = require('knex')({
    client: 'mysql',
    connection: {
        host: '127.0.0.1',
        user: 'your_database_user',
        password: 'your_database_password',
        database: 'myapp_test'
    }
});

You can use it like this

knex.select('*').from('users')

or

knex('users').where({
    first_name: 'Test',
    last_name: 'User'
}).select('id')

Traitement Back-end PHP Try Catch avec réception et traitement Front-end AngularJs 1.6.5

INTRODUCTION :


Gérer les TRY CATCH dans les web service PHP, et communiquer le message contenu dans un THROW directement au FRONT END ANGULARJS

Le système de try catch PHP est puissant et pratique à utiliser, en particulier pour les problèmes de droits par exemple mais cela peut être pour n’importe quoi d’autre !!

Seulement, il faut savoir le faire communiquer avec le FRONT END !!

DETAIL


Pour info, voici le look d’une méthode de ma classe, dans le BACKEND PHP, fichier backend.php , qui enregistre les permissions, on peut voir un test de permission avant l’exécution  de la requête qui enregistre un tableau d’objets JSON décomposé grâce au foreach, l’important ici est de regarder le THROW et son message STRING ( Les contrôles de sécurité ne sont pas affichés dans cet exemple):

    /**
     * Update Permissions after front end management
     * 
     * Required Permission : $_SESSION['auth'] = true | UPDATE_PERMISSIONS
     * 
     * @return true
     * 
     * 
     */
    public function updatePermissions($jsonArray)
    {

        // Check User Permissions
        if (!$this->has_permission('UPDATE_PERMISSIONS', $_SESSION['permissions'])) {
            throw new Exception("Error : You are restricted to do this.");
        };


        foreach ($jsonArray as $index => $row) {
            $row                      = $this->escape_data_object($row);
            $id                       = $row['id'];
            $name                     = $row['name'];
            $permissions              = strval($row['permissions']);
           

            $sql = "UPDATE Job SET name='$name',permissions='$permissions' WHERE id = '$id'";
            $this->conn->query($sql);

        }

        mysqli_close($this->conn);
        return true;
    }

Le Web Service en PHP qui catche une éventuelle erreur de permission et renvoie le message d’erreur STRING du THROW pour pouvoir l’afficher directement dans le front end, (json_encode() permet de créer du JSON, compréhensible par angularJs, ou vue.js, ou angular 5 …) :

 if(!empty($_POST["updatePermissions"]) AND $_SESSION['auth']) {

    $jsonArray = $_POST["updatePermissions"];
    $jsonArray = json_decode($jsonArray,true); 
    $status = 200;

    try{
        $db->updatePermissions($jsonArray);
    } 
    catch(Exception $e){
         echo json_encode(array("response"=>$e->getMessage()));
         exit();
    } 

    echo json_encode(array("response"=>$status));

} 

Et enfin le FRONT END en ANGULARJS 1.6.5 qui traite le message d’erreur dans le .then() et affiche le STRING du THROW originel directement dans le FRONT END (Remarquez que la requête POST ajax s’adressait bien à mon WEBSERVICE en php ):

//~ AJAX CALL -> Sending whole $scope.permissions array of json objects
        $http.post(wsUrl, {updatePermissions: JSON.stringify($scope.permissions)})
            .then(function(data, headers, config) {
                console.log(data.data);

                $scope.ajaxCall = false;
                $scope.record_button_disable = false;

                // Errors management Responses
                if (data.data.response == 200) {
                    Notification.success($translate.instant('REQUESTSUCCESS'));
                    console.log("Réponse Serveur: " + data.data);

                }
                if (data.data.response != 200) {
                    Notification.error(data.data.response);
                }
            })
        }

Et enfin… Juste pour info, la petite fonction privée PHP has_permission() du cru qui permet d’ejecter les gars qui tentent de faire un truc alors qu’ils n’ont pas la permission dans leur array de permissions (séparé par ;), par le back end, hi hi . Par ecemple si il na pas la permission DISPLAY_USERS, le back end throw une erreur, et angularjs(ou vue.js) affiche le message d’erreur:

/**
	 * This function is looking for the permission inside user PHP SESSION permissions variables, if the permission is not present, then it returns false !
	 * 

	 * @return false|true
	 * 

	 */

	private function has_permission($permission, $permissions)
	{

		$permissions = explode(";", $permissions);

		if (in_array($permission, $permissions)) {
			return true;
		}

		return false;
	}

 

240px-Sheep_Shaf_Mouton.JPG‘Bhee, t »es un ouf pourquoi t’utilises pas que Php pour simplifier plutôt que de faire tout ça bhee?’

Parce que AngularJs et Javascript disposent de l’atout temps réel, d’énormément de librairies et sont très puissants, voir par exemple le jeux LARA CROFT http://xproger.info/projects/OpenLara/ avec une lib dédiée graphique js , voir Three.js, ou alors ne serait ce que D3.JS qui permet une modélisation innovante pour analyse de données, bon courage pour faire ça avec php !!!

[AngularJs + Php MYSQL ] Une table Html infinite scroll simple, sur base de donnée

angularjsphp_1_

Introduction


Avec Angularjs 1.6 , on ne télécharge pas tout un modèle de données lorsqu’il est très grand. Par exemple, pour, afficher toute une table de log de 150 MO, évidemment, on ne charge pas toute la table d’un seul coup dans la mémoire vive, ce serait bien trop couteux. Dans d’autres cas, dans le cadre d’une vue spéciale dans une application, on peut envisager de télécharger tout le modèle de données ( Par exemple, 500 utilisateurs)

L’idée de l’infinite Scroll sur base de donnée


L’idée étant d’afficher les 20 premiers enregistrements de la table, puis ensuite, lorsque l’on atteints le bas de la page, charger les 20 suivants, puis ainsi de suite, de cette manière, l’utilisateur a la sensation d’être en temps réel.

Le problème


Lire la suite

[AngularJs] un autocomplete asynchrone sur base de données avec Js-Custom-Select

Introduction :


Avec AngularJs, on est vite tenté de charger tout un modèle de données en mémoire vive, même pour l’afficher dans un select dropdown, c’est tellement facile … Par exemple comme ici :https://desgeeksetdeslettres.com/programmation-java/auto-completion-avec-angularjs

Pourtant, c’est forcément couteux dès que l’on a des centaines d’objets, d’ou l’idée de réserver la partie recherche au BACK END dès que les résultats dépassent la centaine de cas, en gros .

Qu’entends–t-on par modèle de données ? Par exemple : Toutes les villes de France (Des milliers), tous les utilisateurs de facebook (Des millions). Alors évidemment, on ne va pas tout charger dans le Front End et donc faire du asynchrone.

Pour parler basiquement, il faut qu’ à chaque fois que l’on tape une touche dans un champs INPUT, une requête SQL recherche les occurences dans la base de données, et remontent les resultats au format tableau d’objets JSON  (ARRAY [{},{},{},etc ….]). Ces résultats s’affichent alors dans notre select dropdown, afin de pouvoir faire notre choix.

C’est ce que permet de faire https://github.com/axel-zarate/js-custom-select.

Photo exemple de l’autocomplete sur base de données :

moumoute

Le code :

Je passe sur l’installation de js-custom-select qui est bien expliquée dans le github…


Dans la vue HTML, je mets mon SELECT :

<div custom-select="personne.lastName  for personne in searchAsync($searchTerm)" custom-select-options="{ 'async': true }" ng-model="custom2">
    <div class="pull-left" style="width: 40px">
        <img ng-src="{{ personne.image || 'img_app/gender_neutral_user1600_g.png' }}" style="width: 30px" /></div>
    <div class="pull-left">
        <strong>{{ personne.firstName}}</strong>

        <span>{{ personne.lastName}}</span></div>
    <div class="clearfix"></div>
</div>

On voit que on va afficher les objets personnes qui vont satisfaire le critère $searchTerm. En fait, dès qu’on va écrire dans le select, angularJs va exécuter searchAsync($searchTerm) , $searchTerm étant ce que l’on vient d’écrire. La recherche va se faire sur le lastName (le nom, en anglais)

Dans mon controleur MVC angularJS , j’ai cette fonction :

var wsUrl = 'web_services/mes_web_services.php';

$scope.searchAsync = function(term) {

  if (!term) {
    return false;
  }

  var putResponse;
  var promise = $http.post(wsUrl, {
    readPersonnes: JSON.stringify({
      'lastName': term
    })
  }).then(function(data, status, headers, config) {
    putResponse = data.data;
    console.log(putResponse); // this gets called after the server responds ( defined )
    return putResponse;

  })
  console.log(putResponse); // this gets called before the server responds ( undefined )
  return promise;

};

On voit qu’une requête HTTP est exécutée vers la base de données lors de chaque changement de la variable ‘term’ dans le select.

Et enfin, mon code BACK END en PHP MYSQLI, qui retourne à chaque fois la ou les réponses au format Array d’objets JSON habituel :

if(!empty($_POST["readPersonnes"])){
       $json = $_POST["readPersonnes"];
	$data = json_decode($json); 
  	echo json_encode($db->readPersonnes($data));
} 
  
  
// Read Personnes
public function readPersonnes($data)
{
	$sql = " SELECT p.* WHERE 1=1 ";
	

	if ($data->lastName) {
	   
		$sql .= " AND p.lastName LIKE '" .$data->lastName. "%'";
	}

	$responseArray = array();
	
	if ($result = $this->conn->query($sql)) {
		while ($obj = $result->fetch_object()) {
			array_push($responseArray, $obj);
		}
		mysqli_free_result($result); // Free result set
	}
	
	mysqli_close($this->conn);
	return $responseArray;
}

Explication : Si le back end detecte la présence de $data->lastName , alors, il filtre avec LIKE « nomDeLaPersone % » sur le nom, le % veut dire qu’il cherche avec toutes les lettres possibles derrière la variable.
Si l’on ne recherche rien, alors aucun modèle de données n’est chargé, grace à

if (!term) {
return false;
}

NOTE : Ici je fait un select *, mais bien sur, je peux restreindre plus afin de soulager encore le traitement, je peux faire un p.lastName, p.id par exemple dans le select à la place de p.*
Pourquoi le WHERE 1 = 1 ? Et bien c’est pour pouvoir créer des requêtes SQL à la volée qu’on doit écrire cela.

Conclusion :

Avec cette méthode, on obtient des applications pas du tout couteuses, qui ne chargent pas des tas de modèles de données lorsqu’il y a plus de 5 champs autocomplete simultanés porant sur des modèles de données différents (Par exemple : Personnes, Villes, Départements …) dans une vue par exemple.

En d’autres terme, dès que l’on peut soulager le front end, on le fait , avec cette méthode, on peut rechercher sur des millions d’occurences sans dommage pour la mémoire vive .

Il ne nous reste plus qu’à afficher un petit LOADER avec ng-show pour rassurer l’utilisateur … Qui comprends bien qu’une requête SQL est en cours même sans être informaticien.

Note : Avec Jquery, c’est plus facile …

[AngularJs + Php-SQL] Astuce : Copier-Coller des CRUDS pour aller plus vite.

angularjsphp_1_logo-mysql-170x170_400x400

Introduction


Dans les applications informatique, le CRUD revient tout le temps.

Il s’agit de faire de la Creation/Lecture/Mise à jour/Suppression.

L’idée est donc de faire du copié-collé d’un crud standard, puis de changer uniquement le nom du modèle de données, en faisant « controle+h » dans notepad, afin d’aller beaucoup plus vite.

Note : Java Hibernate permettrait de faire cela encore plus simplement( méthode comin’ soon ), sans compter les méthodes de création automatiques des POJO, mais ce n’est pas le sujet de ce post … Là on est sur du back end PHP-MYSQL

Un exemple en temps réel dans une App !


Dans mon application RdvJuristes, j’ai un Crud sur les personnes :

http://nicolash.org/rdvj/index.html#/personnes

crd1.jpg

 

Il est évident que je ne vais pas me retaper tout le code pour créer un CRUD sur les juristes :

http://nicolash.org/rdvj/index.html#/juristes

crd2.jpg

On comprends qu’on a affaire à 2 modèles de données relativement similaires, que l’on peut copier-coller, puis, ensuite adapter à notre convenance.

Lire la suite

[HighCharts] Elaborer une statistique simple avec High Charts dans une application SAAS.

highcharts-logo

Introduction


Dans l’application RdvJuristes, je décide de calculer la somme des notes de frais de tous les rendez vous de la semaine en cours, puis de les afficher dans un graphique High Charts en barres.

Technologie utilisée


  • Highcharts
  • Php-Mysql en technologie PDO pour le back end
  • AngularJs pour le front end

Ordonnancement


  1. Examiner la conception de la base de donnée relationnelle.
  2. Elaborer la requête SQL
  3. Concevoir le Back End
  4. Concevoir le Front End
  5. Tester.

Lire la suite