PHP实现直接修改表内容DataGrid功能_PHP教程
最近想做一个通过PHP实现DataGrid功能的东西,这样可以直接修改数据库中表的内容,而不用开发【新增数据页面】,【编辑页面】,于是乎在网上找了找,类似的东西也有几个,开源的、付费的都有,不过基本都是基于MySQL。由于需要连接Oracle所以从二次开发和页面样式来说个人觉得 phpMyDataGrid还是比较好上手。本篇首先介绍基于MySQL的使用方法,再简单介绍对于Oracle连接(基于sqlrelay)的二次开发。
1. 创建测试数据库和表
<ol class="dp-c"> <li class="alt"><span><span>create database `guru`; </span></span></li> <li><span> </span></li> <li class="alt"><span>USE `guru`; </span></li> <li><span> </span></li> <li class="alt"><span>CREATE TABLE `employees` ( </span></li> <li><span> `id` int(6) NOT NULL auto_increment, </span></li> <li class="alt"> <span> `name` char(20) </span><span class="keyword">default</span><span> NULL, </span> </li> <li> <span> `lastname` char(20) </span><span class="keyword">default</span><span> NULL, </span> </li> <li class="alt"> <span> `salary` float </span><span class="keyword">default</span><span> NULL, </span> </li> <li> <span> `age` int(2) </span><span class="keyword">default</span><span> NULL, </span> </li> <li class="alt"> <span> `afiliation` </span><span class="func">date</span><span> </span><span class="keyword">default</span><span> NULL, </span> </li> <li> <span> `status` int(1) </span><span class="keyword">default</span><span> NULL, </span> </li> <li class="alt"> <span> `active` tinyint(1) </span><span class="keyword">default</span><span> NULL, </span> </li> <li> <span> `workeddays` int(2) </span><span class="keyword">default</span><span> NULL, </span> </li> <li class="alt"> <span> `photo` char(30) </span><span class="keyword">default</span><span> NULL, </span> </li> <li><span> PRIMARY KEY (`id`) </span></li> <li class="alt"><span>) </span></li> <li><span> </span></li> <li class="alt"><span>insert into `employees` </span></li> <li><span> (`id`,`name`,`lastname`,`salary`,`age`,`afiliation`,`status`,`active`,`workeddays`,`photo`) </span></li> <li class="alt"> <span> values (1, </span><span class="string">'Ana'</span><span>, </span><span class="string">'Trujillo'</span><span>,2000,45, </span><span class="string">'2005-05-13'</span><span>,1,1,10, </span><span class="string">'1.jpg'</span><span>); </span> </li> <li><span>insert into `employees` </span></li> <li class="alt"><span> (`id`,`name`,`lastname`,`salary`,`age`,`afiliation`,`status`,`active`,`workeddays`,`photo`) </span></li> <li> <span> values (2, </span><span class="string">'Jennifer'</span><span>, </span><span class="string">'Aniston'</span><span>,3500,23, </span><span class="string">'2004-10-22'</span><span>,1,0,0, </span><span class="string">'2.jpg'</span><span>); </span> </li> <li class="alt"><span>insert into `employees` </span></li> <li><span> (`id`,`name`,`lastname`,`salary`,`age`,`afiliation`,`status`,`active`,`workeddays`,`photo`) </span></li> <li class="alt"> <span> values (3, </span><span class="string">'Michael'</span><span>, </span><span class="string">'Norman'</span><span>,1200,19, </span><span class="string">'2007-01-10'</span><span>,1,1,5, </span><span class="string">'3.jpg'</span><span>); </span> </li> <li><span>insert into `employees` </span></li> <li class="alt"><span> (`id`,`name`,`lastname`,`salary`,`age`,`afiliation`,`status`,`active`,`workeddays`,`photo`) </span></li> <li> <span> values (4, </span><span class="string">'Vanessa'</span><span>, </span><span class="string">'Black'</span><span>,6500,31, </span><span class="string">'2000-11-05'</span><span>,1,1,30, </span><span class="string">'4.jpg'</span><span>); </span> </li> <li class="alt"><span>insert into `employees` </span></li> <li><span> (`id`,`name`,`lastname`,`salary`,`age`,`afiliation`,`status`,`active`,`workeddays`,`photo`) </span></li> <li class="alt"> <span> values (5, </span><span class="string">'Michael'</span><span>, </span><span class="string">'Strauss'</span><span>,3200,45, </span><span class="string">'2006-10-21'</span><span>,2,0,22, </span><span class="string">'5.jpg'</span><span>); </span> </li> <li><span>insert into `employees` </span></li> <li class="alt"><span> (`id`,`name`,`lastname`,`salary`,`age`,`afiliation`,`status`,`active`,`workeddays`,`photo`) </span></li> <li> <span> values (6, </span><span class="string">'William'</span><span>, </span><span class="string">'Brown'</span><span>,2300,21, </span><span class="string">'2001-03-10'</span><span>,3,1,10, </span><span class="string">'6.jpg'</span><span>); </span> </li> <li class="alt"><span>insert into `employees` </span></li> <li><span> (`id`,`name`,`lastname`,`salary`,`age`,`afiliation`,`status`,`active`,`workeddays`,`photo`) </span></li> <li class="alt"> <span> values (7, </span><span class="string">'Lucca'</span><span>, </span><span class="string">'Normany'</span><span>,2800,36, </span><span class="string">'2006-10-02'</span><span>,3,1,20, </span><span class="string">'7.jpg'</span><span>); </span> </li> </ol>
2. PHP程序介绍
phpMyDataGrid主要是通过phpmydatagrid.class.php,dgscripts.js来实现的,总共加起来不到100kB,又是一个小巧的软件。对于这两个文件就不多讲了,感兴趣的同学可以“打包带走”回去慢慢品。主要介绍该软件的使用方法,即实例 datagrid_for_mysql.php。先看一下页面示意图:
程序讲解:
<ol class="dp-c"> <li class="alt"><span><span><?php </span></span></span></li> <li> <span class="keyword">include</span><span> (</span><span class="string">"phpmydatagrid.class.php"</span><span>); </span> </li> <li class="alt"> <span class="vars">$objGrid</span><span> = </span><span class="keyword">new</span><span> datagrid; </span> </li> <li> <span class="vars">$objGrid</span><span>->closeTags(true); </span> </li> <li class="alt"> <span class="vars">$objGrid</span><span>->friendlyHTML(); </span> </li> <li> <span class="vars">$objGrid</span><span>->methodForm(</span><span class="string">"get"</span><span>); </span> </li> <li class="alt"> <span class="comment">//连接数据库 </span><span> </span> </li> <li> <span class="vars">$objGrid</span><span>->conectadb(</span><span class="string">"127.0.0.1"</span><span>, </span><span class="string">"root"</span><span>, </span><span class="string">"root"</span><span>, </span><span class="string">"guru"</span><span>);</span><span class="comment">//加密字符串 </span><span> </span> </li> <li class="alt"> <span class="vars">$objGrid</span><span>->salt(</span><span class="string">"Myc0defor5tr0ng3r-Pro3EctiOn"</span><span>); </span> </li> <li> <span class="vars">$objGrid</span><span>->language(</span><span class="string">"en"</span><span>); </span> </li> <li class="alt"> <span class="comment">//最后一列显示的功能键,从左向右功能为“新增键”、“编辑键”、“删除键”、“浏览键”。 </span><span> </span> </li> <li> <span class="vars">$objGrid</span><span>->buttons(true,true,true,true); </span> </li> <li class="alt"> <span class="comment">//修改数值时产生的Form名称 </span><span> </span> </li> <li> <span class="vars">$objGrid</span><span>->form(</span><span class="string">'employee'</span><span>, true); </span> </li> <li class="alt"> <span class="comment">//可检索列名 </span><span> </span> </li> <li> <span class="vars">$objGrid</span><span>->searchby(</span><span class="string">"name,lastname"</span><span>); </span> </li> <li class="alt"> <span class="comment">//需要读取的表 </span><span> </span> </li> <li> <span class="vars">$objGrid</span><span>->tabla(</span><span class="string">"employees"</span><span>); </span> </li> <li class="alt"> <span class="comment">//索引值用于修改数据 </span><span> </span> </li> <li> <span class="vars">$objGrid</span><span>->keyfield(</span><span class="string">"id"</span><span>); </span> </li> <li class="alt"> <span class="comment">//分页显示行数 </span><span> </span> </li> <li> <span class="vars">$objGrid</span><span>->datarows(20); </span> </li> <li class="alt"> <span class="comment">//默认排序方式 </span><span> </span> </li> <li> <span class="vars">$objGrid</span><span>->orderby(</span><span class="string">"name"</span><span>, </span><span class="string">"ASC"</span><span>); </span> </li> <li class="alt"> <span class="comment">//显示列设置,相关设置可参考phpmydatagrid.class.php </span><span> </span> </li> <li> <span class="vars">$objGrid</span><span>->FormatColumn(</span><span class="string">"id"</span><span>, </span><span class="string">"ID Employee"</span><span>, 5, 5, 1, </span><span class="string">"50"</span><span>, </span><span class="string">"center"</span><span>, </span><span class="string">"integer"</span><span>); </span> </li> <li class="alt"> <span class="vars">$objGrid</span><span>->FormatColumn(</span><span class="string">"name"</span><span>, </span><span class="string">"Name"</span><span>, 30, 30, 0, </span><span class="string">"150"</span><span>, </span><span class="string">"left"</span><span>); </span> </li> <li> <span class="vars">$objGrid</span><span>->FormatColumn(</span><span class="string">"lastname"</span><span>, </span><span class="string">"Last name"</span><span>, 30, 30, 0, </span><span class="string">"150"</span><span>, </span><span class="string">"left"</span><span>); </span> </li> <li class="alt"> <span class="vars">$objGrid</span><span>->FormatColumn(</span><span class="string">"age"</span><span>, </span><span class="string">"Age"</span><span>, 5, 5, 0, </span><span class="string">"50"</span><span>, </span><span class="string">"right"</span><span>);</span><span class="comment">//自定义日期格式 </span><span> </span> </li> <li> <span class="vars">$objGrid</span><span>->FormatColumn(</span><span class="string">"afiliation"</span><span>, </span><span class="string">"Afiliation Date"</span><span>, 10, 10, 0, </span><span class="string">"100"</span><span>, </span><span class="string">"center"</span><span>, </span><span class="string">"date:dmy:/"</span><span>);</span><span class="comment">//编辑时可以自定义为<select>模式 </select></span><span> </span> </li> <li class="alt"> <span class="vars">$objGrid</span><span>->FormatColumn(</span><span class="string">"status"</span><span>, </span><span class="string">"Status"</span><span>, 5, 5, 0, </span><span class="string">"60"</span><span>, </span><span class="string">"left"</span><span>, </span><span class="string">"select:1_Single:2_Married:3_Divorced"</span><span>); </span> </li> <li> <span class="comment">//编辑时可以自定义为<checkbox>模式 </checkbox></span><span> </span> </li> <li class="alt"> <span class="vars">$objGrid</span><span>->FormatColumn(</span><span class="string">"active"</span><span>, </span><span class="string">"Active"</span><span>, 2, 2, 0,</span><span class="string">"50"</span><span>, </span><span class="string">"center"</span><span>, </span><span class="string">"check:No:Yes"</span><span>);</span><span class="comment">//自定义货币显示形式 </span><span> </span> </li> <li> <span class="vars">$objGrid</span><span>->FormatColumn(</span><span class="string">"salary"</span><span>, </span><span class="string">"Salary"</span><span>, 10, 10, 0, </span><span class="string">"90"</span><span>, </span><span class="string">"right"</span><span>, </span><span class="string">"money:€"</span><span>);</span><span class="comment">//将数据以柱状图显示 </span><span> </span> </li> <li class="alt"> <span class="vars">$objGrid</span><span>->FormatColumn(</span><span class="string">"workeddays"</span><span>, </span><span class="string">"Work days"</span><span>, 5, 2, 0, </span><span class="string">"50"</span><span>, </span><span class="string">"right"</span><span>, </span><span class="string">"chart:percent:val:31"</span><span>); </span> </li> <li> <span class="vars">$objGrid</span><span>->checkable(); </span> </li> <li class="alt"> <span class="vars">$objGrid</span><span>->setHeader(); </span> </li> <li> <span class="vars">$objGrid</span><span>->ajax(</span><span class="string">'silent'</span><span>); </span> </li> <li class="alt"> <span class="func">echo</span><span> ' </span> </li> <li><span> <title>PHPDataGrid</title> </span></li> <li class="alt"> <span> <div> <span class="string">"center"</span><span>><br>'; </span><li> <span class="comment">//生成DataGrid </span><span> </span> </li> <li class="alt"> <span class="vars">$objGrid</span><span>->grid(); </span> </li> <li> <span class="func">echo</span><span> </span><span class="string">'</span> </li> </div>'</span><span>;</span><span class="comment">//关闭数据库连接 </span><span> </span> </li> <li class="alt"> <span class="vars">$objGrid</span><span>->desconectar(); </span> </li> <li><span>?> </span></li> </ol>
3. 基于Oracle简介
对于Oracle的读取主要是把phpmydatagrid.class.php中与MySQL连接的函数修改为Oracle,本篇是通过sqlrelay(可参考

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

PHP 8.4 apporte plusieurs nouvelles fonctionnalités, améliorations de sécurité et de performances avec une bonne quantité de dépréciations et de suppressions de fonctionnalités. Ce guide explique comment installer PHP 8.4 ou mettre à niveau vers PHP 8.4 sur Ubuntu, Debian ou leurs dérivés. Bien qu'il soit possible de compiler PHP à partir des sources, son installation à partir d'un référentiel APT comme expliqué ci-dessous est souvent plus rapide et plus sécurisée car ces référentiels fourniront les dernières corrections de bogues et mises à jour de sécurité à l'avenir.

Visual Studio Code, également connu sous le nom de VS Code, est un éditeur de code source gratuit – ou environnement de développement intégré (IDE) – disponible pour tous les principaux systèmes d'exploitation. Avec une large collection d'extensions pour de nombreux langages de programmation, VS Code peut être c

Ce tutoriel montre comment traiter efficacement les documents XML à l'aide de PHP. XML (Language de balisage extensible) est un langage de balisage basé sur le texte polyvalent conçu à la fois pour la lisibilité humaine et l'analyse de la machine. Il est couramment utilisé pour le stockage de données et

JWT est une norme ouverte basée sur JSON, utilisée pour transmettre en toute sécurité des informations entre les parties, principalement pour l'authentification de l'identité et l'échange d'informations. 1. JWT se compose de trois parties: en-tête, charge utile et signature. 2. Le principe de travail de JWT comprend trois étapes: la génération de JWT, la vérification de la charge utile JWT et l'analyse. 3. Lorsque vous utilisez JWT pour l'authentification en PHP, JWT peut être généré et vérifié, et les informations sur le rôle et l'autorisation des utilisateurs peuvent être incluses dans l'utilisation avancée. 4. Les erreurs courantes incluent une défaillance de vérification de signature, l'expiration des jetons et la charge utile surdimensionnée. Les compétences de débogage incluent l'utilisation des outils de débogage et de l'exploitation forestière. 5. L'optimisation des performances et les meilleures pratiques incluent l'utilisation des algorithmes de signature appropriés, la définition des périodes de validité raisonnablement,

Si vous êtes un développeur PHP expérimenté, vous aurez peut-être le sentiment d'y être déjà allé et de l'avoir déjà fait. Vous avez développé un nombre important d'applications, débogué des millions de lignes de code et peaufiné de nombreux scripts pour réaliser des opérations.

Une chaîne est une séquence de caractères, y compris des lettres, des nombres et des symboles. Ce tutoriel apprendra à calculer le nombre de voyelles dans une chaîne donnée en PHP en utilisant différentes méthodes. Les voyelles en anglais sont a, e, i, o, u, et elles peuvent être en majuscules ou en minuscules. Qu'est-ce qu'une voyelle? Les voyelles sont des caractères alphabétiques qui représentent une prononciation spécifique. Il y a cinq voyelles en anglais, y compris les majuscules et les minuscules: a, e, i, o, u Exemple 1 Entrée: String = "TutorialSpoint" Sortie: 6 expliquer Les voyelles dans la chaîne "TutorialSpoint" sont u, o, i, a, o, i. Il y a 6 yuans au total

Liaison statique (statique: :) implémente la liaison statique tardive (LSB) dans PHP, permettant à des classes d'appel d'être référencées dans des contextes statiques plutôt que de définir des classes. 1) Le processus d'analyse est effectué au moment de l'exécution, 2) Recherchez la classe d'appel dans la relation de succession, 3) il peut apporter des frais généraux de performance.

Quelles sont les méthodes magiques de PHP? Les méthodes magiques de PHP incluent: 1. \ _ \ _ Construct, utilisé pour initialiser les objets; 2. \ _ \ _ Destruct, utilisé pour nettoyer les ressources; 3. \ _ \ _ Appel, gérer les appels de méthode inexistants; 4. \ _ \ _ GET, Implémentez l'accès à l'attribut dynamique; 5. \ _ \ _ SET, Implémentez les paramètres d'attribut dynamique. Ces méthodes sont automatiquement appelées dans certaines situations, améliorant la flexibilité et l'efficacité du code.
