国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

Maison développement back-end tutoriel php 關(guān)于PHP中操作MySQL數(shù)據(jù)庫(kù)的一些要注意的問(wèn)題_PHP教程

關(guān)于PHP中操作MySQL數(shù)據(jù)庫(kù)的一些要注意的問(wèn)題_PHP教程

Jul 21, 2016 pm 04:09 PM
mysql php un à propos fonctionner base de données Avis de vouloir question


關(guān)于PHP中操作MySQL數(shù)據(jù)庫(kù)的一些要注意的問(wèn)題 1. 分號(hào)的例外

對(duì)于 MySQL ,第一件你必須牢記的是它的每一行命令都是用分號(hào) (;) 作為結(jié)束的,但……沒(méi)有完全絕對(duì)的事,在這兒也是一樣,當(dāng)一行 MySQL 被插入在 PHP 代碼中時(shí),最好把后面的分號(hào)省略掉,例如:

mysql_query ("INSERT INTO tablename (first_name, last_name) VALUES ('$first_name', $last_name')");

這是因?yàn)?PHP 也是以分號(hào)作為一行的結(jié)束的,額外的分號(hào)有時(shí)會(huì)讓 PHP 的語(yǔ)法分析器搞不明白,所以還是省略掉的好。在這種情況下,雖然省略了分號(hào),但是 PHP 在執(zhí)行 MySQL 命令時(shí)會(huì)自動(dòng)的幫你加上的。

另外還有一個(gè)不要加分號(hào)的情況。當(dāng)你想把要字段的豎者排列顯示下來(lái),而不是像通常的那樣橫著排列時(shí),你可以用 G 來(lái)結(jié)束一行 SQL 語(yǔ)句,這時(shí)就用不上分號(hào)了,例如:

SELECT * FROM PENPALS WHERE USER_ID = 1G


2. TEXT、DATE、和 SET 數(shù)據(jù)類型

MySQL 數(shù)據(jù)表的字段必須有定義一個(gè)數(shù)據(jù)類型。這有大約 25 種選擇,大部分都是直接明了的,就不多費(fèi)口舌了。但有幾個(gè)有必要提一下。

TEXT 不是一種數(shù)據(jù)類型,雖然可能有些書(shū)上是這么說(shuō)的。它實(shí)際上應(yīng)該是“ LONG VARCHAR ”或者“ MEDIUMTEXT ”。

DATE 數(shù)據(jù)類型的格式是 YYYY-MM-DD ,比如: 1999-12-08 。你可以很容易的用 date 函數(shù)來(lái)得到這種格式的當(dāng)前系統(tǒng)時(shí)間: date("Y-m-d")

并且,在 DATA 數(shù)據(jù)類型之間可以作減法,得到相差的時(shí)間天數(shù):

$age = ($current_date - $birthdate);

集合 SET 是一個(gè)有用的數(shù)據(jù)類型,它和枚舉 ENUM 有點(diǎn)相似,只不過(guò)是 SET 能夠保存多個(gè)值而 ENUM 只能保存一個(gè)值而已。而且, SET 類型最多只能夠有 64 個(gè)預(yù)定的值,而 ENUM 類型卻能夠處理最多 65,535 個(gè)預(yù)定義的值。而如果需要有大于 64 個(gè)值的集合,該怎么辦呢?這時(shí)就需要定義多個(gè)集合來(lái)一起解決這個(gè)問(wèn)題了。

3. 通配符

SQL 的通配符有兩種:“ * ”和“ % ”。分別用在不同的情況下。例如:如果你想看到數(shù)據(jù)庫(kù)的所有內(nèi)容,可以像這樣來(lái)查詢:

SELECT * FROM dbname WHERE USER_ID LIKE '%';

這兒,兩個(gè)通配符都被用上了。他們表示相同的意思 ?? 都是用來(lái)匹配任何的字符串,但是他們用在不同的上下文中?!?* ”用來(lái)匹配字段名,而“ % ”用來(lái)匹配字段值。另外一個(gè)不容易引起注意的地方是“ % ”通配符需要和 LIKE 關(guān)鍵字一起使用。

還有一個(gè)通配符,就是下劃線“ _ ”,它代表的意思和上面不同,是用來(lái)匹配任何單個(gè)的字符的。


4. NOT NULL 和空記錄

如果用戶在沒(méi)有填任何東西的情況下按了 submit 按鈕,會(huì)怎樣呢?如果你確實(shí)需要一個(gè)值,那么可以用客戶端腳本或者服務(wù)器端腳本來(lái)進(jìn)行數(shù)據(jù)驗(yàn)證,這一點(diǎn)在前面已經(jīng)說(shuō)過(guò)了。但是,在數(shù)據(jù)庫(kù)中卻是允許一些字段被空出來(lái)什么也不填。對(duì)此類紀(jì)錄, MySQL 將要為之執(zhí)行一些事情:插入值 NULL ,這是缺省的操作。
如果你在字段定義中為之聲明了 NOT NULL (在建立或者修改這個(gè)字段的時(shí)候), MySQL 將把這個(gè)字段空出來(lái)什么東西也不填。對(duì)于一個(gè) ENUM 枚舉類型的字段,如果你為之聲明了 NOT NULL , MySQL 將把枚舉集的第一個(gè)值插入到字段中。也就是說(shuō), MySQL 把枚舉集的第一個(gè)值作為這個(gè)枚舉類型的缺省值。

