ホームページ >バックエンド開発 >PHPチュートリアル >動的WMLサイトの構築(3)_PHPチュートリアル
次に、ユーザーは次のファイル (index3.wml) に入力する必要があります。ユーザーには、被験者の名または教授の姓を入力するよう求めます。変数がページ間でどのように転送されるかに注意する必要があります。構文は少し複雑に見えますが、プロセス全体が複数のファイルを通じてどのように実行されるかを理解できます。
php
Header("Content-type: text/vnd.wap.wml");
header("Cache-Control: no-cache、must-revalidate"); echo ("?xml version='1.0'?>;");
>;DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.1//EN"
"http://www.wapforum. org/DTD/wml_1.1.xml" >; <WML>
<CARD id=card3 title=名前>
<? php
echo ("
挿入");
if (${$choice} == "姓") {
echo ("教授の姓(またはその一部).n"); {$choice} == "主題") {
echo ("主題 (またはその一部).n");
} else {
echo ("おそらく何か問題があるでしょう。n"); "<INPUT name='"${$choice}"' type='"text"'>"); >
<DO type="text" label="Go">
<GO href="query.wml" method="get">
php
echo ("
echo ("
? >
</GO>
</DO>
<P></P>
</CARD>
</WML>
<DO type="text" label="Go">
<GO href="index3.wml#card3" method="get">
php
echo ("
echo ("
</CARD>
</WML>
クエリコードを記述する
以下のファイルはクエリの処理を担当します。その名前は query.wml で、さらに詳しく分析します。
Header("Content-type: text/vnd.wap.wml");
printf("n");
printf("n");
printf("n");
// 次の行は、授業時間をクエリするための SQL ステートメントを構築するために使用されます
$consulting_tables =
"(professors left join tease on (professors.Id = teac.Id), subject)";
$consulting_columns =
"professors.Surname, Professors.Name, subject.Subject , ";
$consulting_columns .=
"subjects.Cod_number, Professors .Consulting_hour, Professors.Consulting_place";
$consulting_query=
"subjects.Cod_Subject = teac.Cod_subject ";
// 次の行は、クエリ テスト時間の SQL ステートメントを構築するために使用されます
$exams_tables= "(試験は残っています)教授に参加 ON (exams.Id = Professors.Id), subject)";
$exams_columns= "subjects.Subject, subject.Cod_number, Professors.Surname, ";
$exams_columns.= "professors.Name, Exam.Date, Exams.Time, Exams.Room, Exams.Test";
$exams_query= "exams.Cod_Subject = subject.Cod_Subject ";
// 次の行は、テスト スケジュールをクエリするための SQL ステートメントにクエリ制限を追加するために使用されます
if ($exams_data) {
switch($exams_data) {
case "subject":
$exams_query.= " and subject.Subject like '%$subject%'";
case "surname";
$ Exam_query.= " and Professors.Surname like '%$surname%'";
break;
}
}
// 次の行は、教育時間をクエリするための SQL ステートメントにクエリ制限を追加するために使用されます
if ($consulting_data ) {
switch($consulting_data) {
case "subject":
$consulting_query
.= " and subject.Subject like '%$subject%'";
case "surname":
$ Consulting_query.= " and Professors.Surname like '%$surname%'"
break;
}
}
// データベースとの接続を処理します
function connect($tables, $data, $condition_passed) {
//
// 次の行にパスワードとユーザー名を入力します
//
$db = mysql_pconnect("localhost","***","***");
// データベース名を入力します次の行
mysql_select_db("lanfranchi_co_uk",$db);
$sql = "SELECT $data FROM $tables WHERE $condition_passed order by Professors.Surname";
return $result;
// この関数は授業時間の wml コードを生成します
functionConsulting_print($consulting_result) {
global $file("n");受信時間
n" );
while ($myrow = mysql_fetch_row($consulting_result)) {
printf(" <P>$myrow[0], $myrow[1]</P>n");
printf( " <P>$myrow[2]</P>n");
printf("
$myrow[3]</P>n"); /P>n") ; $myrow[2], $myrow[3]</P>n") ; $myrow[0] $ myrow[4], $myrow [5]</P>n");
printf(" <P>$myrow[5]</P>n");
}
printf("</CARD>n");
}
// この関数テストスケジュールの wml を生成します。 コード
function print_exams($exams_result) {
global $file;
printf("
n");
while ($myrow = mysql_fetch_row($exams_result)) {
printf("
printf("
printf("
printf(" <P>$myrow[7]</P>n");
printf(" <P>$myrow[6] </P>n") ;
}
printf("</CARD>n");
}
// ティーチング時間またはテスト時間の選択時に確認し、データベースに接続し、生成する関数を呼び出しますwml コード
if ($consulting_data) {
$connection_result =
connect($consulting_tables, $consulting_columns, $consulting_query);
if ($exams_data) {
$connection_result =
connect($exams_tables, $exams_columns, $exams_query)
}
printf("n"); >
はい、終わりました。 MySQL データベースに基づいて最初の PHP/WML ページを作成しました。引き続き自分で練習してください。