php+mysql實現(xiàn)的二級聯(lián)動菜單效果詳解,mysql聯(lián)動_PHP教程
Jul 12, 2016 am 08:52 AMphp+mysql實現(xiàn)的二級聯(lián)動菜單效果詳解,mysql聯(lián)動
本文實例講述了php+mysql實現(xiàn)的二級聯(lián)動菜單效果。分享給大家供大家參考,具體如下:
<!--php+mysql二級聯(lián)動--> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> <title>生成學(xué)院專業(yè)級聯(lián)下拉菜單測試 </title> </head> <body> <? // /*********************************************** ** 功 能: php+mysql+javascript實現(xiàn)學(xué)院專業(yè)二級級聯(lián)下拉框 ** 數(shù)據(jù)庫:數(shù)據(jù)庫名( dms)、數(shù)據(jù)表( colleges、 majors) ** 表 colleges中字段: college_id( id編號)、 name(學(xué)院名) ** 表 majors中的字段: major_id( id編號)、 college_id(學(xué)院 ID)、 name(學(xué)院名) ** version 1.0 ** 作 者: wu yaowen ***********************************************/ //****************** 連接選擇數(shù)據(jù)庫 *************** $link = mysql_connect("localhost", "root", "123456") or die("Could not connect : " . mysql_error()); mysql_select_db("dms") or die("Could not select database"); //******************提取學(xué)院信息 ****************** $queryCol = "select * from colleges order by college_id "; mysql_query("SET NAMES 'gb2312'"); $result1 = mysql_query($queryCol) or die("Query failed : " . mysql_error()); $colleges = array(); while( $row1 = mysql_fetch_array($result1) ) { $colleges[] = $row1; } //print_r ($forum_data); mysql_free_result($result1); //**************獲取專業(yè)信息 ************** $queryMaj = "select * from majors order by college_id desc"; mysql_query("SET NAMES 'gb2312'"); if( !($result2 = mysql_query($queryMaj)) ) { die('Could not query t_city list'); } $majors = array(); while( $row2 = mysql_fetch_array($result2) ) { $majors[] = $row2; } mysql_free_result($result2); ?> <!--************ JavaScript處理 college-onChange *************--> <script language = "JavaScript"> var majorCount; // 存儲專業(yè)記錄條數(shù) // form_majors[] 儲存專業(yè) major數(shù)據(jù),如 {(1,1,電子商務(wù) ),(4,1,計算機科學(xué) ),(3,2,古典文學(xué) )} form_majors = new Array(); <?php $num2 = count($majors); // $num2 獲取專業(yè)表中記錄的個數(shù) ?> majorCount = <?php echo $num2;?>; <? for($j=0;$j<$num2;$j++) // 從 0開始取出上面 majors[]中存儲的專業(yè)數(shù)據(jù)填充數(shù)組 { ?> form_majors[<?echo $j;?>] = new Array("<?echo $majors[$j]['major_id'];?>","<?echo $majors[$j]['college_id'];?>","<?echo $majors[$j]['name'];?>"); <?php } ?> function changeCollege(college_id) { document.stu_add_form.major.length = 0; var id=id; var j; document.stu_add_form.major.options[0] = new Option('==選擇專業(yè) ==',''); // label的 value為空 ' ' for (j=0;j < majorCount; j++) // 從 0開始判斷 { if (form_majors[j][1] == college_id) // if college_id等于選擇的學(xué)院的 id { document.stu_add_form.major.options[document.stu_add_form.major.length] = new Option(form_majors[j][2], form_majors[j][0]); } } } </script> <!--********************頁面表單 *************************--> <form name="stu_add_form" method="post"> 選擇: <select name="college" onChange="changeCollege(document.stu_add_form.college.options[document.stu_add_form.college.selectedIndex].value)" size="1"> <option selected>==請選擇學(xué)院 ==</option> <?php $num = count($colleges); for($i=0;$i<$num;$i++) { ?> <option value="<?echo $colleges[$i]['college_id'];?>"><?echo $colleges[$i]['name'];?></option> <? } ?> </select> <select name="major"> <option selected value="">==選擇專業(yè) ==</option> </select> </form> </body> </html>
sql語句:
-- -- 表的結(jié)構(gòu) `colleges` -- CREATE TABLE IF NOT EXISTS `colleges` ( `college_id` int(8) NOT NULL auto_increment COMMENT '學(xué)院編號自動增加', `name` varchar(40) NOT NULL COMMENT '學(xué)院名稱', PRIMARY KEY (`college_id`), UNIQUE KEY `name` (`name`) ) ENGINE=InnoDB DEFAULT CHARSET=gb2312 AUTO_INCREMENT=7 ; -- -- 導(dǎo)出表中的數(shù)據(jù) `colleges` -- INSERT INTO `colleges` (`college_id`, `name`) VALUES (4, '化學(xué)與化工學(xué)院'), (1, '計算機與信息科學(xué)學(xué)院'), (6, '美術(shù)學(xué)院'), (2, '文學(xué)院'), (5, '音樂學(xué)院'), (3, '政治與公共管理學(xué)院'); -- -- 表的結(jié)構(gòu) `majors` -- CREATE TABLE IF NOT EXISTS `majors` ( `major_id` int(8) NOT NULL auto_increment COMMENT '專業(yè)號,自動增加', `name` varchar(40) NOT NULL COMMENT '專業(yè)名', `college_id` int(8) default NULL COMMENT '所在學(xué)院', `counsellor_id` int(10) default NULL COMMENT '輔導(dǎo)員', PRIMARY KEY (`major_id`), UNIQUE KEY `college_id` (`college_id`,`counsellor_id`) ) ENGINE=InnoDB DEFAULT CHARSET=gb2312 AUTO_INCREMENT=8 ; -- -- 導(dǎo)出表中的數(shù)據(jù) `majors` -- INSERT INTO `majors` (`major_id`, `name`, `college_id`, `counsellor_id`) VALUES (1, '電子商務(wù)', 1, 1), (2, '音樂視唱', 5, 1), (3, '古典文學(xué)', 2, 1), (4, '計算機科學(xué)', 1, NULL), (5, '自動化', 1, NULL), (6, '現(xiàn)代文學(xué)', 2, NULL), (7, '新聞寫作', 2, NULL);
更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《PHP基于pdo操作數(shù)據(jù)庫技巧總結(jié)》、《PHP+MongoDB數(shù)據(jù)庫操作技巧大全》、《php面向?qū)ο蟪绦蛟O(shè)計入門教程》、《php字符串(string)用法總結(jié)》、《php+mysql數(shù)據(jù)庫操作入門教程》及《php常見數(shù)據(jù)庫操作技巧匯總》
希望本文所述對大家PHP程序設(shè)計有所幫助。