一個(gè)值為 NULL 的紀(jì)錄和一個(gè)空紀(jì)錄是有一些區(qū)別的。 % 通配符可以匹配空紀(jì)錄,但是卻不能匹配 NULL 紀(jì)錄。在某些時(shí)候,這種區(qū)別會(huì)造成一些意想不到的后果。就我的經(jīng)驗(yàn)而言,任何字段都應(yīng)該聲明為 NOT NULL 。這樣下面的 SELECT 查詢語(yǔ)句就能夠正常運(yùn)轉(zhuǎn)了:

if (!$CITY) {$CITY = "%";}

$selectresult = mysql_query ("SELECT * FROM dbname
WHERE FIRST_NAME = ' 柳 '
AND LAST_NAME = ' 如風(fēng) '
AND CITY LIKE '$CITY'
");

在第一行中,如果用戶沒(méi)有指定一個(gè) CITY 值,那么就會(huì)用通配符 % 來(lái)代入 CITY 變量,這樣搜索時(shí)就會(huì)把任何的 CITY 值都考慮進(jìn)去,甚至包括那些 CITY 字段為空的紀(jì)錄。

但是如果有一些紀(jì)錄,它的 CITY 字段值是 NULL ,這時(shí)問(wèn)題就出現(xiàn)了。上面的查詢是不能夠找到這些字段的。問(wèn)題的一個(gè)解決辦法可以是這樣:

if (!$CITY) { $CITY = "%"; }

$selectresult = mysql_query ("SELECT * FROM dbname
WHERE FIRST_NAME = ' 柳 '
AND LAST_NAME = ' 如風(fēng) '
AND (CITY LIKE '$CITY' OR CITY IS NULL)
");

注意在搜索 NULL 時(shí),必須用“ IS ”關(guān)鍵字,而 LIKE 時(shí)不會(huì)正常工作的。

在最后要提到的是,如果你在加入或者修改一個(gè)新的字段之前,數(shù)據(jù)庫(kù)中已經(jīng)有了一些記錄了,這時(shí)新加入的字段在原來(lái)的紀(jì)錄中的值,可能是 NULL ,也可能為空。這也算是 MySQL 的一個(gè) Bug 吧,所以在這種情況下,使用 SELECT 查詢要特別的小心。

www.bkjia.comtruehttp://www.bkjia.com/PHPjc/314369.htmlTechArticle關(guān)于PHP中操作MySQL數(shù)據(jù)庫(kù)的一些要注意的問(wèn)題1. 分號(hào)的例外 對(duì)于 MySQL ,第一件你必須牢記的是它的每一行命令都是用分號(hào) (;) 作為結(jié)束的...
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefa?on, veuillez contacter admin@php.cn

Outils d'IA chauds

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

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

Bloc-notes++7.3.1

éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

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

Sujets chauds

Tutoriel PHP
1502
276
Tigne de performance de cartographie relationnelle d'objet (ORM) dans PHP Tigne de performance de cartographie relationnelle d'objet (ORM) dans PHP Jul 29, 2025 am 05:00 AM

é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.

VSCODE Settings.json Emplacement VSCODE Settings.json Emplacement Aug 01, 2025 am 06:12 AM

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

Une plongée profonde dans le mécanisme de collecte interne de PHP Une plongée profonde dans le mécanisme de collecte interne de PHP Jul 28, 2025 am 04:44 AM

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.

La révolution sans serveur: déploiement des applications PHP évolutives avec BREF La révolution sans serveur: déploiement des applications PHP évolutives avec BREF Jul 28, 2025 am 04:39 AM

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.

Construire des objets immuables en PHP avec des propriétés en lecture Construire des objets immuables en PHP avec des propriétés en lecture Jul 30, 2025 am 05:40 AM

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

Intégration de PHP aux modèles d'apprentissage automatique Intégration de PHP aux modèles d'apprentissage automatique Jul 28, 2025 am 04:37 AM

UseArestapitobridgePhpandmlModelsByrunningTheModelinpythonviaflaskorfastapiandCallingitfrompsingCurlorBuzzle.2.Runpythonscripts est ventilateur

Exemple de bascule du mode sombre CSS Exemple de bascule du mode sombre CSS Jul 30, 2025 am 05:28 AM

Tout d'abord, utilisez JavaScript pour obtenir les préférences du système utilisateur et les paramètres de thème stockés localement et initialiser le thème de la page; 1. La structure HTML contient un bouton pour déclencher la commutation du sujet; 2. CSS utilise: Root pour définir des variables de thème brillantes, la classe de mode. Dark définit les variables de thème sombres et applique ces variables via var (); 3. JavaScript détecte préfère-Color-Scheme et lit LocalStorage pour déterminer le thème initial; 4. Communiquez la classe en mode noir sur l'élément HTML lorsque vous cliquez sur le bouton et enregistre l'état actuel vers LocalStorage; 5. Tous les changements de couleur sont accompagnés d'une animation de transition de 0,3 seconde pour améliorer l'utilisateur

Comment semer une base de données à Laravel? Comment semer une base de données à Laravel? Jul 28, 2025 am 04:23 AM

Créer un fichier de semences: utilisez PhPartisanMake: SeeDerUserSederder pour générer la classe Seeder et insérer des données via la requête Model Factory ou Database dans la méthode d'exécution; 2. Appelez un autre Seeder dans DatabaseSeseder: enregistrez USERSEDEDER, POSTSEEDER, etc. dans l'ordre via $ this-> call () pour s'assurer que la dépendance est correcte; 3. Exécutez Seeder: Exécutez PHPARTISANDB: graines pour exécuter tous les semants enregistrés, ou utilisez du phpartisanMigrate: Fresh - Seed pour réinitialiser et remplir les données; 4

See all articles