1 bài tập cơ bản của Access mà mình ko hiểu...

hotmitXXX

New Member
Hội viên mới
Mình mới học access được 3 ngày. ban đầu thầy có giảng phần khoá chính nhưng mình không hiểu lắm:roile:....
Chẳng hạn như để quản lý sinh viên trong trường học thì cần có Mssv và mssv là khoá chính vì không được trùng lặp. nhưng khi thi cử thì mssv lại không là khoá chính vì không phải sinh viên chỉ thi 1 môn . đó là lời thầy mình giảng nhưng mình chả hiểu gì cả. Trường hợp đó cũng như trường hợp của bảng chấm công sau đây: Để quản lý nhân viên trong công ty thì mã nhân viên cần phải thiết lập khoá chính, nhưng khi chấm công thì lại không thiết lập khoá chính cho mã nhân viên. Mình ko hiểu sao lại thế nữa. Bạn nào rành rọt dìa access cũng như khoá chính của nó thì giải đáp thắc mắc dùm mình nha.
71102776.jpg

56013532.jpg

Đây là bài tập về bảng chấm công của mình. Nó còn bảng hồ sơ nhân viên nữa nhưng trường hợp này mình hiểu vì khoá chính là mã nhân viên. Còn trường hợp bảng cấm công thì mình hỏng hiểu. Đề cho sẵn là cái bảng đó không hề có khoá chính :roile:
Chỉ mình nha mấy bạn . Cảm ơn các bạn:kissanh:
 
Ðề: 1 bài tập cơ bản của Access mà mình ko hiểu...

Khoá chính : có thể hiểu nó là một bí danh của dòng dữ liệu đó. Đã là bí danh thì không được trùng. Một bảng có thể có nhiều khoá chính hoặc không có khoá chính nào. Nếu như có nhiều khoá chính thì tất cả các dữ liệu của các khoá chính trên dòng này không được trùng với tất cả các dữ liệu của khoá chính trên dòng khác. Hay nói một cách nôn na cho dễ hiểu, trên bảng có bao nhiêu khoá chính thì kệ nó, ta cứ tưởng tượng rằng tất cả các khoá chính đó nối lại với nhau thành một khoá chính và cái này là cái "bí danh" để phân biệt dòng này với dòng khác.
Trong bảng chấm công vì có thể trùng lặp ngày công,có nhiều người 24 công trong tháng chẳng hạn,nên nếu bạn đặt khoá chính thì gây ra trùng lắp.Không nhất thiết!
 
Ðề: 1 bài tập cơ bản của Access mà mình ko hiểu...

Khoá chính : có thể hiểu nó là một bí danh của dòng dữ liệu đó. Đã là bí danh thì không được trùng. Một bảng có thể có nhiều khoá chính hoặc không có khoá chính nào. Nếu như có nhiều khoá chính thì tất cả các dữ liệu của các khoá chính trên dòng này không được trùng với tất cả các dữ liệu của khoá chính trên dòng khác. Hay nói một cách nôn na cho dễ hiểu, trên bảng có bao nhiêu khoá chính thì kệ nó, ta cứ tưởng tượng rằng tất cả các khoá chính đó nối lại với nhau thành một khoá chính và cái này là cái "bí danh" để phân biệt dòng này với dòng khác.
Trong bảng chấm công vì có thể trùng lặp ngày công,có nhiều người 24 công trong tháng chẳng hạn,nên nếu bạn đặt khoá chính thì gây ra trùng lắp.Không nhất thiết!

Ủa 1 bảng sao có nhiều khoá chính được bạn, 1 bảng có thể không có khoá chính nào thì được chứ nhiều khoá chính thì sao được hả bạn? Mình hỏng hiểu? với lại làm thử trên access cũng đâu chọn được nhiều khoá chính đâu bạn. Đúng là ngày công có sự trùng lắp thì ko thể đặt khoá chính nhưng mã nhân viên đâu trùng nhau đâu mà mình ko dược đặt khoá chính nhỉ? :roile:
Àh và cái bảng của mình đưa ra là ko có 1 cái khoá chính nào cả..hì
 
Ðề: 1 bài tập cơ bản của Access mà mình ko hiểu...

sao lại không?bạn ko hiểu bản chất của khoá chính rùi.Bạn đọc sách và hỏi thầy thêm nha.
 
Ðề: 1 bài tập cơ bản của Access mà mình ko hiểu...

sao lại không?bạn ko hiểu bản chất của khoá chính rùi.Bạn đọc sách và hỏi thầy thêm nha.

