Oracle
 sql >> Cơ Sở Dữ Liệu >  >> RDS >> Oracle

Làm thế nào để thu thập dữ liệu từ phân vùng INMEMORY?

Quy trình IMCO (Điều phối viên bộ nhớ) đánh thức hai phút một lần và kiểm tra xem có cần hoàn thành bất kỳ nhiệm vụ dân số nào không. Vì vậy, truy vấn một bảng ngay sau khi bật nó cho inmemory không đảm bảo rằng truy vấn sẽ được phân phát từ inmemory.

Các đối tượng được đưa vào kho lưu trữ cột IM trong danh sách ưu tiên ngay sau khi cơ sở dữ liệu được mở hoặc sau khi các bảng được quét (truy vấn) lần đầu tiên.

Ví dụ:nếu chúng tôi bật bảng tab1, tab2, tab3 cho inmemory:

alter table tab1 inmemory priority medium;
alter table tab3 inmemory priority high;
alter table tab2 inmemory priority critical;

Các bảng này được đưa vào bộ nhớ khi:

  1. Quy trình IMCO chọn các bảng này và tải chúng vào khu vực bộ nhớ (theo thứ tự ưu tiên từ cao nhất đến thấp nhất:tab2, tab3 và tab1)
  2. Nếu chúng tôi thực hiện truy vấn chọn trên bất kỳ bảng nào (ví dụ:select * from tab1 ) trước khi quy trình IMCO bắt đầu (sau mỗi 2 phút)

Để biết liệu một bảng / phân vùng có được tải hoàn toàn vào bộ nhớ hay không, bạn có thể truy vấn v$im_segments xem như sau:

select owner, segment_name, partition_name, segment_type, bytes, 
bytes_not_populated, populate_status from v$im_segments;

Vì vậy, để trả lời câu hỏi của bạn:

  1. Đảm bảo bảng được tải vào inmemory bằng cách truy vấn v$im_segments
  2. Nếu bảng không được tải, hãy thực hiện truy vấn chọn trên đó để tải bảng vào khu vực bộ nhớ
  3. Nhận kế hoạch truy vấn cho truy vấn đã chọn trên bảng, nó sẽ hiển thị INMEMORY như một phần của kế hoạch

Kiểm tra báo cáo chính thức này để biết thêm chi tiết.




  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Trình quản lý API WSO2:chpasswd.sh không hoạt động khi sử dụng cơ sở dữ liệu bên ngoài

  2. Kết nối Python 2.7 với Oracle:mất ký tự (tiếng Ba Lan)

  3. Truy vấn Java với Liên kết DB không đóng kết nối Liên kết Db

  4. Chọn tất cả các cột từ bảng 1 và một cột từ bảng hai được nhóm theo?

  5. Thay đổi kiểu dữ liệu trong oracle mà không xóa dữ liệu