Outils d'IA chauds

Undress AI Tool
Images de déshabillage gratuites

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.

Clothoff.io
Dissolvant de vêtements AI

Video Face Swap
échangez les visages dans n'importe quelle vidéo sans effort grace à notre outil d'échange de visage AI entièrement gratuit?!

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)

évitez N 1 Problèmes de requête, réduisez le nombre de requêtes de base de données en chargeant à l'avance des données associées; 2. Sélectionnez uniquement les champs requis pour éviter de charger des entités complètes pour enregistrer la mémoire et la bande passante; 3. Utilisez raisonnablement les stratégies de cache, telles que le cache secondaire de la doctrine ou les résultats de requête à haute fréquence de cache de Doctrine; 4. Optimisez le cycle de vie de l'entité et appelez régulièrement () pour libérer la mémoire pour empêcher le débordement de la mémoire; 5. Assurez-vous que l'indice de base de données existe et analysez les instructions SQL générées pour éviter les requêtes inefficaces; 6. Désactiver le suivi automatique des changements dans les scénarios où les modifications ne sont pas nécessaires et utilisez des tableaux ou des modes légers pour améliorer les performances. L'utilisation correcte de l'ORM nécessite de combiner la surveillance SQL, la mise en cache, le traitement par lots et l'optimisation appropriée pour garantir les performances de l'application tout en maintenant l'efficacité du développement.

