Lời mở đầu Error! Bookmark not defined.
CHƯƠNG I NGÔN NGỮ PHP. 3
I.1. Giới thiệu về php. 3
I.1.1. Tốc độ nhanh, dễ sử dụng. 3
I.1.2. Có thể chạy trên nhiều hệ điều hành. 3
I.1.3. Có thể truy cập bất cứ loai cơ sở dữ liêu nào. 3
I.1.4. Luôn được cải tiến và cập nhật. 4
I.2. Nhúng PHP và HTML. 4
I.2.1. Nhúng mã PHP trong HTML 4
I.2.2. Thẻ PHP. 5
I.2.2.1. Kiểu short: 5
I.2.2.2. Kiểu định dạng XML: 5
I.2.2.3. Kiểu Script: 5
I.2.2.4. Kiểu ASP: 5
I.2.3. Khoảng trắng trong PHP 5
I.2.4. Gọi hàm. 6
I.3. Truy cập biến form 6
I.3.1. Biến form 6
I.3.2. Ghép nối chuỗi 7
I.3.3. Nhận dạng 7
I.3.4. Khai báo biến 7
I.3.5. Gán giá trị cho biến 8
I.3.6. Kiểu dữ liệu của biến trong PHP 8
I.3.7. Chuyển đổi kiểu dữ liệu 8
I.3.8. Hằng trong PHP 9
I.4. Toán tử trong PHP. 9
I.4.1. Các phép toán số học 9
I.4.2. Các phép toán về chuỗi 9
I.4.3. Phép toán gán kết hợp 9
I.4.4. Tham chiếu 10
I.4.5. Phép toán ? 10
I.4.6. Phép toán ERROR 10
I.5. Biến hàm 11
I.5.1. Gán và kiểm ta biến 11
I.5.2 Kiểm tra trạng thái biến 11
I.6. Hàm(functions) trong PHP 12
II.1.Cơ sở dữ liệu MySQL 13
II.2. Tạo cơ sở dữ liệu và người dùng 13
II.2.1.Kết nối và tạo cơ sở dữ liệu 13
IV.2.1.2.Kết nối và tạo cơ sở dữ liệu bằng giao diện đồ hoạ 14
II.2.2.Quản lý người dùng 14
II.2.3.Cấp quyền cho người dùng 15
II.2.4.Xoá quyền của User 17
II.3.Các kiểu dữ liệu trong cơ sở dữ liệu MySQL 18
II.3.1.Loại dữ liệu numeric 18
II.3.2.Loại dữ liệu data And Time 19
IV.3.3.Loại dữ liệu String 19
II.4.Phát biểu SQL 20
II.4.1.Nhóm phát biểu SQL 20
II.4.2.Phát biểu SQL thao tác dữ liệu 21
II.4.2.1.Khái niệm cơ bản về câu truy vấn Select 21
II.4.2.2. Phát biểu Select với mệnh đề From 21
II.4.2.3. Phát biểu Select với mệnh đề Where. 22
II.4. Các hàn thường được dùng trong MSQL 23
II.4.1 Các hàm sử dụng trong phát biểu select có mệnh đề GROUP BY 23
II.4.2. Các hàm xử lý chuỗi 23
II.4.4. Các hàm toán học 25
II.4.5. Phát biểu Insert,Update 25
II.4.5.1 Phát biểu SQL dạng Update 25
II.4.5.2.Phát biểu SQL dạng DELETE 26
II.4.5.3.Phát biểu SQL dạng JOIN 26
III.1. Session 29
III.1.1. Khái niệm về session 29
III.1.2. Chức năng cơ bản của session 29
III.1.3. Cookie 29
III.1.4. Gán Cookie từ PHP 30
III.1.5 Sử dụng cookie với session 30
III.2. Cài đặt session 31
III.2.1. Khởi động session. 31
III.2.2. Đăng kí biến session. 31
III.2.3. Sử dụng biến session 32
III.2.4. Huỷ biến session. 32
III.3. Thiết lập đến kết nối cơ sở dữ liệu. 32
III.3.1. Thiết lập kết nối cơ sở dữ liệu. 32
III.3.2. Mở một cơ sở dữ liệu 33
III.3.3. Đóng kết nối cơ sở dữ liệu 34
III.3.4. Truy vấn cơ sở dữ liệu. 34
IV.1. Khảo sát hệ thống hiện hành. 35
IV.2. Phân tích và thiết kế hệ thống. 36
IV.3. Biểu đồ các luồng dữ liệu. 37
IV.3.1. Biểu đồ luồng dữ liệu mức ngữ cảnh. 37
IV.3.2. Biểu đồ luồng dữ liệu mức đỉnh. 39
IV.3.2.1. Biểu đồ dữ liệu phân rã chức năng Module. 40
IV.3.2.2. Biểu đồ dữ liệu phân rã chức năng Module tin tức. 40
IV.3.2.3. Biểu đồ dữ liệu phân rã chức năng diễn đàn. 41
IV.3.2.4. Biểu đồ dữ liệu phân rã chức năng dowload. 41
IV.3.2.5. Biểu đồ dữ liệu phân rã chức năng xem điểm. 42
IV.4. Kết quả của chương trình. 43
IV.4.1. Trang chủ 43
IV.4.2. Trang quản lý module 44
IV.4.3 Trang diễn đàn. 45
55 trang |
Chia sẻ: huong.duong | Lượt xem: 1919 | Lượt tải: 1
Bạn đang xem trước 20 trang tài liệu Các hàm sử dụng trong phát biểu select có mệnh đề Group By, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
oi của hàm. Hai loại thông dụng thường dùng nhất là gettype() và settype(), chúng có cấu trúc như sau:
String gettype(mixed var);
Int settype(string var, string type);
Để sử dụng hàm gettype(), truyền tham số là một biến, chúng ta sẽ quan tâm đến giá trị trả về là loại kiểu dữ liệu hay “unknow type” nếu chúng không thuộc vào các kiểu dữ liệu như: string, interger, double, array,object.
Tương tự như trên, settype() sử dụng bằng cách truyền tham số là một biến và kiểu dữ liệu mới này dưới dạng chuỗi nếu muốn hàm đó trả về kiểu dữ liệu này.
I.5.2 Kiểm tra trạng thái biến
Ngoài các hàm kiểm tra dữ liệu của biến, PHP còn có một số hàm kiểm tra trạng thái của biến.
Ví dụ: Trong trường hợp bạn kiểm tra biến đó có tồn tại hay không ta sử dụng hàm isset() với tham số truyền vào là biến, nếu biến đó tồn tại hàm trả về giá trị true, ngược lại trả về giá trị false.
Hàm unset() với tham số là biến đang tồn tại, hàm này sẽ loại bỏ biến này trong quá trình thực thi.
Hàm empty() cho phép bạn kiểm tra biến tồn tại và không rỗng, có chiều dài khác 0 trả về giá trị true, ngược lại trả về giá trị false.
I.6. Hàm(functions) trong PHP
Không thể không nói đến hàm trong việc lập trình, nhờ có nó mà chương trình của chúng ta trở nên dễ dàng tổ chức hơn. Như các ngôn ngữ khác PHP có khả năng cung cấp những hàm do người dùng tự định nghĩa. Đồng thời, PHP cũng óc một số cải tiến để việc viết hàm dễ chụi và mạnh mẽ hơn.
Định nghĩa và gọi hàm
Rất dễ để định nghĩa và gọi hàm trong PHP:
<?php
Function tên_hàm([các tam số; truyền vào…])
{
[thân hàm…]
}
?>
Từ khoá function báo cho PHP biét rằng đay là một hàm. Tiếp theo đó là tên hàm. Tên hàm của PHP có thể là bất cứ kí tự Unicode gì( kể cả tiếng Việt, Trung…, nhưng không được bắt đầu bằng số). Thật sự mạnh mẽ, nhưng bạn sẽ gặp vấn đề khi đăt tên file đó.
Chương II: Cơ Sở Dữ Liệu MSQL
II.1.Cơ sở dữ liệu MySQL
MSQL lầ cơ sở dữ liệu được sử dụng cho các ứng dụng trong web có quy mô vừa và nhỏ.Tuy không phải là một cơ sở dữ liệu lớn nhưng chúng cũng có trình giao diện windows hay linux, cho phép người dùng có thể có thao tác liên quan đến cơ sở dữ liệu.
Cũng giống như các hệ cơ sở dữ liệu khác,khi làm việc với cơ sở dữ liệu MSQL, bạn đăng ký kết nối tạo cơ sở dưx liệu quản lý người dùng phân quyền sử dụng,thiết kế đối tượng bảng của cơ sở dữ liệu và xử lý dữ liệu.
Để sử dụng hay phát biểu các thao tác trên cơ sở dữ liệu ban có thể sử dụng quy trình quản lý đồ hoạ hay dùng dòng lệnh còn gọi là command line.
Tuy nhiên, trong bất kỳ ứng dụng cơ sở nào cũng vậy,nếu bản thân chúng được hỗ trợ bằng một trình giao diện đồ hoạ, bạn có thể sử dụng chúng tiện lợi hơn với trình giao diện commađ line,bơỉ vì, cho dù bạn điều khiển MSQL dưới bất kỳ hình thức nào, mục đích cũng là quản lý thao tác trên cơ sở dữ liệu.
II.2. Tạo cơ sở dữ liệu và người dùng
II.2.1.Kết nối và tạo cơ sở dữ liệu
Để kết nối cơ sở dữ liệu có 2 cách
II.2.1.1.kết nối và tạo cơ sở dữ liệu bằng command line
Nếu bạn sử dụng command line thì bạn có thể trỏ đến các thư mục msql\bin. Sau đó, bạn có thể bắt đầu start | run | c:\msql\bin\msql.exe.thì sẽ có kết quả.
Bắt đầu từ dấu nhắc msql > như hình trên thì bạn có thể thực hiện các phát biểu SQL và MSQL.
Lưu ý: Nếu bạn chua biết các lệnh của MSQL từ dấu nhác msql> bạn có thể gõ dấu ?để liệt kê các phát biểu như: connect, exit, quit, …
MSQL>crate database database name;
Trong trường hợp này, chúng tôi tạo cơ sở dữ liệu trên Inter Shop như phát biểu sau:
Msq;>create database Inter shop;
Chú ý: Để thay đổi cơ sở dữ liệu làm việc, bạn có thể sử dụng lệnh use database name; trong trường hợp có nhiều cơ sở dữ liệu, bạn có thể làm việc trên bất kỳ cơ sở dữ liệu chỉ định nào chẳng hạn use inteshop;
IV.2.1.2.Kết nối và tạo cơ sở dữ liệu bằng giao diện đồ hoạ
Trong trưòng hợp thưc hiện giao diện đồ hoạ bạn có thể chạy trên tập tin msqlfront.exe trong thư mục MSQL control của sổ xuất hiện
Nếu lần đầu tiên tạo cơ sở dữ liệu, bạn cần tạo một kết nối Connection , cung cấp trên Server hay IP của máy chứa MSQL của cơ sở dữ liệu MSQL là root và pasword là rỗng
Nếu bạn đã có cơ sở dữ liệu đang tồn tại, bạn có thể gõ tên cơ sở dữ liệu trong phần databases
Trong trường hợp lần đầu tiên , bạn không cần cung cấp tên cơ sở dữ liệu, bạn có thể tạo chúng khi kết nối
Sau khi kết nối cơ sở dữ liệu thành công, trình điều khiển cơ sở dữ liệu MSQL có giao diện như hình 4-5.Công việc đầu tiên của bạn là phảI tạo cơ sở dữ liệu.
Bắt đầu từ menu có tên Tools | create Database hay goi tên Root @localhost | R- Click |Create Database cửa sổ xuất hiện như hình 4-6.
Cung cấp tên cơ sở dữ liệu, trong trường hợp này bạn có thể nhập InterShop, bấm nút OK, cơ sở dữ liệu xuất hiện trong củă sổ điều khiển.
Trong cả hai trường hợp tạo cơ sở dữ liệu MSQL thành công như trên có thể tìm thấy cơ sở dữ liệu trong thư mục msql/ data như hình 4-7
II.2.2.Quản lý người dùng
Để đăng nhập cơ sở dữ liệu MSQL, bạn có thể sử dụng hai cách trình bày ở trên hoặc sau khi tạo ra cacs usename khác, bạn có thể sử dụng các usename và password này để đăng nhập.
Nếu sử dụng command line bạn chỉ cần gõ >msql-h hostname- u usename –p từ dấu nhắc, nếu sử dụng trình giao diện đồ hoạ thì nhập các thông tin vào các ô textbox .
Từ khoá -h chỉ tên ( computer name ),IP, hay localhost của máy có sử dụng có sở dữ liệu MSQL, bạn có thể sử dụng hai cách trên.Muốn tạo Use namê bằng comman line bạn có thể gõ tù đấu nhắc phát biểu sau
GRANT
Select,Inset,Update,Index,Alter
Create,Drop,References
On *.* TO’myis’@’%’
IDENTIFED BY ‘12345678’
Phát biểu trên vùa tạo rs use name trên myis với hostname là cơ sở dữ lỉệu hiện hành,password là 12345678 và được quyền lựa chọn Select,Inset,Update,Index,Alter ..trên cơ sở dữ liệu hiện hành
Trong trường hợp bạn tạo ra một use name hiện hành không cung cấp các quyền trên cơ sở dữ liệu, bạn có thể thực hiện như phát biểu use name: ekhang,password:12345678 sau:
GRANT
Usage
On *.* TO’ekhang’@’%’
IDENTIFED BY ‘12345678’
Nếu bạn sử dụng giao diện đồ hoạ có thể tạo use name và gán quyền như khi sử dụng menu có trên , cửa sổ xuất hiện 4-8
II.2.3.Cấp quyền cho người dùng
Các quyền Select,Inset,Update,Index,Alter… trên cơ sở dữ liệu bạn có thể tham khảo 4-1
Loại áp Dụng Diễn Giải
Select tables,columns cho phép use truy vấn mẩu tin từ table
,Inset tables,columns cho phép use thêm mới mẩu tin vào table
Update tables,columns cho phép use thay đổi mẩu tin từ table
Index tables cho phép use tmẩu tin tồn tại trong table
Deleter tables cho phép use thêm mới hay xoá từ table
Alter tables cho phép use thay đổi cấu trúc đối tượng
Create Database tables cho phép user tạo mới đối tượg Table
Drop Database tables cho phép user xoá đối tượg Table
Xuất hiện từ các quyền có ảnh hưởng đến cấu truc cơ sở dữ liệu, các
đối tượng cơ sở dữ liệu và dữ liệu bạn có thể xem xét kĩ trước khi cung cấp quyền cho user làm việc trên cơ sở dữ liệu.
Ngoài các quyền trên, trong MSQL có một số quyền không gán mặc định như trong bảng 4-2, bạn có thể xem xét các quyền quản trị để cấp cho người dùng.
Loại Diễn Giải
Reload cho phép người quản trị nạp lại các Table,quyền, hots,logs
Shutdow cho phép người quản trị chấm dứt hoạt động MSQLServer
Process cho phép người quản trị xem chuong trinh chủ và chấm một số
Quá trình dang thực thi
File Cho phép dữ liệu ghi vào bảng từ tập tin
Lưu ý: các use name bình thường không nên được cấp quyền như trong bảng 4-2 cho họ.Trong trường hợp bạn muốn cấp tất cả các quyền trong bảng 4-1 và bảng 4-2 cho use name khi tạo ra hok, bạn sử dụng khoá All hay All Privileges trong phát biểu tạo use như sau
GRANT
All
On *.* TO’ekhang’@’%’
IDENTIFED BY ‘12345678’
Tương tự như vậy, trong trường hợp bạn không cung cấp các quyền nào trên cơ sỏ dữ liệu hiện hành bạn có thể khai báo cấp p-hát quỳên như sau
GRANT
Usage
On *.* TO’ekhang’@’%’
IDENTIFED BY ‘12345678’
II.2.4.Xoá quyền của User
Để xoá các quyền của user từ cơ sở dữ liệu hiện hành, bạn có thể sử dụng phát biểu SQL có tên Revoke và phát biểu ngược lại với Grant.
Nếu bạn xoá một số quyền của user, bạn có thể sử dụng khai báo phát biểu như sau
Revoke privileges [(clomns)]
On item
From user name
Trong trường hợp xoá tất cả các quyền của user, bạn có thể phát biểu như sau:
Revoke All
On item
From user name
Nếu user được cấp quyền với tuỳ chọn Grant Oion, để xoá quyền đó của user bạn có thể khai báo như sau.
Revoke Grant Oion
On item
From user name
II.3.Các kiểu dữ liệu trong cơ sở dữ liệu MySQL
Trước khi thiết kế cơ sở dữ liệu trên MySQL, bạn cần tham khảo một số dữ liệu thương dùng, chúng bao gồm các nhóm như:numeric,date and time và string .
Điều cần lưu ý khi thiết kế cơ sở dữ liệu cho cột trong table, bạn cần xem xét các loại dữ liệu lưu trữ trong thuộc nhóm kiểu dữ liệu nào, chiều dài cũng như các rằng buộc khác, nhằm khai báo cho phù hợp.
II.3.1.Loại dữ liệu numeric
Kiểu dữ liệu này bao gồm các số nguyên trình bày trong bảng 4-3 và kiểu chấm động trong trường hợp kiểu dữ liệu chấm động diều khiển bạn cần chỉ tõ bao nhiêu dấu phần lẻ như trong bảng 4-4
Loại
Range
Byte
Diễn giảI
Tinyint
-127->128 hay 0..255
1
Số nguyên rất nhỏ
Small int
2
Số nguyên nhỏ
Mediumint
3
Số nguyên vùă
Int
4
Số nguyên
Bigint
8
Số nguyên lớn
II.3.2.Loại dữ liệu data And Time
Kiểu dữ liệu này cho phép nhập chuỗi ngày tháng hay dạng số như trong bảng 4-5
Loại
Range
Bytes
Diễm giảI
float
Phụ thuộc số thập phân
4
Số thập phân dạng single hay double
Float (M,D)
+1.175494351E-38
-1.175494351E-38
+3.40282346638
-3.40282346638
4
Số thập phân dạng single
Double (M,D)
+1.7976931348623157308
-1.7976931348623157308
+2.202250738585072014E-308
-2.202250738585072014E-308
Số thập phân dạng double
Float (M [,D] )
8
Số chấm động lưu dưới dạng char
IV.3.3.Loại dữ liệu String
Kiểu dữ liệu chia làm ba loại, loại thứ nhát như char( chiều dài cố định) và varchar ( chiều dài biến thiên ).Char cho phép bạn nhập dưới dạng chuỗi với chiều dài lớn nhất bằng chiều dài bạn đã định nghĩa, nhưng khi truy cập dữ liệu trên File có khai báo dạng này, bạn cần sử lý khoản trắng.Điều này có nghĩa là nếu khai báo chiều dài 10, nhưng bạn chỉ nhập chuỗi kí tự 4. MSQL lưu trữ chuỗi trong bộ nhớ với chiều dài 10.
Ngựơc lại với kiểu dữ liệu char và varchar, chiều dài lớn nhất người dùng có thể nhập vào bằng chiều dài bạn đã định nghĩa cho File này, bộ nhớ chỉ lưu trữ chiều dài dúng chiều dài bạn đã nhập
Loại thứ hai là Text hay Blob,Text cho phép lưu trữ chuỗi rất lớn,Blob cho phép lưu trữ đối tượng nhị phân.
Loại thứ ba là Enum và Set, bạn có thể tham khảo ba loại tren trong bảng 4-7
Loại
Range
Diễn giải
Char
Varchar
Tinyblob
Tinytext
II.4.Phát biểu SQL
MSQL là một hệ thống quản lý cơ sở dữ liệu quan hệ (RDBMS).RDBMS là hệ mô hình cơ sở dữ liệu thông dụng hiện nay
II.4.1.Nhóm phát biểu SQL
Như đã trình bày trong chương 3,hầu hết sản phẩm cơ sở dữ liệu quan hệ hiện nay đều dựa trên chuẩn SQL, chẳng hạn như SQL server ,Oracle , MSQL điều này có nghĩa tất cả các cơ sở dữ liệu quan hệ đều phải có những tiêu chuẩn theo cú pháp SQL và MSQL cũng không phảI là ngoại tệ
Ngôn ngữ SQL chia làm 4 loại sau:
DDL : ngôn ngữ định nghĩa dữ liệu, dùng để tạo cơ sở dữ liệu, định nghĩa các đối tượng cơ sở dữ liệu như Table,Query,View hay các đối tượng khác.
DML : ngôn ngữ thao tác dữ liệu dùng để thao tác dữ liệu chẳng hạn nhu các phát biểu Select,Insert,Delet,Update …
DCL : ngôn ngữ sử dụng truy cập đối tượng cơ sở dữ liệu dùng để thay đổi cấu trúc tạo cho người dùng gán quyền
TCL: Ngôn ngữ sử dụng khi báo chuyển tác chẳng hạn như Begin Tran, commit …
II.4.2.Phát biểu SQL thao tác dữ liệu
II.4.2.1.Khái niệm cơ bản về câu truy vấn Select
Phát biểu Select dùng để truy vấn dữ liệu một hay vài bảng khác nhau, kết quả trả về một tập mẫu tin thoả các điều kiện cho trước nếu có cú pháp của phát biểu SQL dưới dang Select như sau:
SELEC: danh sách các cột
FROM: danh sách bảng
WHERE: các điều kiện rằng buộc
HAVING: điều kiện bắt buộc
ORDER BY: danh sách cột
LIMIT
Danh sách cột khi khai báo các cột,biểu thức thức kết hợp giữa các cột của bảng bạn cần truy vấn.Trong trường hợp có hai cột cùng tên của hai bảng trong cùng phát biểu, bạn cần định nghĩa bảng đI trước
II.4.2.2. Phát biểu Select với mệnh đề From
Phát biểu Sql dạng Select là một trong những phát biểu yêu cầu MSQL truy vấn dữ liệu trên cơ sở dữ liệu chỉ định Select dùng để đọc thông tin từ cơ sở dữ liệu theo những trường quy định, hay nhưng biểu thức cho trường đó.
Mệnh đề From chỉ ra tên một bảng có qun hệ truy vấn thông tin.Thường chúng ta sử ssụng công cụ MSQL-Font | Query để thực thi phát biểu SQL
Sau khi thực thi và phát biểu SQL kết quả trả về số mẩu tin và tổng mẩu tin .
II.4.2.3. Phát biểu Select với mệnh đề Where.
Khi bạn dùng mệnh đề where để tạo nên điều kiện cần lọc mẩu tin theo tiêu chuẩn được định nghĩa. Thông thường where dùng trường đẻ so sánh giá trị, cột khác, hay biểu thức chứa trường bất kỳ có trong bảng. Phát biểu SQL dưới dạng Select dưới mệnh đè where có cú pháp dạng như sau:
Tổng quát: Select*from tablename where điều kiện
Hoặc Select field1, field2… where điều kiện
Cụ thể ; Select * from tblkhách _hàng where city In(‘HN,HCM’)
Các phép toán so sánh:
>(lớn hơn) where amount >1000
< (nhỏ hơn) where amount<1000
>=(lớn hơn or bằng) where amount >=1000
<=(nhỏ hơn or bằng) where amount <=1000
= where custID= ‘12’
!=khác where custID= ‘12’
khác where custID= ‘12’
Các phép toán logic có thể sử dụng trong điều kiện
and: phép toán “and”-và
Select * from tbloders where amount>1000 and custID= ‘5’.
or: Phép toán “or”- trừ hoặc
Select * from tbloders where amount>1000 or custID= ‘5’.
Not: Phép toán “Not”- phủ định.
Select * from tbloders
Where date IS NOT NULL.
Not In: Phép toán “NOT IN”- phủ định tập hợp.
Select * from tbloders
Where Amount Between 12000 AND 3000.
II.4. Các hàn thường được dùng trong MSQL
II.4.1 Các hàm sử dụng trong phát biểu select có mệnh đề GROUP BY
Max- tìn giá trị lớn nhất trong tập hợp giá trị
Select SUM (Amuont )AS S1_Total
FROM tble Orders
Min- Tìm giá trị nhỏ nhất trong tập hợp giá trị
Select MIN (Amuont )AS S1_Min
FROM tbleOrders
AVG- tìm giá trịn trung bình trong một tập hợp
Select AVG (Amuont )AS S1_Mid
FROM tbleOrders
SUM- tính tổng giá trị trường hợp trong câu truy vấn
Select SUM (Amuont )AS S1_Total
FROM tbl Orders
COUNT- trả về giá trị số lượng mẩu tin trong câu truy vấn
Select Count (* )AS S1_Mau_Tin
FROM tbleOrders
Ví dụ :về hàm MAX,MIN,VAG,SUM,COUNT
SELECT Select SUM (Amuont )AS S1_Total, Select MIN (Amuont )AS S1_Min, Select AVG (Amuont )AS S1_Mid, Select SUM (Amuont )AS S1_Total, Select Count (* )AS S1_Mau_Tin
FROM tbleOrders
II.4.2. Các hàm xử lý chuỗi
+ Char()-chuyển đổi kiểu mã ASCII sang dạng chuỗi Select char(35)cho kết quả #
+ ASCII()- Hàm trả về giá trin mã ASCII của ký tự bên trái của chuỗi
SELECT (‘TOI’)cho kết quả 84
+LOWER()- Hàm này chuyển đổi kiểu chuỗi thành kiểu chữ thường
LOWER(Tuân) cho kết quả tuân
LOWER(TUÂN) cho kết quả là tuân
+LEN()-Hàm trả về giá trị một chuỗi
LEN(nguyễn văn tuân )trả về giá trị 15
+RTRIM()- Hàm dùng loại bỏ khoang trắng bên phải của chuỗi
RTRIM( nguyễn văn tuân) trả về giá trị ‘nguyễn văn tuân ‘
+LEFT(‘ biểu thức ký tự ’,n)- Hàm trả về giá trịn bên trái cho đến vị trí thứ n
Left(‘thuy’,3) trả về ‘ơThu’
REFT(‘biểu thức ký tự ’,n)- hàm trả về chuỗi bên trái cho đến vị trí n
Left (‘thuy’,3) trả về giá trị ‘huy’
INTR(‘ Biểu thức cần tìm’,’Biểu thức cần tìm ’)
SELECT Instr(‘Tuân’,’Nguyên Văn Tuân’)
Cho kết quả trả về giá trị 11
II.4.3.Các hàm xử lý thời gian
+Ngày CurDate() Hàm trả về ngày,tháng năm hiện hành của hệ thống
Select Curdate() AS’ hôm_nay ’
Kết quả trả về 2206-11-07
+Curtime(): Hàm trả về giờ phút giây hiện hành của hệ thống
Select Curtime() AS’ Time is’
Kết quả trả về 23:45:06
+Hàm period_Diff- Hàm trả về số ngàt trong khoảng thời gian giữa hai ngày
Select period_dif(Orderdate,Getdate()) as ‘Sn từ lúc thu tiền đến nay’ from tblOrders
+Hàm Dayofmonth – hàm trả về ngày thứ mấy trong tháng
Select dayofmonth(curdate()) as’hôm nay ngày ’ trả về 6
II.4.4. Các hàm toán học
+Hàm Sqrt()- Hàm trả về là căn bậc hai của một biểu thức
Select Sqrt(16) trả về 4
+Hàm Round trả về số lần làm tròn của một biểu thức
Select round(456.45,-1) kết quả trả về 460.00
II.4.5. Phát biểu Insert,Update
Khi cần thêm mẩu tin vào bảng trong cơ sở dữ liệu MSQL ta dùng phát biểu Insert
Cú pháp của phát biểu Insert
INSERT INTO tblName (fỉeld1,field2,field3......) values (biểu thức 1, biểu thức2, biểu thức 3....) giá trị cụ thể
[Select fỉeld1,field2,field3...... From tblName1] giá trịn insert và là kết quả của câu truy vấn .
II.4.5.1 Phát biểu SQL dạng Update
Chức năng của phát biểu update là cập nhập dữ liệu đã tồn tại trong bảng dữ liệu.khi update cùng cập nhập dữ liệu cho một mẩu tin chỉ định nào đó thường lệnh này sủ dụng chung với mệnh đề Where.Nếu cập nhập tất cả các Record trong bảng thì ta có thể bỏ mệnh đề Where.cấu trúc của biểu thức này được phát biểu như sau:
+Update từ giá trị cụ thể
Update
Set=,....,Where Điều Kiện
+Update phát biểu từ kết quả của biểu thức select
Update
Set= Where Điều Kiện
Ví dụ :
UPDATE ‘tblcustomers’ SET UserName=
‘Nhungvnn@gmail.com ‘WHể CustID =5
II.4.5.2.Phát biểu SQL dạng DELETE
Với phát biểu này cho phép bạn xoá mẩu tin trong bảng dữ liệu theo ý mình.Thường kềm theo Delete là mệnh đề where để lọc những mẩu tin muốn xoá.
Cấu trúc:
DELETE FROM Where
ví dụ:
Delete from tblCustomurs where Cust Name is Null
II.4.5.3.Phát biểu SQL dạng JOIN
Ngoài các phát biểu SQL với các dạng trên trong phần kế tiếp, ở đây trình bày một số phát biểu SQL dạng select để kết nối dữ liệu các bảng có quan hệ với nhau, những phát biểu này bao gồm : JOIN,INER JOIN,LEFT JOIN,RIGHT JOIN.
Nói một chút về cơ sở dữ liệu quan hệ
đôi khi chúng ta phải lấy dữ liệu từ hai bảng một lúc chúng ta thực hiện một kết nối
Cấc bảng trong CSDL có thể quan hệ rằng buộc với nhau thông qua cấc khoá. Một khoá chính(primary key) là một cột mà trong đó mỗi giá trị của hàng phải là duy nhất. Mục đích của khoá là kết nối dữ liệu lại với nhau từ nhièu bảng khác nhau mà không gây trùng lặp dữ liệu giữa các bảng
ví dụ :
về mệnh đề :join, Inerjoin,.....
trong bảng Employees( nhân viên ) ở ví dụ dưới đay có cột
Employees_ID là khoá chính, đảm bảo là không thể có hai dòng nào đó có trìng Employees_ID. Employees_ID dùng để phân biệt hai nhân viên khi họ trung tên
Trong ví dụ dưới đây:
Employees_ID là khoá chínghcủa Employees
Prod_ID là khoá chíng của orders
Cột Employees_ID trong bảng Orders được sử dụng để kết nối với bảng Employees, chỉ đến nhân viên trong bảng Employees
Bảng Employees:
Employees_ID
Name
01
Hansen,Ola
02
Svendson,Tove
03
SvenDson,Stêphen
04
Pêttrsen, Kari
Bảng Orders
Prod_ID
Product
Employees_ID
234
Printer
01
657
Table
03
865
Chair
03
Ví Dụ: LEFT JOIN
Cú pháp:
SELECT côt_1,cột_2,cột_3
FROM bảng_1
LEFT FOIN bảng _2
On bảng _1. khóa_chính = bảng _2. khoá _ngoại
Liệt kê tất cả các nhân vien và món hàng mà họ đặt (nếu có )
SELECT Employees.Năm,Orders. Product
FROM Employees
On Employees. Employees_ID =Orders. Employees_ID
Chương III. PHP & CƠ Sở Dữ LIệU MySQL
III.1. Session
III.1.1. Khái niệm về session
Khi bạn đang làm việc trên một trang web của website và gọi một trang web khác cũng thuộc website bạn đang làm việc, trình duyệt không cung cấp cho bạn biết hai trang web này được gọi nhau từ một người dùng.
Bằng cách xây dựng các trang web bằng server script, bạn có thể dùng Query String để gọi những cặp tham số và giá trị, sau đó sử dụng các phương thức $HTTP_GET_VARS[“Parameter”] để lấy giá trị của từng tham số, nhằm quản lý trình duyệt web của người dùng.
III.1.2. Chức năng cơ bản của session
Session trong PHP được nhận biết bởi một session ID gán cho mỗi Browser.
Khi Browser mở ra ứng với trang web bất kỳ của website, session ID có giá trị là một dãy số ngẫu nhiên được lưu phía trên client.
Session ID có chu kỳ sống cho đén khi chúng hết hạn sử dụng, bạn có thể truyền giá trị cho session ID với URL hay ghi chúng ra Cookie.
III.1.3. Cookie
Cookie là một mẫu nhỏ thông tin được lưu trữ xuống từng máy tính truy cập đến website của bạn. Bạn có thể gán cookie trên máy tính của người dùng thông qua HTTP Header, bằng cách khai báo như sau:
Set-Cookie: Name=Value;[expries = Date;]
[path=Path;] [domain=Domain_name;][secure]
Khai báo trên sẽ tạo Cookie với tên là Name, giá trị là Value, các tham số khác là tham số tuỳ chọn. Expries là thời gian giới hạn mà cookie này không thích hợp nữa. Nếu thời gian không cung cấp trong cookie, cookie này sẽ còn hiệu lực cho đến khi người dùng xoá tập tin cookie.
Domain_name là tên miền của website của bạn, secủe chỉ ra rằng nôI dung của cookie sẽ không gửi thông điệp qua giao thức HTTP.
III.1.4. Gán Cookie từ PHP
Bạn có thể gán Cookie trong PHP bằng cách sử dụng hàm setcookie(), hàm setcookie() có cú pháp như sau:
int setcookie (tring name [, string value
[, int exprire [.string path
[, string domain [, int secure]]]]])
Ví dụ:
<?php
$myvalue= “ Chào các ban!”
Setcookie(“intershop”, $myvalue);
?>
Cookie
trang kế
III.1.5 Sử dụng cookie với session
Cookie có một vài vấn đề không thích hợp, trong trường hợp browser của người dùng không chấp nhận cookie. Ngưòi dùng có thể vô hiệu hoá chức năng chấp nhận cookie trong cấu hình trong Browser.
Do cookie lưu thông tin cá nhân trên máy khách nên hầu hết người dùng đều không muốn, đó là lý do tại sao người dùng có thể vô hiệu hoá chức năng chấp nhận cookie trong cấu hình trong browser, ứng dụng sẽ khó xử lý trong trường hợp này.
Đối với trường hợp này, bạn có thể sử dụng điều khiển session có cú pháp session_set_cookie_params($lifttime, $path, $domain); để gán cookie
III.2. Cài đặt session
Bao gồm các bước sau:
Khởi động session.
Đăng ký biến session.
Sử dụng biến session.
Khai báo lại và huỷ bỏ session.
III.2.1. Khởi động session.
Để sử dụng session, trước tiên cần phải khởi động chúng, khi khởi động session, nếu chưa tồn tại session ID, lập tức session ID được tạo ra. Trong trường hợp session đã tồn tại, chúng sẽ được nạp vào biến session và bạn có thể sử dụng chúng.
Biến session sẽ hết hiêu lực khi nó hết hạn, người trình duyệt đóng browser đang duyệt trang web đó.
Từ một Browser, bạn có thể mở nhiều cửa sổ trình duyệt, nhưng nếu bạn bắt đầu mở cửa sổ trình duyệt từ biểu tượng hay menu đó chính là một session.
Để khởi động session, bạn có thể sử dụng hai cách như sau:
Session_start();
Cách thứ 2, khai báo trong trang php.ini như sau:
Session_start =0
III.2.2. Đăng kí biến session.
Khi cần sử dụng biến session nào đó, sau khi khai báo khởi động, cần phải đăng ký biến session như sau:
$myvar=12;
Session_register(“myvar”);
III.2.3. Sử dụng biến session
Để sử dụng được biến session đã được đăng ký và gán giá trị trước đó, có thể sử dụng chúng sau khi khai báo đăng ký.
Khi khởi động và đăng ký biến session, các biến này sẽ có hiệu lực trên mọ trang PHP mà đang truy cập của website ứng với Browser đang mở.
III.2.4. Huỷ biến session.
Trong trường hợp bạn đã đăng ký một session và không muốn sử dụng nữa, có thể sử dụng session_unregister để xoá tên biến session đó.
Phát biểu này, yêu cầu cung cấp tên biến session không có dấu $ đi kèm, chỉ có thể xoá từng biến session đã khai báo. Khi đăng ký nhiều biến session thì khi xoá chúng phả thực hiện xoá từng biến một.
III.3. Thiết lập đến kết nối cơ sở dữ liệu.
Để kết nối tới cơ sở dữ liệu MySql, bạn phảI cung cấp tên server hay IP( có thể là localhost) vào máy chứa cơ sở dữ liệu MySQL. Username. Pass để đăng nhập và làm việc trên cơ sở dữ liêu được mở.
III.3.1. Thiết lập kết nối cơ sở dữ liệu.
PHP cung cấp cho kết nối cơ sở dữ liệu như sau:
Int mysql_pconnect
(“servername”, “username”, “password”)
If(!$db)
{
Echo “could not connect to MySQL database”
Exit;
}
Ngoài ra có thể khai báo như sau:
$link= mysql_connect
(“servername”, “username”, “password”)
Or die (“could not connect to MySQL database”)
Lưu ý: Lệnh die cho ta kết thúc kết nối và giải phóng toàn bộ biến khởi tạo để kết nối cơ sở dứ liêu trước đó.
III.3.2. Mở một cơ sở dữ liệu
Sau khi nối cơ sở dữ liệu MySQL thàng công, bạn khai báo phát biểu để mở cơ sở dữ liệu cũng theo hai cách kết nối như sau:
Mysql_select_db(“database name”);
Tương tự trường hợp kết nối cơ sở dữ liệu thứ hai, bạn cũng có thể khai báo như sau:
Mysql_select_db(“database name”,$link);
Ví dụ:
Ví dụ mở cơ sở dữ liêu thứ nhất:
<?php
@$db=mysql_Pconnect
(“localhost” ,“root”, “”)
If(!db)
{
Echo “không kết nối được CSDL”
}
Mysql_select_db=(“test”);
?>
Nếu sử dụng cách kết nối cơ sở dữ liệu thứ nhất. Có thể khai báo mở cơ sở dữ liệu trong myphpadmin.
Ví dụ khai báo kết nối:
<?php
$link=mysql_Pconnect(“localhost”,”root”, “”)
Or die (“Không kết nối được CSDL mysql”);
Mysql_select_db=(“test”, “link”);
?>
II
Các file đính kèm theo tài liệu này:
- DAN220.doc