検索
ホームページバックエンド開発PHPチュートリアルPHP 開発における 2 つの実践的な SQL_PHP チュートリアル

PHP 開発における 2 つの実践的な SQL_PHP チュートリアル

Jul 13, 2016 pm 04:58 PM
phpsql関数成し遂げる開発する比較する使用必要プロジェクト開発

過去 2 日間のプロジェクト開発では、いくつかの実用的な関数を実装する必要があり、2 つの SQL を使用しました。要約すると、次回は忘れてしまうのではないかと思います。

1. 送信されたコンテンツと一致するコンテンツをデータベースから取得します

たとえば、送信されたデータが「水泳」の場合、データベース内の「水泳が好き」という単語は一致するとみなされますが、これではまだ十分ではありません。たとえば、「週末に水泳に行きます」と入力した場合、はデータベース内で「泳いでいる」です。 の内容は実際には似たような意味ですが、like を使用してそれを見つけることができなかったので、関数にカプセル化された次の SQL を考えました:

関数 getRelationTags($tagTitle,$cols="*")
{
$titleFeildStrLen = 24; //3*8 漢字 4 文字または 24 文字
if ("" == $tagTitle) return false;

$sql = "select $cols from ".$TableName." where title != '' and (LOCATE(title,'$tagTitle') or ((issystem = 1 or LENGTH(title) $data =& $db->getAll($sql);
if(DB::isError($data)){
return $this->returnValue($data->getMessage());
}その他{
$data を返します;
}
}

SQLを見てください:

select $cols from ".$TableName." where title != '' and (LOCATE(title,'$tagTitle') or ((issystem = 1 or LENGTH(title)
実際には、これは 2 回の照合で、1 回目は送信されたタグとデータベース内のタグを照合する前方照合で、2 回目はデータベース内のタグと送信されたタグを照合します。

重要なのは LOCATE() 関数であり、mysql のエンコーディングが次のとおりであるため、この関数も長さを制限します。
名前「utf8」を設定します

utf8 なので、中国語の文字は 3 バイトを使用し、文字は 1 バイトしか使用しないため、上記は次のようになります:

$titleFeildStrLen = 24;

つまり、24 文字の範囲内の 8 つの漢字とタグを照合します。


2. 類似ソート

たとえば、データベースの内容は次のとおりです:

北京 1023 1

天津 2301 1

上海 3450 1

天津 4520 1

北京 3902 1

次に、すべての都市データを抽出し、各都市データの合計数を他の都市の合計数と比較して、並べ替える必要があります。

関数コードは次のとおりです:

関数 getMostCity($num)

{

$sql = "select count(id) as num,city from ".$TableName." where city != '' group by city order by num desc limit 0,$num;";

$data =& $db->getAll($sql);

if($db->isError($data))

false を返します;

それ以外

$data を返します;

}

上記の SQL ステートメントに注目してみましょう:

select count(id) as num,city from ".$TableName." where city != '' 数値による順序でグループ化 制限 0,$num

中心となるのは都市ごとのグループで、類似した都市を収集し、最も多い都市から最も少ない都市へと並べ替えます。

http://www.bkjia.com/PHPjc/631404.htmlwww.bkjia.comtru​​ehttp://www.bkjia.com/PHPjc/631404.html技術記事この 2 日間のプロジェクト開発では、いくつかの実用的な関数を実装する必要があり、要約すると、次回は忘れてしまうのではないかと心配しています。 1. 送信されたコンテンツと一致するコンテンツをデータベースで検索します...
声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
PHPメール:ステップバイステップ送信ガイドPHPメール:ステップバイステップ送信ガイドMay 09, 2025 am 12:14 AM

PhpisusedForsedingEmailsDueToitsIttegration withServerMailServicesAndExternalSmtpproviders、自動化とMarketingCampaign.1)SetupYourphpenvironment withebeBironment witheBiserverandphp、保証

PHP経由で電子メールを送信する方法:例とコードPHP経由で電子メールを送信する方法:例とコードMay 09, 2025 am 12:13 AM

メールを送信する最良の方法は、PHPMailerライブラリを使用することです。 1)Mail()関数を使用することはシンプルですが信頼できないため、電子メールがスパムを入力するか、配信できない場合があります。 2)PHPMailerは、より良い制御と信頼性を提供し、HTMLメール、添付ファイル、SMTP認証をサポートします。 3)SMTP設定が正しく構成されていることを確認し、暗号化(StartTLSやSSL/TLSなど)を使用してセキュリティを強化します。 4)大量の電子メールについては、メールキューシステムを使用してパフォーマンスを最適化することを検討してください。

高度なPHPメール:カスタムヘッダーと機能高度なPHPメール:カスタムヘッダーと機能May 09, 2025 am 12:13 AM

customedersandaddadvancedfeaturesinphpemailentalitylivainability.1)customederadddetadata fortrackingandcategorization.2)htmLemailsallowStingtintintintintintinteractivity.3)添付物質の添付物質の添付

php&smtpでメールを送信するためのガイドphp&smtpでメールを送信するためのガイドMay 09, 2025 am 12:06 AM

PHPとSMTPを使用してメールを送信することは、PHPMailerライブラリを介して実現できます。 1)PHPMailerをインストールして構成する、2)SMTPサーバーの詳細を設定する、3)電子メールコンテンツを定義し、4)メールを送信してエラーを処理します。この方法を使用して、電子メールの信頼性とセキュリティを確保します。

PHPを使用して電子メールを送信する最良の方法は何ですか?PHPを使用して電子メールを送信する最良の方法は何ですか?May 08, 2025 am 12:21 AM

BestappRoachforseminginphpisusingthephpmailerlibrarydueToitsReliability、featurrichness、andeaseofuse.phpmailerSupportssmtpは、detairederorhandlingを提供します

PHPでの依存関係注射のベストプラクティスPHPでの依存関係注射のベストプラクティスMay 08, 2025 am 12:21 AM

依存関係注射(DI)を使用する理由は、コードのゆるい結合、テスト可能性、および保守性を促進するためです。 1)コンストラクターを使用して依存関係を注入します。2)サービスロケーターの使用を避け、3)依存関係噴射コンテナを使用して依存関係を管理する、4)依存関係を注入することでテスト可能性を向上させる、5)注入依存性を回避、6)パフォーマンスに対するDIの影響を考慮します。

PHPパフォーマンスのチューニングのヒントとコツPHPパフォーマンスのチューニングのヒントとコツMay 08, 2025 am 12:20 AM

phpperformancetuningisucial cuseenhancess andandandadsand。

PHP電子メールセキュリティ:電子メールを送信するためのベストプラクティスPHP電子メールセキュリティ:電子メールを送信するためのベストプラクティスMay 08, 2025 am 12:16 AM

bestpracticesforsendingemails securlyinphpinclude:1)sutureconsmttarttlsencryptionとの使用の使用、2)検証およびサンシジン化のinputStopReventinjectuctacks、3)adinitivedinitivedInemailsopenslsl、4)adlinglinglingemailoaに

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

AtomエディタMac版ダウンロード

AtomエディタMac版ダウンロード

最も人気のあるオープンソースエディター

SublimeText3 英語版

SublimeText3 英語版

推奨: Win バージョン、コードプロンプトをサポート!

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

Eclipse を SAP NetWeaver アプリケーション サーバーと統合します。

PhpStorm Mac バージョン

PhpStorm Mac バージョン

最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。