Pour construire un microservice PHP flexible, vous devez utiliser RabbitMQ pour obtenir une communication asynchrone, 1. Découplez le service via des files d'attente de messages pour éviter les défaillances en cascade; 2. Configurer des files d'attente persistantes, des messages persistants, une confirmation de libération et un ACK manuel pour assurer la fiabilité; 3. Utilisez des échecs de traitement de la sécurité de la file d'attente de la file d'attente de la file d'attente de la file d'attente de la file d'attente de la file d'attente de la file d'attente de la file d'attente de la file d'attente; 4. Utilisez des outils tels que SuperVisord pour protéger les processus de consommation et permettre des mécanismes de battements cardiaques pour assurer la santé des services; et finalement réaliser la capacité du système à opérer en continu en échecs.

L'utilisation de l'image de base PHP correcte et la configuration d'un environnement Docker sécurisé et optimisé sont la clé pour obtenir la production prête. 1. Sélectionnez PHP: 8.3-FPM-Alpine comme image de base pour réduire la surface d'attaque et améliorer les performances; 2. Désactiver les fonctions dangereuses via PHP.ini personnalisé, désactiver l'affichage des erreurs et activer Opcache et Jit pour améliorer la sécurité et les performances; 3. Utilisez Nginx comme proxy inverse pour restreindre l'accès aux fichiers sensibles et transférer correctement les demandes PHP à PHP-FPM; 4. Utilisez des images d'optimisation en plusieurs étapes pour supprimer les dépendances de développement et configurez les utilisateurs non racinaires pour exécuter des conteneurs; 5. Supervisord facultatif pour gérer plusieurs processus tels que Cron; 6. Vérifiez qu'aucune fuite d'informations sensibles avant le déploiement

Le fichier SetfitS.JSON est situé dans le chemin de niveau utilisateur ou au niveau de l'espace de travail et est utilisé pour personnaliser les paramètres VScode. 1. Chemin de niveau utilisateur: Windows est C: \ Users \\ AppData \ Roaming \ Code \ User \ Settings.json, macOS est /users//library/applicationsupport/code/user/settings.json, Linux est /home//.config/code/user/settings.json; 2. Chemin au niveau de l'espace de travail: .vscode / Paramètres dans le répertoire racine du projet

Le mécanisme de collecte des ordures de PHP est basé sur le comptage de référence, mais les références circulaires doivent être traitées par un collecteur de déchets circulaires périodique; 1. Le nombre de références libère la mémoire immédiatement lorsqu'il n'y a pas de référence à la variable; 2. Référence La référence fait que la mémoire ne peut pas être automatiquement libérée, et cela dépend de GC pour le détecter et le nettoyer; 3. GC est déclenché lorsque la "racine possible" Zval atteint le seuil ou appelle manuellement gc_collect_cycles (); 4. Les applications PHP à long terme devraient surveiller GC_Status () et appeler GC_COLLECT_CYCLES () à temps pour éviter la fuite de mémoire; 5. Les meilleures pratiques incluent d'éviter les références circulaires, en utilisant gc_disable () pour optimiser les zones clés de performance et les objets de déréférence via la méthode Clear () d'Orm.

BREF permet aux développeurs PHP de créer des applications évolutives et rentables sans gérer les serveurs. 1.BREF apporte PHP à Awslambda en fournissant une couche d'exécution PHP optimisée, prend en charge PHP8.3 et d'autres versions, et s'intègre de manière transparente à des frameworks tels que Laravel et Symfony; 2. Les étapes de déploiement incluent: l'installation de BREF à l'aide de composer, configurer Serverless.yml pour définir des fonctions et des événements, tels que les points de terminaison HTTP et les commandes artisanales; 3. Exécutez la commande ServerlessDeploy pour terminer le déploiement, configurez automatiquement Apigeway et générez des URL d'accès; 4. Pour les restrictions de lambda, BREF fournit des solutions.

ReadonlypropertiesInphp8.2CanlybeassignedonceinthestrustructoratDeclarationandcannotBemodifiedAfterward, applicationmutabilityaThelanguageLevel.2.Toachievedeep-immutability, webutableTypeSlikEarrayinArrayobjectorUSustomymutability, webutilletypeslikearraysinarrayobjectoruseseCustomMutabeColEctionSucha.

UseArestapitobridgePhpandmlModelsByrunningTheModelinpythonviaflaskorfastapiandCallingitfrompsingCurlorBuzzle.2.Runpythonscripts est ventilateur
