K
Khách

Hãy nhập câu hỏi của bạn vào đây, nếu là tài khoản VIP, bạn sẽ được ưu tiên trả lời.

program uptowin; uses crt; const dong=5; tocdo=1000; var memory:array[1..dong]of word; vt:shortint;thua,Qexit:boolean;x,y,z:word;{x,y,z la bien nhap} dem,key:byte;c:char; {_} function wall(a:word;b:byte):boolean; begin b:=16-b; if odd(a shr (b)) then wall:=true else wall:=false; end; {_} procedure vekhung(x1,y1,x2,y2:word); var z,a,b:word; begin if (x1<>x2) and (y1<>y2) then begin a:=wherex; b:=wherey; if x1>x2 then begin z:=x1; x1:=x2; x2:=z; end; if y1>y2 then begin z:=y1; y1:=y2; y2:=z; end; ...
Đọc tiếp

program uptowin;
uses crt;
const dong=5; tocdo=1000;
var
memory:array[1..dong]of word;
vt:shortint;thua,Qexit:boolean;x,y,z:word;{x,y,z la bien nhap}
dem,key:byte;c:char;
{_}
function wall(a:word;b:byte):boolean;
begin
b:=16-b;
if odd(a shr (b)) then wall:=true
else wall:=false;
end;
{_}
procedure vekhung(x1,y1,x2,y2:word);
var z,a,b:word;
begin
if (x1<>x2) and (y1<>y2) then
begin
a:=wherex; b:=wherey;
if x1>x2 then
begin z:=x1; x1:=x2; x2:=z; end;
if y1>y2 then
begin z:=y1; y1:=y2; y2:=z; end;
gotoxy(x1,y1); write(#201);
if x2-x1>1 then for z:=1 to x2-x1-1 do write(#205);
gotoxy(x2,y1); write(#187);
gotoxy(x1,y2); write(#200);
if x2-x1>1 then for z:=1 to x2-x1-1 do write(#205);
gotoxy(x2,y2); write(#188);
if y2-y1>1 then for z:=1 to y2-y1-1 do begin
gotoxy(x1,z+y1); write(#186); end;
if y2-y1>1 then for z:=1 to y2-y1-1 do begin
gotoxy(x2,z+y1); write(#186); end;
end;
gotoxy(a,b);
end;
function rand:word;
var a:word;b,c:byte;
begin
b:=random(14)+1;
for c:=1 to b do
a:=a+ 1 shl (c-1);
a:=a shl random(14);
rand:=not a;
if (a=0) or (not a=0) then a:=rand;
end;
{_}
procedure run(x:boolean);
var e:byte;
{\}
procedure traiphai(var a:word);
var d:boolean;
begin
if odd(dem+e) then
begin
if a>maxint then
begin d:=true;
a:=a-maxint-1; end
else d:=false;
a:=a shl 1;
if d then a:=a+1;
if (wall(memory[1],vt)) then
vt:=vt-1;
end
else
begin
if odd(a) then
begin a:=a-1;
d:=true; end
else d:=false;
a:=a shr 1;
if d then a:=a+maxint+1;
if (wall(memory[1],vt)) then
vt:=vt+1;
end;
end;
{/}
begin
for e:=1 to dong do
if x and odd(e) then
traiphai(memory[e])
else if not x and not odd(e)then
traiphai(memory[e]);
end;
{_}
procedure draw;
var x,y:byte;
{\}
procedure help;
begin
textcolor(white);
vekhung(51,5,70,22);
vekhung(8,5,25,22);
textcolor(yellow);
gotoxy(54,8);write(' W : Up');
gotoxy(54,11);write(' A : Left');
gotoxy(54,14);write(' D : Right');
gotoxy(54,17);write(' Space : Pause');
gotoxy(54,20);write(' Esc : Exit');
vekhung(54,7,58,9);
vekhung(54,10,58,12);
vekhung(54,13,58,15);
vekhung(54,16,62,18);
vekhung(54,19,60,21);
gotoxy(9,6); write('Go up each floor');
gotoxy(9,7); write(', you will add 1');
gotoxy(9,8); write('bonus. But must');
gotoxy(9,9); write('not passing wall');
gotoxy(11,10); write('Example:');
gotoxy(11,12); write('Can''t go up:');
gotoxy(12,13);write(#219#32#219#219#32#219);
gotoxy(12,14);write(#205#205#205#205#205#205);
gotoxy(12,15);write(' ',#15,' ');
gotoxy(12,17);write('Can go up:');
gotoxy(12,18);write(#219#32#219#219#32#219);
gotoxy(12,19);write(#205#205#205#205#205#205);
gotoxy(12,20);write(' ',#15,' ');
end;
{/}
begin
clrscr;
textcolor(white);
vekhung(20,1,60,3);
gotoxy(30,2); write('*** GO UP TO WIN! ***');
vekhung(28,5,47,22);
textcolor(yellow);
gotoxy(30,7);
writeln(#205#205#205#205#205#205#205#205,
#205#205#205#205#205#205#205#205);
for x:=dong downto 1 do
begin
gotoxy(30,8+(dong-x)*2);
for y:=1 to 16 do
if memory[x] shl (y-1)>maxint-1 then write(#219)
else write(' ');
writeln;
gotoxy(30,8+(dong-x)*2+1);
writeln(#205#205#205,
#205#205#205#205#205#205#205,
#205#205#205#205#205#205);
end;
help;
gotoxy(30,20); write('Lines:',dem,' Key:',key,'/50');
gotoxy(vt+29,16); write(#15);
end;
procedure pause;
begin
clrscr;
vekhung(15,10,65,15);
gotoxy(18,13);
write(' Paused! Press any key to continue...');
readkey;
end;
procedure thuchon;
begin{+3}
c:=readkey;
case upcase(c) of{+4}
'D':if not wall(memory[1],vt+1) then vt:=vt+1;
'A':if not wall(memory[1],vt-1) then vt:=vt-1;
'W':if not wall(memory[2],vt) then begin{+5}
dem:=dem+1;
for z:= 1 to dong-1 do
memory[z]:=memory[z+1];
memory[dong]:=rand;
end;{-5}
' ': pause;
#27:begin
qexit:=true;
thua:=true;
end;
end;{-4}
if upcase(c) in['D','A','W'] then
begin key:=key+1; draw; end;
if key=50 then thua:=true;
end;{-3}

{____Main Program____}
begin
textbackground(blue); textcolor(yellow); clrscr;
randomize;
vekhung(15,10,65,15);
gotoxy(18,13);
write('Press any key to continue...');
repeat x:=random(1); until keypressed;
window(1,1,80,25);
repeat
key:=0;thua:=false;Qexit:=false;
vt:=8;x:=0;clrscr;
for x:=2 to dong do
memory[x]:=rand;
repeat{+0}
draw;
for x:=0 to 1000 do
begin{+1}
if x=0 then
run(true);
if x=500 then
run(false);
for y:=0 to tocdo do
begin{+2}
if keypressed then
thuchon;
if not (vt in[1..16]) then
begin thua:=true; break; end;
end;{-2}
end;{-1}
until thua;
gotoxy(1,4);
for x:= 1 to 80*21 do
begin write(' ');
for y:=1 to 1000 do
for z:=1 to 600 do; end;
textcolor(white);
vekhung(15,11,65,15);
gotoxy(30,11); write(' Infomation ');
textcolor(yellow);
gotoxy(19,12); write('Score: ',dem);
if not qexit then
write(' You are lost!');
gotoxy(19,13); write('Press Enter or Esc to quit!');
gotoxy(19,14); write('Press Space to replay!');
repeat c:=readkey; until c in [#27,#13,#32];
until c in [#27,#13];
end.

Trên là một chương trình game mình soạn trên Free Pascal nhưng không được. Lỗi thì không có rồi. Khi ấn Ctrl+F9 thì có dòng chữ "Press any key to continue", ấn xong thì bị thoát và có dòng chữ mới: "Program.... exited with exitcode = 201".

Ai phát hiện và tìm ra cách sửa lỗi thì báo mình nhé!!!

0
Câu 1: Em đã bôi đen một hàng trong Excel, lệnh nào trong số các lệnh sau cho phép chèn thêm một hàng vào vị trí phía trên hàng đang chọn? A. Vào thực đơn Insert, chọn Rows. B. Vào thực đơn Insert, chọn Columns. C. Vào thực đơn Insert, chọn Object. D. Vào thực đơn Insert, chọn Cells. Câu 2: Để tìm nghiệm của phương trình 2x-5=0 em sử dụng lệnh nào trong phần mềm Toolkit Math? A. expand. B. solve. C. simplify. D....
Đọc tiếp

Câu 1: Em đã bôi đen một hàng trong Excel, lệnh nào trong số các lệnh sau cho phép chèn thêm một hàng vào vị trí phía trên hàng đang chọn?
A. Vào thực đơn Insert, chọn Rows.
B. Vào thực đơn Insert, chọn Columns.
C. Vào thực đơn Insert, chọn Object.
D. Vào thực đơn Insert, chọn Cells.
Câu 2: Để tìm nghiệm của phương trình 2x-5=0 em sử dụng lệnh nào trong phần mềm Toolkit Math?
A. expand. B. solve. C. simplify. D. plot.
Câu 3: Để tăng chữ số thập phân ta nhấn vào nút:
A. . B. . C. . D. .
Câu 4: Theo mặc định ký tự dạng chuỗi được:
A. Canh trái trong ô. B. Canh giữa trong ô.
C. Canh phải trong ô. D. Canh đều hai bên.
Câu 5: Để vẽ đường thẳng đi qua hai điểm, ta sử dụng công cụ vẽ nào sau đây?
A. . B. . C. . D. .
Câu 6: Để vẽ biểu đồ, em sử dụng nút lệnh:
A. . B. . C. . D. .
Câu 7: Câu nào sau đây sai?
A. Định dạng bảng tính làm thay đổi nội dung các ô tính.
B. Định dạng bảng tính không làm thay đổi nội dung các ô tính.
C. Khi cần định dạng ô tính em chọn ô đó.
D. Câu A và B đúng .
Câu 8: Muốn thoát khỏi chế độ lọc dữ liệu, em thực hiện:
A. Chọn DataFilterAutofilter. B. Chọn DataFilterShow all.
C. DataForm. D. Chọn DataFilterAcvanced filter.
Câu 9: Để lựa chọn các vùng liền kề nhau trong bảng tính, bạn cần sử dụng chuột kết hợp với phím nào ?
A. Shift. B. Ctrl.
C. Alt. D. Ctrl và Shift.
Câu 10: Hãy cho biết định dạng dùng nút lệnh nào trong các nút lệnh sau?
A. . B. . C. . D. .
Câu 11: Trong bảng tính Excel, nếu trong một ô tính có các kí hiệu dấu thăng , điều đó có nghĩa là gì?
A. Cột chứa ô đó có độ rộng quá hẹp nên không hiển thị hết chữ số.
B. Chương trình bảng tính bị nhiễm virus.
C. Công thức nhập sai và Excel thông báo lỗi.
D. Hàng chứa ô đó có độ cao quá thấp nên không hiển thị hết chữ số.
Câu 12: Để tính trung bình cộng giá trị các ô từ A2 đến A9, ta sử dụng hàm:
A. =Average(A2;A9). B. =Average(A2,A9).
C. =Average(A2:A9). D. =Average (A2:A9).
Câu 13: Trong khi làm việc với Microsoft Excel, để nhập vào công thức tính toán cho một ô, trước hết ta phải gõ :
A. Dấu bằng(=). B. Dấu hai chấm (:).
C. Dấu đôla ($). D. Dấu chấm hỏi(?).
Câu 14: Các dạng biểu đồ phổ biến nhất là:
A. biểu đồ hình tròn.
B. biểu đồ cột, biểu đồ đường gấp khúc.
C. biểu đồ cột.
D. biểu đồ cột, biểu đồ đường gấp khúc, biểu đồ hình tròn.
Câu 15: Để xem trước trang in, em sử dụng lệnh nào?
A. Print Preview . B. .
C. . D. . .
Câu 16: Muốn vẽ đồ thị của hàm số y = 3x -2, tại cửa sổ dòng lệnh ta gõ:
A. Solve y = 3*x -2. B. Expand 3*x -2.
C. Solve 3*x -2= 0 x. D. Plot y = 3*x -2.
Câu 17: Để chọn hướng giấy in cho trang tính ta chọn lệnh nào trong các lệnh sau?
A. File/ print. B. File/ Save.
C. File/ close. D. File/ page setup.
Câu 18: Để tính tổng các ô từ A1 đến A7, công thức nào dưới đây là đúng?
A. =SUM(A1);SUM(A7).
B. =SUM(A1- A7).
C. =SUM(A1:A7).
D. =SUM(A1):SUM(A7).
Câu 19: Trong Excel để mở tập tin có trong đĩa ta dùng:
A. Chọn File, Open. B. Tổ hợp phím Ctrl + O.
C. Hai câu a và c đúng. D. Tổ hợp phím Ctrl + N.
Câu 20: Để thay đổi cỡ chữ của nội dung các ô tính, ta sử dụng nút lệnh nào?
A. . B. . C. . D. .
Câu 21: Để thực hiện định dạng đường viền cho bảng dữ liệu nằm trong tập tin danh sách lớp, chọn bảng dữ liệu đó, nhấn chuột vào thực đơn lệnh Format - Cells. Trong hộp thoại Format Cells, chọn thẻ:
A. Alignment. B. Border.
C. Font . D. Pattern.
Câu 22: Ô A1 của trang tính có số 1.867. Sau khi chọn ô A1 và nháy chuột 2 lần vào nút . Kết quả hiển thị trong ô A1 sẽ là:
A. 2. B. 1.85. C. 1.9. D. 1.86.
Câu 23: Để in văn bản, em sử dụng nút lệnh:
A. . B. . C. . D. .
Câu 24: Để định dạng dữ liệu tại cột Điểm là kiểu số có một chữ số ở phần thập phân, ta chọn cột dữ liệu, nhắp chuột vào thực đơn lệnh Format, chọn:
A. AutoFormat.
B. Conditional Formatting.
C. Cells.
D. Column.
Câu 25: Để điều chỉnh các trang in được hợp lí, chúng ta phải làm gì?
A. Thay đổi hướng giấy in. B. Định dạng màu chữ.
C. Định dạng phông chữ. D. Điều chỉnh dấu ngắt trang.
Câu 26: Theo mặc định ký tự dạng số được:
A. Canh giữa trong ô. B. Canh phải trong ô.
C. Canh trái trong ô. D. Canh đều hai bên.
Câu 27: Để chọn toàn bộ các ô trên bảng tính bằng tổ hợp phím em chọn:
A. Nhấn tổ hợp phím Ctrl + All.
B. Nhấn tổ hợp phím Ctrl + A.
C. Cả ba cách trên đều được.
D. Nhấn tổ hợp phím Ctrl + Alt +Space.
Câu 28: Trong Microsoft Excel, câu lệnh =MIN(6, 5,- 1, 2, 10, -4, 3, 1, -8) có kết quả là:
A. -8. B. -1. C. 10. D. 1.
Câu 29: Công cụ dùng để làm gì?
A. Vẽ tam giác.
B. Tạo đường thẳng đi qua một điểm cho trước.
C. Tạo giao điểm của hai đối tượng.
D. Tạo đường phân giác của một góc.
Câu 30: Phần mềm Toolkit Math dùng để:
A. Học toán đơn giản.
B. Quan sát và tra cứu bản đồ thế giới.
C. Vẽ hình học động.
D. Luyện gõ phím nhanh.
Câu 31: Trong hộp thoại Page Setup, nút lệnh có chức năng gì?
A. Thiết đặt hướng trang in ngang. B. Định dạng phông chữ.
C. Chèn dấu ngắt trang. D. Thiết đặt hướng trang in đứng.
Câu 32: Công cụ vẽ một đường thẳng đi qua một điểm và vuông góc với đường thẳng khác:
A. . B. . C. . D. .
Câu 33: Để sắp xếp danh sách dữ liệu giảm dần, em làm thế nào?
A. Nháy nút .
B. Nháy chọn 1 ô trong cột cần sắp xếp rồi nháy nút .
C. Nháy chọn 1 ô trong cột cần sắp xếp rồi nháy nút .
D. Nháy nút .
Câu 34: Trong Excel, bạn có thể cho dòng chữ trong một ô hiển thị theo kiểu gì ?
A. Theo chiều thẳng đứng.
B. Cả 3 kiểu trên ngang, đứng, nghiêng.
C. Theo chiều nằm ngang.
D. Theo chiều nghiêng.
Câu 35: Để tạo giao điểm của hai đường thẳng, ta sử dụng công cụ vẽ nào sau đây?
A. . B. . C. . D. .
Câu 36: Phần mềm Geogebra dùng để:
A. Quan sát và tra cứu bản đồ thế giới.
B. Luyện gõ phím nhanh.
C. Học toán đơn giản.
D. Vẽ hình học động.
Câu 37: Để làm phép toán (9/4 + 4/11)/(6/13-6/19), ta dùng lệnh:
A. plot. B. expand. C. solve. D. simplify.
Câu 38: Cách tạo biểu đồ nào sau đây đúng?
A. Nháy nút Chart Wizand/ chọn 1 ô trong miền dữ liệu.
B. chọn 1 ô trong miền dữ liệu.
C. Chọn 1 ô trong mi ền dữ liệu/ nháy nút Chart Wizand/chọn dạng biểu đồ/next/finish.
D. Nháy nút Chart Wizand.
Câu 39: Trong Microsoft Excel, câu lệnh =AVERAGE(5,6,8,9) có giá trị là:
A. 8. B. 7. C. 5. D. 6.
Câu 40: Ô A1 của trang tính có số 3.16, ô B1 có số 8.07, số trong ô C1 được định dạng là số nguyên. Nếu trong ô C1 có công thức =B1-A1, em sẽ nhận được kết quả trong ô đó là:
A. 3. B. 4. C. 4.91. D. 5.

1
23 tháng 4 2019

Giúp mk vs nha

Mọi người giúp mình với ạ <Tin học 12> Câu 45: Hãy sắp xếp các bước đề tạo liên kết bảng là: 1. Chọn Tool \ Relationships 2. Tạo liên kết đôi một giữa các bảng 3. Đóng hộp thoại Relationships/ Yes đề lưu lại 4. Chọn các bảng sẽ liên kết A. 4, 2, 3, 1 B. 1, 4, 2 , 3 C.1 , 2 , 3 , 4 D. 2, 3,4, 1 Câu 46: Trong Access, để tạo mối liên kết giữa các bảng, ta thực hiện : ..... -> Relationships A....
Đọc tiếp

Mọi người giúp mình với ạ <Tin học 12>

Câu 45: Hãy sắp xếp các bước đề tạo liên kết bảng là:

1. Chọn Tool \ Relationships

2. Tạo liên kết đôi một giữa các bảng


3. Đóng hộp thoại Relationships/ Yes đề lưu lại

4. Chọn các bảng sẽ liên kết


A. 4, 2, 3, 1

B. 1, 4, 2 , 3

C.1 , 2 , 3 , 4

D. 2, 3,4, 1


Câu 46: Trong Access, để tạo mối liên kết giữa các bảng, ta thực hiện : ..... -> Relationships
A. Tools

B. Format

C. Insert

D. Edit


Câu 47: Khi muốn thiết lập liên kết giữa hai bảng thì mỗi bảng phải có:
A. Số trường bằng nhau

B. Số bản ghi bằng nhau

C. Khóa chính giống nhau.

D. Tất cả đều sai


Câu 48: Mẫu hỏi thường dùng để:


A. Sắp xếp bản ghi

B. Tổng hợp thông tin

C. Thực hiện tính toán

D. Tât cả đêu đúng


Câu 49: Khi tạo biểu mẫu, ta muốn tính cột tổng điểm là tổng của cột Toán và cột Văn thì biểu thức nào sau đây đúng
A. Tong:=[Toan] + Van

B. Tong:[Toan]+[Van]

C. Tong=Toan+Van

D. Tong:=Toan+Van


Câu 50: Khi tạo biểu mẫu, muốn đếm có bao nhiêu học sinh Nam ta sử dụng hàm nào sau đây?
A. Sum

B. Count

C. Max

D. AVG
Câu 51: Tạo biểu mẫu: Khi muốn đặt điều kiện ta viết điều kiện vào dòng nào trên lưới QBE?


A. Criteria

B. Show _

C. Sort

D. Table


Cau 52: Tao biểu mẫu: Khi muốn đặt một trường nào đó hiển thị hay không ta chọn vào dòng nào trên lưới QBE?
A. Criteria

B. Show

C. Sort

D. Table


Câu 53: Tạo biểu mẫu: Khi muốn thục hiện tính toán ta chọn vào dòng nào trên lưới QBE?
A. Criteria

B. Total

C. Sort

D.Table


Câu 54: Hãy sắp xếp các thao tác tạo biểu mẫu sau đây cho đúng trình tự: (1) Chọn các trường cần thiết (2): Chọn nguồn dữ
liệu (3): Create query in design view (4): Khai báo: điều kiện, sắp xếp, tính toán, gộp nhóm (5): Lưu lại.


A. 3, 2, 1, 4, 5

B.3, 1, 2, 5, 4

C. 3, 1, 2, 4, 5

D. 1, 2, 3, 4, 5


Câu 55: Khi muốn đưa ra DS học sinh, điểm các môn và tổng điểm ta có thể thực hiện thao tác nào sau đây?
A. Lọc theo mẫu

B. Tìm kiếm trong bản

C. Tạo mẫu hỏi

D. Cả 3 đáp án trên


Câu 56: Khi muốn xem dữ liệu được tạo ra bởi mẫu hỏi ta mở mẫu hỏi đó ở chế độ nào
A. Trang dữ liệu

B. Thiết kế

C. A và B


Câu 57: Báo cáo thường được sử dụng nhằm mục đích gì?
A. Cập nhật thông tin

B. Xem thông tin

C. Tổng hợp thông tin

D. Cả B và C


Cau 58: Khi muốn trình bày theo mẫu in an danh sách họ tên học sinh và tông điểm ta có thể tạo ra đối tượng nào?
A. Bảng

B. Biểu mẫu

C. Mẫu hỏi

D. Báo cáo

0
31 tháng 12 2020

A nha

15 tháng 3 2020

Câu 1:

program an_danh;

uses crt;

var tong,n,i: integer;

begin

clrscr;

tong:= 0;

write('Nhap n: ');readln(n);

for i:= 1 to n do tong:= tong + i;

write('Tong tu 1 den ',n,' = ',tong);

readln

end.

Câu 2:

program an_danh;

uses crt;

var tong,i: integer;

begin

clrscr;

tong:= 0;

for i:= 1 to 200 do

tong:= tong + i;

write('Tong 200 so nguyen dau tien: ',tong);

readln

end.

Câu 3:

program an_danh;

uses crt;

var tich:real;

i:integer;

begin

clrscr;

tich:= 1;

for i:= 1 to 30 do

tich:= tich * i;

write('Tich 30 so nguyen dau tien: ',tich:0:0);

readln

end.

Câu 4:

program an_danh;

uses crt;

var gt:real;

i,n: integer;

begin

clrscr;

write('Nhap n: ');readln(n);

gt:= 1;

for i:= 1 to n do gt:= gt * i;

write(n,'! = ',gt:0:0);

readln

end.

Câu 5:

program an_danh;

uses crt;

var x,n,i:integer;

kq:real;

begin

clrscr;

write('Nhap x: ');readln(x);

write('Nhap n: ');readln(n);

kq:= x;

for i:= 2 to n do kq:= kq * x;

write(x,' mu ',n,' = ',kq:0:0);

readln

end.

Câu 1:

uses crt;
var n,i,s:longint;
begin
clrscr;
write('n='); readln(n);
s:=0;
for i:=1 to n do
s:=s+i;
writeln('tong S=',s);
readln;
end.

Câu 2:

uses crt;
var i,s:longint;
begin
clrscr;
s:=0;
for i:=1 to 200 do
s:=s+i;
writeln('tong 200 so nguyen dau tien la: ',s);
readln;
end.

Câu 3:

uses crt;
var i:integer;
s:real;
begin
clrscr;
s:=1;
for i:=1 to 30 do
s:=s*i;
writeln(s:4:0);
readln;
end.

Câu 4:

uses crt;
var n:qword;
i:integer;
s:real;
begin
clrscr;
write('n='); readln(n);
s:=1;
for i:=1 to n do
s:=s*i;
writeln(n,'!=',s:4:0);
readln;
end.

Câu 5:

uses crt;
var n,x,i:longint;
lt:real;
begin
clrscr;
write('co so x='); readln(x);
write('so mu n='); readln(n);
if n>=0 then
begin
lt:=1;
for i:=1 to n do
lt:=lt*x;
writeln(x,'^',n,'=',lt:4:0);
end
else writeln('vui long nhap lai so mu khong am');
readln;
end.

16 tháng 10 2016

Một trong các lý do chính cho việc dùng cơ sở dữ liệu quan hệ, chẳng hạn như Access, là để tránh dữ liệu trùng lặp mà điều đó có thể gây ra nhầm lẫn và rắc rối. Đôi khi, nếu bạn tạo cơ sở dữ liệu bằng cách thu thập dữ liệu từ các hệ thống hiện có, ví dụ như một bộ sổ làm việc Excel, bạn có thể có các dữ liệu trùng lặp cần được giải quyết trước khi bắt đầu sử dụng cơ sở dữ liệu đó. Hơn nữa, nếu không áp dụng một số biện pháp phòng ngừa trong thiết kế (hoặc điều đó là không thực tế vì một lý do nào đó), thì cơ sở dữ liệu đôi khi có thể thu nhận các giá trị trùng lặp, đặc biệt là khi nhiều người dùng nhập dữ liệu cùng một lúc.

Dữ liệu trùng lặp là gì

Thuật ngữ dữ liệu trùng lặp không có nghĩa là có hai bản sao chính xác của cùng một dữ liệu. Thay vào đó, dữ liệu trùng lặp là dữ liệu hơi khác nhưng cùng tham chiếu đến một thứ, chẳng hạn như một vài dữ liệu khác. Nó có thể không sai – ví dụ như tên đầy đủ có và không có tên đệm.

Dữ liệu trùng lặp có thể xuất hiện ở nhiều mức độ khác nhau:

  • Hai hoặc nhiều bản ghi có thể chứa các trường trùng lặp.    Hai bản ghi có thể được xem là trùng lặp ngay cả khi không phải tất cả các trường của các bản ghi đó có chứa các giá trị khớp nhau. Ví dụ, trong hình này, bạn sẽ thấy hai bản ghi cho Antonio Moreno Taquería.

    Các bản ghi trùng lặp cho một khách hàng trong bảng Khách hàng

    Ngay cả khi mỗi bản ghi có ID khách hàng duy nhất (giá trị ở cột ngoài cùng bên trái), các giá trị trong các trường Tên, Địa chỉ và Thành phố vẫn khớp nhau. Có lẽ một bản ghi được tạo hai lần cho một khách hàng hoặc có thể có lý do chính đáng rằng hai khách hàng thuộc cùng một công ty. Bạn sẽ phải dùng kiến thức trong công việc của mình để xem lại các bản ghi đó xem chúng có phải là bản trùng lặp hay không.

  • Hai hoặc nhiều bảng có thể có chứa dữ liệu tương tự nhau.    Ví dụ, bạn có thể thấy cả bảng Khách hàng và bảng Khách mua đều có chứa các bản ghi cho cùng một khách hàng.

    Bảng Khách mua và bảng Khách hàng có dữ liệu chồng chéo

    Ngay cả khi các bảng đó có thể có cấu trúc khác nhau một chút nhưng cả hai bảng đều chứa cùng một loại thông tin — dữ liệu khách hàng — vì vậy, bạn cần cân nhắc tạo bảng mới bằng cách kết hợp chúng.

  • Hai hoặc nhiều cơ sở dữ liệu có thể chứa dữ liệu tương tự nhau.    Nếu bạn thấy hai hoặc nhiều cơ sở dữ liệu có chứa dữ liệu tương tự nhau hoặc bạn thừa kế một cơ sở dữ liệu có nội dung chồng chéo với cơ sở dữ liệu hiện thời của mình, bạn cần so sánh dữ liệu và cấu trúc của các cơ sở dữ liệu đó rồi thực hiện những bước cần thiết để hợp nhất chúng.

    So sánh cơ sở dữ liệu theo cách thủ công, ngay cả đối với cơ sở dữ liệu nhỏ, không phải là một việc dễ dàng. Nếu bạn cần trợ giúp để so sánh, một vài nhà cung cấp bên thứ ba có bán các công cụ để so sánh nội dung và cấu trúc của cơ sở dữ liệu Access.

    QUAN TRỌNG: Nếu bạn thực hiện các bước để loại bỏ dữ liệu trùng lặp khỏi các bảng và bạn vẫn thấy dữ liệu trùng lặp trong một biểu mẫu hoặc báo cáo, đó có thể là do thiết kế biểu mẫu hoặc báo cáo không chính xác. Hãy bảo đảm các bảng và truy vấn ẩn dưới được nối đúng cách và các phần biểu mẫu hoặc báo cáo không bao gồm nhiều điều khiển được kết nối với cùng một nguồn điều khiển. Để biết thêm thông tin về thiết kế báo cáo, hãy xem bài viết Giới thiệu về báo cáo.

Những gì không phải là dữ liệu trùng lặp

  • Đôi khi hai hoặc nhiều bản ghi có bộ giá trị chung nhưng chúng sẽ không tham chiếu đến cùng một thứ. Ví dụ, nhiều khách hàng có thể có tên đầy đủ là John Smith, nhưng các giá trị đó không phải là giá trị trùng lặp vì chúng tham chiếu đến những người khác nhau. Khi điều đó xảy ra, bạn sẽ không có nguy cơ gặp dữ liệu trùng lặp với điều kiện là các trường khác trong cơ sở dữ liệu của bạn (chẳng hạn như trường ID, tên người dùng, địa chỉ hoặc mã bưu chính) có chứa đủ thông tin duy nhất để tránh cho các bản ghi bị coi là trùng lặp.

  • Dữ liệu do truy vấn trả về có thể có vẻ như chứa các bản ghi trùng lặp nếu truy vấn đó không bao gồm các trường nhận dạng duy nhất từng bản ghi. Ví dụ, bảng này hiện dữ liệu do truy vấn trả về:

    Dạng xem không bao gồm trường có thể nhận dạng duy nhất các bản ghi

    Một vài hàng trong kết quả truy vấn có vẻ như trùng lặp. Tuy nhiên, cũng truy vấn đó kèm theo trường khóa chính cho biết rằng mỗi bản ghi thực sự là duy nhất:

    Bây giờ dạng xem bao gồm trường OrderID để loại bỏ các bản ghi trùng lặp

    Để tránh sự nhầm lẫn này, khi tạo truy vấn, bạn hãy đưa vào đó các trường nhận dạng duy nhất mỗi bản ghi. Trường khóa chính có thể thực hiện chức năng này nhưng bạn cũng có thể dùng kết hợp các trường khác thay vào đó. Ví dụ, bạn có một tên liên hệ thường gặp lặp lại nhiều lần và một tên thành phố lặp lại nhiều lần, nhưng nếu bạn đưa vào đó số điện thoại và địa chỉ, thì tổ hợp dữ liệu đó có thể đủ để khiến cho mỗi bản ghi trở thành duy nhất.

Giải quyết và ngăn chặn dữ liệu trùng lặp

Để giải quyết dữ liệu trùng lặp, hãy sửa hoặc xóa bỏ dữ liệu đó.

  • Bạn hãy sửa bản ghi trùng lặp nếu nó thực sự biểu thị một thực thể riêng biệt – ví dụ, một khách hàng không có bản ghi nào khác – và trùng lặp với một bản ghi nào đó khác do nhầm lẫn nào đó, có lẽ do nhập sai.

  • Bạn hãy xóa bỏ bản ghi trùng lặp nếu nó không biểu thị một thực thể nào khác; tức là có bản ghi khác cho cùng một thực thể mà bạn muốn dùng.

  • Trong một số trường hợp, bạn sẽ xóa bỏ một mục trùng lặp và sửa mục còn lại bởi vì cả hai bản ghi đều không hoàn toàn chính xác. Nếu bạn muốn xóa bỏ từ một bảng liên quan đến các bảng khác, bạn có thể cần bật xóa xếp tầng cho một số quan hệ.

Để giúp ngăn chặn dữ liệu trùng lặp, hãy bạn hãy cân nhắc những điều sau đây:

  • Hãy bảo đảm mỗi bảng của bạn có một khóa chính

  • Nếu có nhiều trường không phải là một phần của khóa chính nhưng phải chứa các giá trị duy nhất, hãy tạo chỉ mục duy nhất cho các trường đó

  • Hãy cân nhắc tạo biểu mẫu cho việc nhập dữ liệu và dùng các hộp danh sách trên các biểu mẫu đó để giúp tìm các giá trị hiện có dễ dàng hơn

Đầu Trang

Trước khi bạn bắt đầu

Trước khi bạn bắt đầu xóa bỏ dữ liệu trùng lặp, hãy thực hiện các bước sau đây:

  • Hãy đảm bảo tệp cơ sở dữ liệu không ở dạng chỉ đọc.

  • Nếu người khác dùng cơ sở dữ liệu của bạn và bạn muốn giảm thiểu sự gián đoạn dịch vụ của họ, hãy yêu cầu họ đóng các đối tượng mà bạn muốn thao tác. Nếu không, có thể xảy ra xung đột dữ liệu.

  • Nếu có thể chấp nhận việc cơ sở dữ liệu không sẵn dùng trong khi bạn làm việc với chúng, hãy mở cơ sở dữ liệu trong chế độ riêng. Để làm như vậy, hãy bấm vào tab Tệp rồi bấm Mở. Trong hộp thoại, hãy duyệt và chọn cơ sở dữ liệu, bấm vào mũi tên bên cạnh nút Mở, rồi bấm Mở Riêng.

    Mở tệp trong chế độ Mở riêng