Òh..thì ra là bôi đen các field là có thể đặt khoá cho tất cả. Nhưng do mới học có 3 ngày hà nên mình chưa có gặp trường hợp nào mà phải đặt nhìu khoá cả..hì:xinloinhe:...Nhưng giờ vấn đề là ở bài tập trên chỗ MaNV ko có đặt khoá chính, mình vẫn ko hỉu chỗ này:roile:..bạn có thể nói cho mình biết lý do được không?:rachoa:..chờ hỏi thầy phải tới thứ 3 lận..còn lâu quá hà:chetroi:
À mà đặt nhiều khoá chính có phải ở phần nâng cao ko bạn :xinloinhe:
 
Ðề: 1 bài tập cơ bản của Access mà mình ko hiểu...

Mình mới học access được 3 ngày. ban đầu thầy có giảng phần khoá chính nhưng mình không hiểu lắm:roile:....
Chẳng hạn như để quản lý sinh viên trong trường học thì cần có Mssv và mssv là khoá chính vì không được trùng lặp. nhưng khi thi cử thì mssv lại không là khoá chính vì không phải sinh viên chỉ thi 1 môn . đó là lời thầy mình giảng nhưng mình chả hiểu gì cả. Trường hợp đó cũng như trường hợp của bảng chấm công sau đây: Để quản lý nhân viên trong công ty thì mã nhân viên cần phải thiết lập khoá chính, nhưng khi chấm công thì lại không thiết lập khoá chính cho mã nhân viên. Mình ko hiểu sao lại thế nữa. Bạn nào rành rọt dìa access cũng như khoá chính của nó thì giải đáp thắc mắc dùm mình nha.
71102776.jpg

56013532.jpg

Đây là bài tập về bảng chấm công của mình. Nó còn bảng hồ sơ nhân viên nữa nhưng trường hợp này mình hiểu vì khoá chính là mã nhân viên. Còn trường hợp bảng cấm công thì mình hỏng hiểu. Đề cho sẵn là cái bảng đó không hề có khoá chính :roile:
Chỉ mình nha mấy bạn . Cảm ơn các bạn:kissanh:

Khóa chính là một trường mà Access sử dụng để sắp xếp bảng. Thông thường, một khóa chính là duy nhất, nghĩa là chỉ có một bản ghi với duy nhất một mã khóa chính, Access sẽ không cho phép bạn thêm một bản ghi nếu nó trùng với khóa chính ở bản ghi khác.

Ví dụ, nếu bạn có 3 người bạn có cùng họ Phạm, bạn không thể sử dụng tên họ là khóa chính. Tương tự như vậy, nếu tất cả đều sống ở Hồ Chí Minh, bạn không thể sử dụng thành phố là một khóa chính. Tuy nhiên, họ có các số điện thoại riêng cố định nên có thể sử dụng trường điện thoại làm khóa chính.

Khi chọn một trường làm khóa chính, bạn nên lựa chọn trường gần như là duy nhất thì tốt hơn, bất chấp việc bạn cho phép lặp lại hay không.

Ngoài ra, có thể sử dụng nhiều trường để xác định khóa. Tuy nhiên, bạn không thể sử dụng Table Wizard để làm việc đó. Thay vì vậy, bạn phải tạo bảng bằng tay.

Một khóa chính được xác định để Access sắp xếp thông tin trong bảng. Mặc dù bạn không cần định nghĩa khóa chính, Access sẽ thực hiện chức năng này có hiệu quả hơn nếu bạn định nghĩa khóa chính đó. Sử dụng một khóa chính, Access có thể định vị và hiển thị bản ghi rất nhanh. Thực hiện sự cải tiến này sẽ rất quan trọng khi bạn thêm nhiều bản ghi vào cơ sở dữ liệu.

Access cho phép xác định cả khóa duy nhất lẫn khóa không phải duy nhất. Sử dụng khóa duy nhất tốt hơn vì nó cải thiện được thời gian tìm kiếm. Tuy nhiên, có thể có tình huống khóa duy nhất là không được. Ví dụ, bạn muốn dùng tên thành phố làm khóa. Một khi có nhiều thành phố cùng tên đó, bạn muốn chỉ rõ khóa đó không phải là duy nhất
-----------------------------------------------------------------------------------------
Òh..thì ra là bôi đen các field là có thể đặt khoá cho tất cả. Nhưng do mới học có 3 ngày hà nên mình chưa có gặp trường hợp nào mà phải đặt nhìu khoá cả..hì:xinloinhe:...Nhưng giờ vấn đề là ở bài tập trên chỗ MaNV ko có đặt khoá chính, mình vẫn ko hỉu chỗ này:roile:..bạn có thể nói cho mình biết lý do được không?:rachoa:..chờ hỏi thầy phải tới thứ 3 lận..còn lâu quá hà:chetroi:
À mà đặt nhiều khoá chính có phải ở phần nâng cao ko bạn :xinloinhe:

