ホームページ >バックエンド開発 >PHPチュートリアル >プロジェクトに取り組む中で学んだPHPの知識集_PHPチュートリアル
1 SQL ステートメントでは、制限を追加できます: left(text,20) はテキストの最初の 20 文字のみを取ります
2 ページングとして limit fromRecord、RecordNum を使用できます。たとえば、limit 0,30 は開始を意味します。最初のレコードの後で 30 レコードの走査を開始します。
3 2 つのテーブル間の接続は、x を使用して table1 join table2 (x は 2 つのテーブルの共通フィールドです)、または table1.x = table2 で table1 join table2 にすることができます。 x
4. PHP は $page = $_GET['page'];
または
を使用できます:
parse_str($_SERVER['QUERY_STRING'],$output); // まずクエリ文字列を配列に保存 $output
$page = $output[' page']; //次に、変数名に従ってインデックスを作成します
5 php の日付関数の比較は、実際には文字列の比較です。 6 mysql の日付型データは、2000-02-03、2002.02.03、2002.2.3、02.02.03、02.2.3 になります。つまり、月と日が必要であり、それらは次のように区切られている必要があります。 '-' または '。'。
7 data() を使用して時刻を取得すると、タイム ゾーンの問題が発生します。これは、php.ini のデフォルト設定が GTM US タイム ゾーンであるためです。
解決策: 変更できます。 php.ini:
[Date]
; 日付関数で使用するデフォルトのタイムゾーンを定義します
date.timezone = "Asia/Shanghai"
または、date() 関数を使用する場合は、date_Default_TimeZone_set("PRC") を追加します;
8段落 デバッグ時に、常に本文に「)」がないと表示されます。それは、intval($_POST['consumeType'])の問題です。データベースでは、フィールドは varchar(50) で、ID が 1、2 なので intval 関数を使用しますが、整数型と char 型は相互に変換できます。他の 2 つのテーブルでは、A5A、SP07-01 などですが、どうすれば int 型に変換できるのでしょうか。
intval 関数の宣言を見てみましょう。変数の整数値を取得するために使用されます: int intval (mixed var [, int Base])
特定の基数変換 (デフォルトは 10 進数) を使用して、変数 var の整数値を返します。
var は任意のスカラー型にすることができます。 intval() は配列またはオブジェクトでは使用できません。
9 もう 1 つの不可解な問題です。ユーザー名 1 でログインし、次に 'bo' でログインすると、システムはエラーを起こします。実行時エラーが発生しました: ")" が欠落している、nnd と表示されます。確認したところ、SQL文の変数の型がデータベースの変数の型と一致していないことが判明しました
10 phpで浮動小数点数を整数に変換する際、数値は四捨五入されます(小数点以下は切り捨てられます)。 。
11 mysql の insert ステートメントで、それが自動インクリメントフィールドの場合は、代わりに (NULL) を使用します。
12 php で中国語が文字化けする??? 問題の解決策:
mysql_connect の後に mysql_query("set names 'gb2312'"); を追加する
または utf8 エンコーディングを使用するため、上記のステートメントを追加する必要はありません。
さまざまな文字エンコーディングの変換を実現できる関数 iconv("GBK", "UTF8", "String"); もあります。
http://www.bkjia.com/PHPjc/325726.html
www.bkjia.com
true
http://www.bkjia.com/PHPjc/325726.html