II .Cấu trúc ngôn ngữ
5. Tên của Cơ sở dữ liệu, bảng, chỉ số cột và bí danh
Tên của cơ sở dữ liệu, bảng, chỉ số cột và bí danh tất cả đều tuân theo một qui luật chung trong Mysql. Nh−ng chú ý rằng qui luật này đã đ−ợc thay đổi bắt đầu với Mysql Version 3.23.6 khi chúng ta d−a vào lời chú thích cho việc nhận biết cơ sở dữ liệu, bảng và tên cột với dấu ‘ ‘ ’ ’ .’ ” ’sẽ làm việc nhận ra lời chú thích nếu bạn chạy trong chế độ ANSI . Định danh (Identifier) Độ dài Các kí tự cho phép Database (cơ sở dữliệu) 64 Tất cả các kí tự cho phép trong th− mục ngoại trừ ‘/’ và ‘.’ Table (Bảng)
64 Tất cả các kí tự cho phép với tên File ngoại trừ ‘/’ và ‘.’ Column (Cột) 64 Cho phép tất cả các kí tự Alias (Bídanh) 256 Cho phép tất cả các kí tự
Chú ý: ở bảng trên định danh khơng thể có kí tự đánh dấu, ASCII(0) hoặc ASCII(255) .
Nếu định danh là một từ bị hạn chế hoặc trong đó có chứa các kí tự đặc biệt thì bạn phải sử dụng dấu nháy đơn để chú thích khi sử dụng chúng .
Ví dụ: SELECT * from `select` where `select`.id > 100; Trong phiên bản tr−ớc của Mysql, luật đặt tên nh− sau :
- Một tên gồm các kí tự trong bảng mã, cũng cho phép kí tự gạch d−ới ‘_’ và ‘$’.
- Tên có thể bắt đầu bởi tất cả các kí tự hợp pháp, trong thực tế tên có thể bắt đầu bằng một số (điều này khác nhiều với hệ cơ sở dữ liệu )tuy nhiên tên không chỉ gồm một số .
- Không đ−ợc sử dụng kí tự ‘.’ Trong tên bởi vì kí tự đó đ−ợc sử dụng để mở rộng khn dạng để truy nhập đến cột (xem ở bảng d−ới đây). Chúng ta khơng nên dùng những tên nh− 1e bởi vì một biểu thức nh− 1e1thì rất mơ hồ, nó có thể đ−ợc biên dịch là một biểu thức 1e1 hoặc là số 1e1.
Trong Mysql ta có thể liên hệ tới một cột bằng việc sử dụng những cách sau:
Cột tham chiếu ý nghĩa
Col_name Cột col_name từ bảng sử dụng trong câu truy vấn chứa cột với tên này.
Tbl_name.col_name Cột col_name từ bảng tbl_name của cơ sở dữ liệu hiện thời .
Db_name.tbl_name. col_name
Cột col_name từ bảng tbl_name của cơ sở dữ liệu Db_name.
‘column_name’ Một cột có chứa kí tự đặc biệt hoặc từ khố Bạn cần phải chỉ rõ tbl_name hoặc db_name.tbl_name đối với những cột có cùng tên trong nhiều bảng của cơ sở dữ liệu, hoặc bảng có cùng tên trong các cơ sở dữ liệu khác nhau để tránh sự nhập nhằng .
Ví dụ : giả sử mỗi bảng T1 ,T2 chứ một cột C bạn có thể lấy C trong một lệnh SELECT sử dụng cả T1 và T2. Trong tr−ờng hợp này C nhập nhằng bởi vì nó khơng duy nhất giữa các bảng đ−ợc sử dụng trong câu lệnh. Bạn phải chỉ ra tên bảng bằng cách viết T1.C hoặc T2.C. t−ơng tự nếu bạn lấy từ một bảng T trong cơ sở dữ liệu DB1 và từ bảng T trong cơ sở dữ liệu DB2, bạn phải tham chiếu đến cột trong những bảng đó nh− sau : DB1.T.col_name và DB2.T.col_name.
Cú pháp .Tbl_name có nghĩa là bảng Tbl_name nằm trong cơ sở dữ liệu hiện thời .cú pháp này đ−ợc chấp nhận cho t−ơng thích ODBC bởi vì một số ch−ơng trình ODBC thêm vào đầu tên bảng một dấu chấm ‘.’