Bạn có thể tham khảo video tại đây để biết thêm chi tiết nhé

http://baigiang.violet.vn/present/show?entry_id=3290420

Thân
 
Sửa lần cuối:
Ðề: 1 bài tập cơ bản của Access mà mình ko hiểu...

Nếu theo định nghĩa một cách chính quy thì các bạn sẽ phải "học chính quy" mới có thể hiểu một cách chính quy. :xinloinhe:

Nhưng nếu hiểu theo kiểu giang hồ thì như thế này:

Khóa chính (Primary Key) là một thiết lập dùng để phân biệt sự khác nhau giữa 2 record. Nó giống như "đặc điểm nhận dạng" vậy đó.

VD: Để quản lý nhân khẩu, mỗi người có một số CMND. Để quản lý thuế thu nhập cá nhân, mỗi người có một mã số thuế vậy.

Ngoài chức năng đó, trong CSDL quan hệ, khóa chính còn được sử dụng để làm khóa quan hệ giữa table đó với một hay nhiều table khác.

Đặc tính của khóa chính là:

Có thể lấy giá trị của một hay nhiều field của table để làm khóa quan hệ
Giá trị của field làm khóa chính (hoặc giá trị ghép nếu khóa chính nhiều field) không được Null và không được trùng lặp ở những record khác nhau.

Tùy theo tính chất của table mà chúng ta thiết lập khóa chính. VD:

Quản lý nhân viên: dùng mã số nhân viên làm khóa chính trong table hồ sơ nhân viên
Quản lý học sinh: dùng mã số học sinh làm khóa chính trong table hồ sơ học sinh
...
 
Ðề: 1 bài tập cơ bản của Access mà mình ko hiểu...

Vấn đề để bạn xác định đâu là khoá chính và tại sao phải đặt khoá chính la như thế này. Khi bạn bắt đầu xây dựng 1 CSDL, bạn phải tự trả lời cho mình CSDL của mình phải có mấy thực thể ( Entity ) và mỗi thực thể phải có những thuộc tính gì (attribute ).
Vi dụ : CSDL bán hàng chẳng hạn có 2 thực thể Mặt hàng và Giao dịch
Thực thể Mặt hàng có thuộc tính mã item, tên items, giá nhập, giá bán, ngày mua...
Thực thể Giao dịch có thuộc tính mã giao dịch, ngày giao dịch, người bán,tổng tiền...
Và 2 thực thể này quan hệ với nhau theo kiểu nhiều - nhiều .Vì 1 giao dịch có thể bán nhiều mặt hàng, và 1 mặt hàng có thể được bán bởi nhiều giao dịch. Và giữa chúng sẽ phát sinh mối quan hệ gọi là Chi tiết giao dịch.
Chi tiết giao dịch có mã item, mã giao dịch, ten mặt hàng,giá bán...
Và tại sao phải đặt khóa chính cho 2 thực thể Mặt hàngGiao dịch, vì để phân biệt tính duy nhất cho mỗi đối tượng, mỗi mặt hàng.
Nguyên tắc đặt khóa chính bạn sẽ dựa vào trường nào có giá trị là duy nhất, như mã sản phẩm chẳng hạn. Những thực thể nào có từ 2 khóa chính người ta gọi là Khóa tổ hợp ( Composite key ) , còn những khóa có thể làm khóa chính gọi là khóa Ứng viên ( Candidate key).
Sau khi đặt khóa chính cho 2 thực thể trên, tiếp đó bạn phải đặt khóa cho mối quan hệ Chi tiết giao dịch, với mối quan hệ bạn hoặc là để cả 2 khóa chính(khóa tổ hợp) hoặc không. Lý do đơn giản thế này nếu bạn lại đặt mã item trong Chi tiết giao dịch là khóa chính thì mối quan hệ của Chi tiết giao dịchMặt hàng sẽ là quan hệ 1 - 1 và như thế xuất hiện lỗi vì bạn chỉ có thể bán 1 mặt hàng 1 lần duy nhất, rồi đóng cửa hàng nghỉ hưu. Vì nó là bản ghi chính thì nó sẽ không cho trùng lặp.
 

CẨM NANG KẾ TOÁN TRƯỞNG


Liên hệ: 090.6969.247

KÊNH YOUTUBE DKT

Cách làm file Excel quản lý lãi vay

Đăng ký kênh nhé cả nhà

SÁCH QUYẾT TOÁN THUẾ


Liên hệ: 090.6969.247

Top