Luận văn Phân tích và xây dựng chức năng giám định tự động trong hệ thống giám định bảo hiểm xã hội

Luận văn đã trình bày kiến trúc hướng dịch vụ SOA, phương pháp xây dựng một ứng dụng dựa trên kiến trúc hướng dịch vụ SOA cụ thể là phương pháp top-down. Từ đó áp dụng vào bài toán giám định tự động. Luận văn đã phân tích và xây dựng thành công: - Bộ service giám định hồ sơ: GetDataKB, ProcessDataKB, SendDataKB - Bộ service giám định danh mục: GetData, ProcessData, SendData - Bộ quy tắc hồ sơ: Quy tắc thẻ, quy tắc mức hưởng, quy tắc thuốc, quy tắc dịch vụ kỹ thuật, quy tắc vật tư y tế và quy tắc khác về máu, thanh toán ngày giường - Bộ quy tắc danh mục: Quy tắc thuốc thầu tỉnh, vật tư thầu tỉnh, thuốc bệnh viện, dịch vụ kỹ thuật bệnh viện, vật tư y tế bệnh viện. Hiện tại bộ service hồ sơ có thể xử lý được khoảng trên 40 hồ sơ/giây, đóng vai trò đắc lực hỗ trợ giám định viên phát hiện xử lý sai phạm trong quá trình thanh quyết toán bảo hiểm y tế. Giúp tiết kiệm ngân sách hàng năm của nhà nước. Nhưng hạn chế của giải pháp này là phải định nghĩa trước được bộ quy tắc cần phải chạy, vì vậy trong tương lai định hướng phát triển của em sẽ theo hướng mà sẽ mã hóa các bộ quy tắc trước được lưu trữ trong file hoặc database dưới dạng chuỗi base64 hoặc json. Trong service ProcessDataKB thực hiện giám định, sẽ cần phát triển tính năng đọc được chuỗi mã hóa quy tắc để tìm ra những quy tắc giám định. Với giải pháp này khi thêm quy tắc mới chỉ cần thêm một chuỗi mã hóa quy tắc mà không cần sửa lại service xử lý. Hiện tại với giám định tự động chưa có yêu cầu công khai như một dịch vụ nhưng trong tương lai giám định tự động có thể sẽ được công khai rộng rãi như một dịch vụ, để các cơ sở thực hiện giám định tự động trước khi gửi hồ sơ để tránh sai phạm, mất thời gian gửi dữ liệu. Chức năng sẽ công khai một đầu webservice để cơ sở thực hiện gửi hồ sơ dạng file xml, tận dụng các bộ service nghiệp vụ như hiện tại để xử lý và trả lại kết quả cho webservice thông qua hệ thống message queue.

pdf96 trang | Chia sẻ: yenxoi77 | Lượt xem: 578 | Lượt tải: 0download
Bạn đang xem trước 20 trang tài liệu Luận văn Phân tích và xây dựng chức năng giám định tự động trong hệ thống giám định bảo hiểm xã hội, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
ssage Broker). Một trong những hệ thống message broker phổ biến cũng như dễ sử dụng hiện nay là RabbitMQ, về rabbitMQ thì đã được trình bày trong phần giám định hồ sơ. Cơ sở dữ liệu: Oracle 11g 64bit Ngôn ngữ lập trình: C# trên môi trường .Net 4.0, công cụ lập trình Visual Studio 15. Các thư viện client sử dụng sẽ được trình bày chi tiết hơn ở chương 4. 3.2.2.8. Các quy tắc giám định danh mục  Danh mục thuốc tỉnh: - A1_1: Thuốc không có số đăng ký Trường hợp thuốc phóng xạ và vị thuốc y học cổ truyền thì không có số đăng ký nên sẽ bỏ qua còn những trường hợp khác không có số đăng ký sẽ cảnh báo (DM_THUOC_THAU.SODK == null). - A1_2: Thuốc chưa được kê khai Thuốc cần kê khai với cục quản lý dược để cấp số đăng ký, vì vậy tìm kiếm với số đăng ký được gửi lên trong danh mục kê khai kê khai lại của cục quản lý dược nếu không tìm thấy thì từ chối duyệt những thuốc này (DM_THUOC_KK). - A1_3: Thuốc vượt giá kê khai kê khai lại 64 Với những thuốc đã được kê khai, cần kiểm tra giá khi gửi lên với giá thuốc khi kê khai bên cục quản lý, nếu giá thuốc gửi lên mà cao hơn thì sẽ từ chối duyệt những thuốc giá cao hơn (DM_THUOC_THAU.GIA > DM_THUOC_KK.GIA). - A1_5: Thuốc ngoài danh mục Bộ Y tế Tùy trường hợp thuốc là đơn chất hay đa chất có quy định, đa chất không có quy định mà kiểm tra tìm kiếm trong Thông tư 40 (DM_HOATCHAT) hay Thông tư 05 (DM_THUOCYHCT). Khi không tìm thấy sẽ tiến hành cảnh báo thuốc này. - A1_6: Không có thuốc được cấp số đăng ký có cùng đường dùng và ngày công bố phù hợp Với trường hợp thuốc phóng xạ và vị thuốc y học cổ truyền thì không có số đăng ký, còn những trường hợp còn lại có số đăng ký, cần kiểm số đăng ký này trên cục quản lý dược. Nếu không có thuốc nào được tìm thấy thì từ chối thuốc được gửi lên (DM_THUOC). - A1_8: Thuốc kết hợp Vitamin sai quy định Chỉ kiểm tra với những đa chất không có quy định tại Thông tư 40 (DM_HOATCHAT). Theo quy định hoạt chất vitamin không được kết hợp với một hoạt chất khác không cùng nhóm vitamin nên sẽ kiểm tra nếu thuốc đa chất không có quy định mà có vitamin kết hợp với một hoặc nhiều hoạt chất không cùng nhóm vitamin thì sẽ tiến hành cảnh báo (Kiểm tra các hoạt chất trong của thuốc, từ MA_THUOC). - A1_9: Sai hoạt chất Với trường hợp thuốc tân dược, kiểm tra với Thông tư 40 nếu tên hoạt chất của thuốc được gửi lên khác so với hoạt chất được quy định với Thông tư 40 thì tiến hành cảnh báo (tìm trong DM_HOATCHAT theo mã hoạt chất trong DM_THUOC_THAU.MA_THUOC, kiểm tra DM_THUOC_THAU.TEN với DM_HOATCHAT.TEN). - A1_10: Đa chất kết hợp sai đơn chất 65 Với trường hợp đa chất được kết hợp bởi nhiều đơn chất, cần kiểm tra từng đơn chất có tồn tại trong Thông tư 40 hay Thông tư 05 hay không (DM_HOATCHAT với DM_THUOCYHCT). Nếu tồn tại một đơn chất không tồn tại thì tiến hành cảnh báo vi phạm. - A1_11: Đa chất kết hợp sai đường dùng Với trường hợp đa chất kết hợp bởi nhiều đơn chất, những đơn chất đã tồn tại trong Thông tư 40 hay Thông tư 05 (DM_HOATCHAT, DM_THUOCYHCT) thì cần kiểm tra những đơn chất này có cùng đường dùng hay nhóm đường dùng được quy định ở Thông tư 40, Thông tư 05 hay không. Nếu tồn tại một đơn chất mà đường dùng khác hoặc đường dùng không thuộc nhóm đường dùng thì tiến hành cảnh báo vi phạm.  Danh mục vật tư tỉnh: - A3_16: Không nằm trong danh mục dùng chung Bộ y tế Cần kiểm tra vật tư được gửi lên có trong danh mục vật tư mà Bộ y tế ban hành hay không (DM_VATTU). Nếu vật tư gửi lên không nằm trong danh mục vật tư của Bộ y tế thì sẽ bị từ chối phê duyệt (DM_VATTU_THAU). - A3_17: Sai tên vật tư y tế Khi vật tư gửi lên đã có trong danh mục vật tư mà Bộ y tế ban hành (DM_VATTU), cần kiểm tra tên của vật tư gửi lên có giống với tên của vật tư mà Bộ y tế ban hành hay không. Nếu không giống thì cần cảnh báo (DM_VATTU_THAU.TEN != DM_VATTU.TEN). - A3_18: Vật tư y tế không thanh toán riêng Có những vật tư sẽ không được thanh toán riêng nếu thanh toán một mình vì vậy khi vật tư đã có trong danh mục vật tư mà Bộ y tế ban hành (DM_VATTU), nếu vật tư này không được thanh toán riêng thì cần từ chối phê duyệt (DM_VATTU.KHONGTHANHTOANRIENG == 1).  Danh mục thuốc bệnh viện: - B1_20: Thuốc kết hợp nhiều đường dùng khác nhau 66 Với thuôc tân dược, trường hợp đa chất được kết hợp bởi nhiều đơn chất, cần kiểm tra tất cả các đơn chất được kết hợp có cùng đường dùng hoặc nhóm đường dùng. Nếu tồn tại một hoặc nhiều đơn chất mà không có cùng đường dùng hoặc nhóm đường dùng thì sẽ cảnh báo (từ DM_THUOC_BV.MA -> lấy trong DM_HOATCHAT.DUONGDUNG). - B1_21: Thuốc tân dược không có số đăng ký Trường hợp thuốc tân dược gửi lên không có số đăng ký cần cảnh báo để giám định viên biết (DM_THUOC_BV.LOAITHUOC == 1 và DM_THUOC_BV.SODK == null). - B1_22: Thuốc không có tên hoạt chất/ đường dùng Trường hợp thuốc tân dược (DM_THUOC_BV.LOAITHUOC == 1) gửi lên không có tên hoạt chất hoặc đường dùng cần cảnh báo để giám định viên biết. (DM_THUOC_BV.HOATCHAT == null hoặc DUONGDUNG == null). - B1_23: Tân dược nằm ngoài danh mục Trường hợp thuốc tân dược, đơn chất hay đa chất có quy định hay đa chất không có quy định, cần kiểm tra các hoạt chất của thuốc tồn tại trong Thông tư 40 (DM_HOATCHAT) hoặc Thông tư 05 (DM_THUOCYHCT). Nếu tồn tại một hoặc nhiều hoạt chất không tồn tại trong Thông tư 40 hoặc Thông tư 05 thì sẽ từ chối phê duyệt thuốc. - B1_25: Thuốc sử dụng sai hạng Với thuốc tân dược, trong Thông tư 40 có quy định về hạng bệnh viện được sử dụng các loại thuốc khác nhau, vì vậy cần kiểm tra thuốc được dùng tại cơ sở gửi lên có đúng hạng đã được quy định trong Thông tư 40 hay không. Nếu sử dụng sai hạng sẽ cảnh báo (DM_HOATCHAT.HANG != CSKCB.HANGBV). - B1_26: Thuốc vượt giá kê khai kê khai lại Với thuốc tân dược, khi cơ sở gửi thuốc lên giám định, cần kiểm tra giá thuốc của cơ sở gửi lên so với giá thuốc mà cục quản lý dược quản lý. Nếu giá thuốc cơ sở 67 gửi lên cao hơn giá thuốc cục quản lý dược quản lý thì sẽ bị từ chối phê duyệt (DM_THUOC_BV.GIA > DM_THUOC_KK.GIA). - B1_27: Thuốc tân dược vượt giá đấu thầu Với thuốc tân dược (DM_THUOC_BV.LOAITHUOC == 1), khi cơ sở gửi thuốc lên giám định cũng cần kiểm tra giá thuốc của cơ sở gửi lên so với giá thuốc mà tỉnh đã đấu thầu. Nếu giá thuốc cơ sở gửi lên cao hơn giá thuốc tỉnh đã đấu thầu thì sẽ bị từ chối phê duyệt (DM_THUOC_BV.GIA > DM_THUOC_THAU.GIA). - B1_28: Thuốc kết hợp nhóm Vitamin ngoài quy định Với thuốc tân dược, đa chất mà có chứa đơn chất là vitamin (mã nhóm chứa .A27). Theo quy định vitamin sẽ chỉ được kết hợp với các đơn chất là cùng vitamin hoặc nhóm vitamin. Cần kiểm tra các đơn chất của thuốc, nếu tồn tại một đơn chất khác nhóm vitamin thì cần cảnh báo thuốc. - B1_30: Thuốc tân dược ngoài thầu Với thuốc tân dược, khi cơ sở gửi lên giám định, cần kiểm tra lại so với dữ liệu đấu thầu của tỉnh (DM_THUOC_THAU), nếu thuốc cơ sở gửi lên không tồn tại trong dữ liệu đấu thầu của tỉnh thì sẽ bị từ chối phê duyệt. - B1_31: Thuốc phối hợp có sử dụng nhóm điều trị ung thư Với thuốc tân dược, đa chất mà có chứa hoạt chất có mã nhóm điều trị ung thư (mã nhóm chứa .A.8.1). Cần kiểm tra cơ sở đấy có được sử dụng thuốc điều trị ung thư hay không (COSO_KCB.UNGTHU != 1). Nếu không được điều trị cần từ chối phê duyệt. - B1_32: Thuốc sai tên hoạt chất Với thuốc tân dược (DM_THUOC_BV.LOAITHUOC == 1), cần kiểm tra từng tên hoạt chất cấu thành thuốc mà cơ sở gửi lên so với Thông tư 40. Nếu tên hoạt chất khác nhau cần cảnh báo vi phạm (DM_THUOC_BV.HOATCHAT != DMHOATCHAT.TEN). - B1_33: Thuốc sai tên đường dùng 68 Với thuốc tân dược, cần kiểm tra đường dùng của các hoạt chất, nếu tồn tại một hoạt chất có đường dùng khác hoặc nhóm đường dùng khác thì cần cảnh báo vi phạm (DM_THUOC_BV.DUONGDUNG != DM_HOATCHAT.DUONGDUNG). - B1_34: Thuốc sử dụng vượt tuyến đi kèm với dịch vụ kỹ thuật Với thuốc tân dược, các thuốc cơ sở gửi lên cần kiểm tra với Thông tư 40 (DM_HOATCHAT) để biết hạng bệnh viện được sử dụng. Nếu sai hạng, sẽ kiểm tra quyết định phê duyệt kèm theo (DM_HOATCHAT.HANG != COSO_KCB.HANGBV). Nếu không có quyết định phê duyệt cơ sở được sử dụng thuốc này thì tiến hành từ chối phê duyệt (DM_QUYETDINHPHEDUYET). - B1_35: Thuốc có số đăng ký chưa được công bố Với thuốc tân dược, cần kiểm tra thuốc cơ sở gửi lên có tồn tại trong cục quản lí dược hay không (DM_THUOC). Nếu không tồn tại thì tiến hành từ chối phê duyệt. - B1_37: Thuốc tân dược sai tên so với thầu Với thuốc tân dược, cần kiểm tra tên thuốc cơ sở gửi lên so với tên thuốc trong dữ liệu đấu thầu của tỉnh. Nếu khác nhau cần cảnh báo (DM_THUOC_BV.TEN != DM_THUOC_THAU.TEN). - B1_38: Thuốc tân dược sai đường dùng so với thầu Với thuốc tân dược, cần kiểm tra đường dùng của thuốc cơ sở gửi lên so với đường dùng của thuốc trong dữ liệu đấu thầu của tỉnh. Nếu đường dùng khác nhau cần cảnh báo (DM_THUOC_BV.DUONGDUNG != DM_THUOCTHAU.DUONGDUNG).  Danh mục dịch vụ kỹ thuật bệnh viện: - B5_62: Dịch vụ kỹ thuật không nằm trong danh mục tương đương Kiểm tra dịch vụ kĩ thuật bệnh viện cơ sở gửi lên có nằm trong danh mục tương đương mà Bộ y tế ban hành hay không (DM_DICHVU_TD). Nếu dịch vụ kỹ thuật bệnh viện cơ sở gửi lên không nằm trong danh mục tương đương thì tiến hành từ chối phê duyệt. 69 - B5_63: Dịch vụ có tên sai quy định (Thông tư 43, Thông tư 50) Với dịch vụ kỹ thuật bệnh viện cơ sở gửi lên đã tồn tại trong Thông tư 43, Thông tư 50, tiến hành kiểm tra tên của dịch vụ bệnh viện cơ sở gửi lên với tên dịch vụ kỹ thuật trong Thông tư 43, Thông tư 50. Nếu khác nhau thì cảnh báo. (DM_DICHVU_BV.TEN != DM_TEN_DICHVU.TEN) - B5_66: Dịch vụ kỹ thuật không phù hợp với tuyến, hạng của bệnh viện Thông tư 43, Thông tư 50 có quy định về hạng bệnh viện được sử dụng dịch vụ kỹ thuật, vì vậy cần kiểm tra dịch vụ kỹ thuật cơ sở gửi lên có phù hợp với hạng viện viện của cơ sở hay không. Nếu hạng bệnh viện không phù hợp theo Thông tư 43, Thông tư 50 thì từ chối phê duyệt (COSO_KCB.HANGBV != DM_TEN_DICHVU.HANG). - B6_68: Dịch vụ kỹ thuật không nằm trong danh mục phê duyệt của tỉnh Kiểm tra danh mục dịch vụ kỹ thuật phê duyệt của tỉnh, nếu dịch vụ kỹ thuật cơ sở gửi lên không tồn tại trong danh mục dịch vụ kỹ thuật phê duyệt của tỉnh thì tiến hành từ chối phê duyệt (DM_GIA_DICHVU_TINH). - B6_69: Giá sử dụng cao hơn giá phê duyệt Với những dịch vụ kỹ thuật đã nằm trong danh mục dịch vụ kỹ thuật phê duyệt của tỉnh, tiến hành so sánh giá dịch vụ kỹ thuật cơ sở gửi lên với danh mục dịch vụ kỹ thuật phê duyệt của tỉnh, nếu giá lớn hơn thì tiến hành từ chối phê duyệt (DM_DICHVU_BV.GIA > DM_GIA_DICHVU_TINH.GIA). - B6_70: Giá sử dụng cao hơn giá trong thông tư Bộ Y tế Với những dịch vụ kỹ thuật đã nằm trong danh mục dịch vụ kỹ thuật tương đương do Bộ y tế ban hành, tiến hành kiểm tra giá của dịch vụ kỹ thuật cơ sở gửi lên với giá của dịch vụ kĩ thuật trong danh mục tương đương mà Bộ y tế ban hành. Nếu lớn hơn thì từ chối phê duyệt (DM_DICHVU_BV.GIA > DM_DICHVU_TD.GIA). - B6_71: Dịch vụ kỹ thuật không nằm trong danh mục được phê duyệt của cơ sở thực hiện 70 Theo Công văn 510, dịch vụ kỹ thuật của cơ sở gửi lên sẽ nằm trong danh mục được phê duyệt của cơ sở thực hiện. Vì vậy cần kiểm tra dịch vụ kỹ thuật của cơ sở gửi lên có nằm trong danh mục dịch vụ kỹ thuật của cơ sở thực hiện. Nếu không tồn tại thì thực hiện từ chối phê duyệt.  Danh mục vật tư bệnh viện: - B7_72: Vật tư y tế không nằm trong danh mục Bộ y tế Với những vật tư cơ sở gửi lên, cần kiểm tra với danh mục vật tư do Bộ y tế ban hành, nếu vật tư cơ sở gửi lên mà không tồn tại trong danh mục vật tư do Bộ y tế ban hành thì từ chối phê duyệt (DM_VATTU). - B7_73: Vật tư y tế không thanh toán riêng Với những vật tư đã tồn tại trong danh mục vật tư do Bộ y tế ban hành thì tiến hành kiểm tra vật tư đó có được thanh toán riêng hay không. Nếu vật tư đó không được thanh toán riêng thì cảnh báo (DM_VATTU.KHONGTHANHTOANRIENG == 1). - B7_74: Sai tên vật tư y tế Với những vật tư đã tồn tại trong danh mục vật tư do Bộ y tế ban hành thì tiến hành kiểm tra tên của vật tư đó so với vật tư trong danh mục Bộ y tế. Nếu tên khác nhau thì tiến hành cảnh báo (DM_VATTU_BV.TEN != DM_VATTU.TEN). - B7_75: Vật tư y tế không nằm trong danh mục thầu tỉnh Với những vật tư y tế cơ sở gửi lên, cần kiểm tra với danh mục đấu thầu của tỉnh (DM_VATTU_THAU). Nếu trong danh mục đấu thầu của tỉnh không tồn tại vật tư mà cơ sở gửi lên thì tiến hành từ chối phê duyệt - B7_76: Vật tư y tế giá cao hơn danh mục thầu tỉnh Với những vật tư y tế cơ sở gửi lên đã tồn tại trong danh mục đấu thầu của tỉnh (DM_VATTU_THAU), kiểm tra giá vật tư y tế mà cơ sở đưa lên, nếu giá vật tư y tế mà cơ sở đưa lên lớn hơn giá của vật tư trong danh mục đấu thầu tỉnh thì tiến hành từ chối phê duyệt (DM_VATTU_BV.GIA > DM_VATTU_THAU.GIA). 71 3.3. Kết luận Chương 3 đã giới thiệu về hệ thống giám định bảo hiểm xã hội việt nam, từ đó giới thiệu về bài toán giám định tự động, các tính chất, yêu cầu của giám định tự động. Áp dụng các bước xây dựng một ứng dụng kiến trúc hướng dịch vụ vào bài toán giám định tự động. Phân tích và xây dựng các dịch vụ được đưa cùng hai bộ quy tắc hồ sơ và quy tắc danh mục. 72 CHƯƠNG 4: CÀI ĐẶT, TRIỂN KHAI VÀ THỰC NGHIỆM GIÁM ĐỊNH TỰ ĐỘNG 4.1. Cài đặt Như đã đề cập trong chương trước, ta sẽ sử dụng: Ngôn ngữ lập trình: C# môi trường .Net 4.0 Phiên bản ODTwithODAC 32bit, 64bit phiên bản 11 Công cụ lập trình: Visual Studio 15 4.1.1. Giám định hồ sơ 4.1.1.1. GetDataKB Nhiệm vụ của dịch vụ GetDataKB sẽ cần phải chạy độc lập, liên tục khi có các hồ sơ mới được gửi lên và lưu vào bảng Xml19324, Xml29324, Xml39324, Xml49324, Xml59324. Sau khi lấy được danh sách các hồ sơ mới được gửi lên dưới dạng danh sách Object của Xml19324 dịch vụ sẽ cần phải gửi lên hệ thống Message Broker với queue có tên là WaitingProcessKB. Trong trường hợp xảy ra sự cố thì dịch vụ cần phải xử lý sự cố cũng như ghi log lại để quản trị viên có thể xử lý kịp thời. Dịch vụ cần quét liên tục nên cơ chế Timer sẽ phù hợp với yêu cầu này. Với tham số thời gian vòng lặp sẽ được đọc ở file cấu hình để tùy chỉnh số giây mà Timer sẽ quét lượt tiếp theo. Vì cần đánh dấu các hồ sơ đã lấy để xử lý, mà thời gian đánh dấu sẽ có độ trễ nên dịch vụ ta sẽ thực hiện theo cơ đế đơn luồng. Dịch vụ GetXml19324(): Dịch vụ lấy những hồ sơ KCB theo trạng thái mới được gửi lên: Sử dụng Nhibernate.dll để kết nối đến cơ sở dữ liệu. Rồi thực hiện select trong bảng Xml19324 với status = 0, mỗi lần ta sẽ lấy một lượng theo cấu hình trong file cấu hình, sau khi lấy thì tiến hành cập nhật status của bản ghi = 1 để đánh dấu bản ghi là trạng thái đã được lấy để xử lý. 73 SendMessage(Message): Dịch vụ sẽ gửi thông điệp cho thành phần khác với thông điệp dạng đối tượng Message lên hệ thống MessageBroker với queue tên WaitingProcessKB. Tạo kết nối đến Hệ thống MessageBroker sử dụng RabbitMQ.Client.dll. Sau khi tạo kết nối thì tiến hành gửi nội dung thông điệp lên queue. Gửi nội dung lên queue, cần mã hóa nội dung gửi thành mảng byte. Hàm chuyển từ đối tượng sang mảng byte được hỗ trợ bởi Newtonsoft.Json.dll Xử lý(exeption): Xử lý khi xảy ra sự cố, trong trường hợp có lỗi kết nối đến cơ sở dữ liệu thì sẽ tiến hành ghi log để quản trị viên có thể xử lý, còn trường hợp có sự cố khi gửi thông điệp lên queue thì sẽ tiến hành cập nhật lại bản ghi thành trạng thái mới (status = 0). Ghilog(exeption): Dịch vụ ghi log khi xảy ra sự cố dùng log4net.dll 4.1.1.2. ProcessDataKB Nhiệm vụ của dịch vụ ProcessDataKB là thực hiện tìm kiếm trên queue WaitingProcessKB, nếu có thông điệp mới được gửi đến từ dịch vụ GetDataKB thì tiến hành giải mã thông điệp, thực hiện giám định và gửi thông điệp tới dịch vụ khác thông qua queue FinishProcessKB của RabbitMQ. Trong trường hợp xảy ra sự cố thì tiến hành xử lý và ghi log để quản trị viên biết và xử lý kịp thời. Dịch vụ cần quét liên tục nên cơ chế Timer sẽ phù hợp với yêu cầu này. Với tham số thời gian vòng lặp sẽ được đọc ở file cấu hình để tùy chỉnh số giây mà Timer sẽ quét lượt tiếp theo. Với việc nghiệp vụ có thể thực hiện một cách song song, vì vậy dịch vụ sẽ thực hiện cơ chế đa luồng để tăng hiệu năng. Số luồng sẽ được cấu hình ở file cấu hình. GetMesssage(): Dịch vụ nhận thông điệp từ dịch vụ khác, tiến hành kết nối đến RabbitMQ để lấy thông điệp. Sau khi kết nối đến queue WaitingProcessKB của hệ thống MessageBroker sẽ tiến hành lấy thông điệp. Nhưng nội dung của thông điệp là chuỗi json vì vậy cần giải mã thông điệp về đối tượng để sử dụng. 74 Giải mã(Message): Dịch vụ giải mã thông điệp, khi đã lấy được phần nội dung trong thông điệp, nhưng phần nội dung của thông điệp đang ở dạng mảng bytes, vì vậy cần giải mã về dạng đối tượng để xử lý giám định. Với hàm chuyển từ mảng bytes sang chuỗi string của System.dll của .net Hàm chuyển từ chuỗi json sang đối tượng message sử dụng thư viện Newtonsoft.Json.dll Hàm chuyển từ chuỗi base64 sang đối tượng sử dụng thư viện Newtonsoft.Json.dll và System.dll ConnectDB(): Kết nối cơ sở dữ liệu sử dụng Nhibernate.dll GetDmFunction(xml.NgayThanhToan): Lấy những quy tắc đang bật theo ngày thanh toán của hồ sơ. Lấy những bản ghi thỏa mãn điều kiện, start_date nhỏ hơn hoặc bằng ngày thành toán, end_date có thể null hoặc lớn hơn ngày thanh toán và giá trị value bằng một là những quy tắc đang được bật. Run(Xml19324): Thực hiện chạy các quy tắc giám định hồ sơ, với danh sách các quy tắc hồ sơ lấy được từ dịch vụ GetDmFunction(xml.NgayThanhToan), tiến hành chạy lần lượt qua các quy tắc để phát hiện sai phạm. Các quy tắc sẽ được gọi bằng phương thức Invoke theo tên hàm trùng với Key trong DmFunction. Nội dung các quy tắc sẽ tuân theo chi tiết trong phần các quy tắc giám định hồ sơ. SendMessage(Message): Dịch vụ sẽ gửi thông điệp cho thành phần khác với thông điệp dạng đối tượng Message lên hệ thống MessageBroker với queue tên FinishProcessKB. Tạo kết nối đến Hệ thống MessageBroker sử dụng RabbitMQ.Client.dll. Thực hiện chuyển đổi đối tượng thông điệp sang mảng byte để thực hiện gửi lên queue. Với hàm chuyển từ đối tượng sang mảng byte được hỗ trợ bởi Newtonsoft.Json.dll Xử lý(exeption): Xử lý khi xảy ra sự cố, trong trường hợp có lỗi kết nối đến cơ sở dữ liệu thì sẽ tiến hành ghi log để quản trị viên có thể xử lý, còn trường hợp có sự cố khi gửi thông điệp lên queue thì sẽ tiến hành cập nhật lại bản ghi thành trạng thái mới. 75 Ghilog(exeption): Dịch vụ ghi log khi xảy ra sự cố dùng log4net.dll 4.1.1.3. SendDataKB Nhiệm vụ của dịch vụ SendDataKB là thực hiện tìm kiếm trên queue FinishProcessKB, nếu có thông điệp mới được gửi đến từ dịch vụ ProcessDataKB thì tiến hành giải mã thông điệp, cập nhật kết quả vào cơ sở dữ liệu, thực hiện tính toán các trường nghiệp vụ để tiến hành gửi dữ liệu lên Solr. Trong trường hợp xảy ra sự cố thì tiến hành xử lý và ghi log để quản trị viên biết và xử lý kịp thời. Dịch vụ cần quét liên tục nên cơ chế Timer sẽ phù hợp với yêu cầu này. Với tham số thời gian vòng lặp sẽ được đọc ở file cấu hình để tùy chỉnh số giây mà Timer sẽ quét lượt tiếp theo. Với việc nghiệp vụ có thể thực hiện một cách song song, vì vậy dịch vụ sẽ thực hiện cơ chế đa luồng để tăng hiệu năng. Số luồng sẽ được cấu hình ở file cấu hình. GetMesssage(): Dịch vụ nhận thông điệp từ dịch vụ khác, tiến hành kết nối đến RabbitMQ để lấy thông điệp. Sau khi kết nối đến queue FinishProcessKB của hệ thống MessageBroker sẽ tiến hành lấy thông điệp. Giải mã(Message): Dịch vụ giải mã thông điệp, khi đã lấy được phần nội dung trong thông điệp, nhưng phần nội dung của thông điệp đang ở dạng mảng bytes, vì vậy cần giải mã về dạng đối tượng để xử lý giám định: Với hàm chuyển từ mảng bytes sang chuỗi string của System.dll của .net Hàm chuyển từ chuỗi json sang đối tượng message sử dụng thư viện Newtonsoft.Json.dll Hàm chuyển từ chuỗi base64 sang đối tượng sử dụng thư viện Newtonsoft.Json.dll và System.dll ConnectDB(): Kết nối cơ sở dữ liệu sử dụng Nhibernate.dll UpdateSGD(Xml19324): Cập nhật kết quả sau giám định, thực hiện cập nhật các trường loại bn, các trường tiền cơ sở đề nghị sau, tiền quyết toán sau khi tổng hợp từ chi tiết và tiền xuất toán sau khi thực hiện giám định. Cùng với các kết quả giám định ghi vào các trường resultchung, resultthuoc, resultdichvu tương ứng với các quy tắc. 76 Tinhtoan(ref Xml19324): Tính toán theo yêu cầu báo cáo. Từ các trường tiền đề nghị tính toán trường tổng chi là tổng số tiền được đề nghị lên. Tổng quyết toán là tổng các trường tiền quyết toán. Tổng tiền bảo hiểm thanh toán quyết toán là tổng các trường tiền đề nghị có nhân mức hưởng nhưng tiền vận chuyển sẽ không nhân mức hưởng. Convert(Xml19324): Chuyển đổi về schema của Solr, gán giá trị tương tứng ở đối tượng Xml19324 với các trường trong đối tượng Xml19324_report. SendSolr(Xml19324_report): Đẩy dữ liệu lên Solr. Thư viện sử dụng SolrNet.dll. Việc đẩy lên Solr đối tượng Xml19324_report sẽ cần mapping trong đối tượng tương ứng với các trường nghiệp vụ trên Solr schema. Xử lý(exeption): Xử lý khi xảy ra sự cố, trong trường hợp có lỗi kết nối đến cơ sở dữ liệu thì sẽ tiến hành ghi log để quản trị viên có thể xử lý, còn trường hợp có sự cố khi gửi thông điệp lên queue hoặc Solr thì sẽ tiến hành cập nhật lại bản ghi thành trạng thái mới (status = 0). Ghilog(exeption): Dịch vụ ghi log khi xảy ra sự cố dùng log4net.dll 4.1.2. Giám định danh mục 4.1.2.1. GetData Nhiệm vụ của dịch vụ GetData sẽ cần phải chạy độc lập, liên tục khi có các danh mục mới được gửi lên và lưu vào các bảng danh mục tương ứng: DmThuocThau, DmVattuThau, DmGiadvTinh, DmThuocBv, DmVattuBv, DmDichvuBv. Sau khi lấy được danh sách các danh mục mới được gửi lên dưới dạng danh sách Object của các danh mục tương ứng dịch vụ sẽ cần phải gửi lên hệ thống Message Broker với queue có tên là WaitingProcess. Trong trường hợp xảy ra sự cố thì dịch vụ cần phải xử lý sự cố cũng như ghi log lại để quản trị viên có thể xử lý kịp thời. Dịch vụ cần quét liên tục nên cơ chế Timer sẽ phù hợp với yêu cầu này. Với tham số thời gian vòng lặp sẽ được đọc ở file cấu hình để tùy chỉnh số giây mà Timer sẽ quét lượt tiếp theo. 77 Vì cần đánh dấu các hồ sơ đã lấy để xử lý, mà thời gian đánh dấu sẽ có độ trễ nên dịch vụ ta sẽ thực hiện theo cơ đế đơn luồng, nhưng với mỗi loại danh mục sẽ tạo một luồng riêng. GetListDm(): Lấy danh sách danh mục theo trạng thái mới được gửi lên, số lượng bản ghi lấy sẽ được cấu hình trong file cấu hình. DmThuocBv: Với danh mục thuốc bệnh viện có status = 0, chưa có hiệu lực (hiệu lực = 0) và chưa bị xóa isdel = 0. DmVattuBv: Với danh mục vật tư bệnh viện có status = 0, chưa có hiệu lực (hiệu lực = 0) và chưa bị xóa isdel = 0. DmDichvuBv: Với danh mục dịch vụ bệnh viện có status = 0, chưa có hiệu lực (hiệu lực = 0) và chưa bị xóa và thuộc trong một bảng giá (bảng giá dvkt id không null). DmThuocThau: Với danh mục thuốc thầu có status = 0, chưa có hiệu lực (hiệu lực = 0) và chưa bị xóa isdel = 0. DmVattuThau: Với danh mục vật tư thầu có status = 0, chưa có hiệu lực (hiệu lực = 0) và chưa bị xóa isdel = 0. DmGiaDichvuTinh: Với danh mục giá dịch vụ tỉnh có status =0, chưa có hiệu lực (hiệu lực = 0) và chưa bị xóa isdel = 0. Sau khi lấy được danh sách các bản ghi thì tiến hành cập nhật status = 1 để đánh dấu trạng thái đã được lấy để xử lý. SendMessage(Message): Dịch vụ sẽ gửi thông điệp cho thành phần khác với thông điệp dạng đối tượng Message lên hệ thống MessageBroker với queue tên WaitingProcess. Tạo kết nối đến Hệ thống MessageBroker sử dụng RabbitMQ.Client.dll. Sau khi kết nối sẽ tiến hành mã hóa đối tượng sang bảng byte rồi thực hiện gửi thông điệp. Hàm chuyển từ đối tượng sang mảng byte được hỗ trợ bởi Newtonsoft.Json.dll Xử lý(exeption): Xử lý khi xảy ra sự cố, trong trường hợp có lỗi kết nối đến cơ sở dữ liệu thì sẽ tiến hành ghi log để quản trị viên có thể xử lý, còn trường hợp có sự 78 cố khi gửi thông điệp lên queue thì sẽ tiến hành cập nhật lại bản ghi thành trạng thái mới. Ghilog(exeption): Dịch vụ ghi log khi xảy ra sự cố dùng log4net.dll 4.1.2.2. ProcessData Nhiệm vụ của dịch vụ ProcessData là thực hiện tìm kiếm trên queue WaitingProcess, nếu có thông điệp mới được gửi đến từ dịch vụ GetData thì tiến hành giải mã thông điệp, thực hiện giám định và gửi thông điệp tới dịch vụ khác thông qua queue FinishProcess của RabbitMQ. Trong trường hợp xảy ra sự cố thì tiến hành xử lý và ghi log để quản trị viên biết và xử lý kịp thời. Dịch vụ cần quét liên tục nên cơ chế Timer sẽ phù hợp với yêu cầu này. Với tham số thời gian vòng lặp sẽ được đọc ở file cấu hình để tùy chỉnh số giây mà Timer sẽ quét lượt tiếp theo. Với việc nghiệp vụ có thể thực hiện một cách song song, vì vậy dịch vụ sẽ thực hiện cơ chế đa luồng để tăng hiệu năng. Số luồng sẽ được cấu hình ở file cấu hình. GetMesssage(): Dịch vụ nhận thông điệp từ dịch vụ khác, tiến hành kết nối đến RabbitMQ để lấy thông điệp. Sau khi kết nối đến queue WaitingProcess của hệ thống MessageBroker sẽ tiến hành lấy thông điệp. Vì thông điệp đang ở dạng chuỗi json vì vậy cần giải mã thông điệp sang dạng đối tượng. Giải mã(Message): Dịch vụ giải mã thông điệp, khi đã lấy được phần nội dung trong thông điệp, nhưng phần nội dung của thông điệp đang ở dạng mảng bytes, vì vậy cần giải mã về dạng đối tượng để xử lý giám định. Với hàm chuyển từ mảng bytes sang chuỗi string của System.dll của .net. Hàm chuyển từ chuỗi json sang đối tượng message sử dụng thư viện Newtonsoft.Json.dll. Hàm chuyển từ chuỗi base64 sang đối tượng sử dụng thư viện Newtonsoft.Json.dll và System.dll ConnectDB(): Kết nối cơ sở dữ liệu sử dụng Nhibernate.dll GetDmFunctionDm(objectDm.Tungay): Lấy những quy tắc danh mục đang bật theo từ ngày của danh mục. Từ ngày của danh mục lớn hơn hoặc bằng ngày bắt đầu của 79 quy tắc. Ngày kết thúc của quy tắc có thể không có hoặc từ ngày của danh mục nhỏ hơn hoặc bằng ngày kết thúc của quy tắc, và giá trị của quy tắc đang bật value = 1. Mapping(objectDm): Thực hiện ánh xạ danh mục với từng loại danh mục. Với từng loại danh mục cần ánh xạ với các danh mục dùng chung như DmThuoc, DmDichvuTd, Dmhoatchat, DmYhct Run(ObjectDm): Thực hiện chạy các quy tắc giám định danh mục lấy được. Các quy tắc sẽ được gọi bằng phương thức Invoke theo tên hàm trùng với Key trong DmFunctionDm. Nội dung các quy tắc sẽ tuân theo chi tiết trong phần các quy tắc giám định danh mục. SendMessage(Message): Dịch vụ sẽ gửi thông điệp cho thành phần khác với thông điệp dạng đối tượng Message lên hệ thống MessageBroker với queue tên FinishProcess. Tạo kết nối đến Hệ thống MessageBroker sử dụng RabbitMQ.Client.dll. Sau khi kết nối đến hệ thống queue, tiến hành chuyển đối tượng sang chuỗi byte để thực hiện gửi thông điệp lên queue. Hàm chuyển từ đối tượng sang mảng byte được hỗ trợ bởi Newtonsoft.Json.dll Xửlý(exeption): Xử lý khi xảy ra sự cố, trong trường hợp có lỗi kết nối đến cơ sở dữ liệu thì sẽ tiến hành ghi log để quản trị viên có thể xử lý, còn trường hợp có sự cố khi gửi thông điệp lên queue thì sẽ tiến hành cập nhật lại bản ghi thành trạng thái mới. Ghilog(exeption): Dịch vụ ghi log khi xảy ra sự cố dùng log4net.dll 4.1.2.3. SendData Nhiệm vụ của dịch vụ SendData là thực hiện tìm kiếm trên queue FinishProcess, nếu có thông điệp mới được gửi đến từ dịch vụ ProcessData thì tiến hành giải mã thông điệp, cập nhật kết quả vào cơ sở dữ liệu. Trong trường hợp xảy ra sự cố thì tiến hành xử lý và ghi log để quản trị viên biết và xử lý kịp thời. Dịch vụ cần quét liên tục nên cơ chế Timer sẽ phù hợp với yêu cầu này. Với tham số thời gian vòng lặp sẽ được đọc ở file cấu hình để tùy chỉnh số giây mà Timer sẽ quét lượt tiếp theo. 80 Với việc nghiệp vụ có thể thực hiện một cách song song, vì vậy dịch vụ sẽ thực hiện cơ chế đa luồng để tăng hiệu năng. Số luồng sẽ được cấu hình ở file cấu hình. GetMesssage(): Dịch vụ nhận thông điệp từ dịch vụ khác, tiến hành kết nối đến RabbitMQ để lấy thông điệp. Sau khi kết nối đến queue FinishProcess của hệ thống MessageBroker sẽ tiến hành lấy thông điệp. Vì thông điệp lấy được đang ở dạng json nên cần giải mã từ chuỗi json về dạng đối tượng để sử dụng. Giải mã(Message): Dịch vụ giải mã thông điệp, khi đã lấy được phần nội dung trong thông điệp, nhưng phần nội dung của thông điệp đang ở dạng mảng bytes, vì vậy cần giải mã về dạng đối tượng để xử lý giám định. Với hàm chuyển từ mảng bytes sang chuỗi string của System.dll của .net. Hàm chuyển từ chuỗi json sang đối tượng message sử dụng thư viện Newtonsoft.Json.dll. Hàm chuyển từ chuỗi base64 sang đối tượng sử dụng thư viện Newtonsoft.Json.dll và System.dll. ConnectDB(): Kết nối cơ sở dữ liệu sử dụng Nhibernate.dll UpdateSGD(ObjectDm): Tùy từng loại danh mục mà tiến hành cập nhật kết quả giám định tương ứng vào cơ sở dữ liệu Xử lý(exeption): Xử lý khi xảy ra sự cố, trong trường hợp có lỗi kết nối đến cơ sở dữ liệu thì sẽ tiến hành ghi log để quản trị viên có thể xử lý, còn trường hợp có sự cố khi gửi thông điệp lên queue thì sẽ tiến hành cập nhật lại bản ghi thành trạng thái mới. Ghilog(exeption): Dịch vụ ghi log khi xảy ra sự cố dùng log4net.dll 4.2. Triển khai Các dịch vụ sẽ được triển khai trên Win server được cài đặt môi trường .net 4.0 và phiên bản ODTwithODAC 32bit, 64bit phiên bản 11. Cùng các hệ thống RabbitMQ 3.6.2, Solr 6.4 Một vài chú ý trong quá trình triển khai: - Các service GetData, GetDataKB vì chạy đơn luồng nên khi có lượng hồ sơ hay danh mục được gửi lên nhiều. Với 1 app không thể đáp ứng được tốc độ 81 sẽ thì sẽ tiến hành chia nhỏ các app Get ra thành một bộ Get riêng, có thể chia theo nghiệp vụ. Ví dụ với hồ sơ, có thể làm bộ Get theo các tháng quyết toán khác nhau. Với những tháng có thể lấy theo hồ sơ theo giới tính hoặc mã loại khám chữa bệnh - Các service ProcessDataKB, ProcessData là các service xử lý nên tùy vào lượng thông điệp được gửi đến queue WaitingProcessDataKB, WaitingProcessData để lựa chọn số lượng app bật sao cho phù hợp nhất. Tương tự với các app SendDataKB và SendData. Một vài hình ảnh về bộ service giám định tự động: Hình 4.1. Màn hình hiển thị service GetDataKB khi quét trong Database. Hình 4.1 hiển thị màn hình của service GetDataKB khi đang quét trong cơ sở dữ liệu bảng Xml19324 để tìm các hồ sơ mới được gửi lên. 82 Hình 4.2. Màn hình hiển thị của Service ProcessDataKB khi đang giám định hồ sơ. Hình 4.2 là màn hình hiển thị Service ProcessDataKB khi đang thực hiện giám định hồ sơ. Sau khi giám định sẽ thực hiện gửi thông điệp lên queue FinishProcessKB. 4.3. Kết quả thực nghiệm Nội dung thực nghiệm: Sau khi triển khai môi trường, các dịch vụ giám định tự động đã đáp ứng các yêu cầu về nghiệp vụ giám định. Nhưng cần phải đảm bảo về mặt hiệu năng xử lý nữa nên phần thực nghiệm sẽ tập trung về tốc độ xử lý của dịch vụ giám định hồ sơ. Sau đây là kết quả thực nghiệm dịch vụ giám định hồ sơ. Sau đây là một vài kết quả thực nghiệm của chức năng giám định hồ sơ với mô hình triển khai bật một service GetDataKB, 5 service ProcessDataKB, 3 service SendDataKB: Số lượng hồ sơ Thời gian xử lý xong 134 20.12s 1120 77.85s 16739 932s 83 Hê thống đã đáp ứng với những yêu cầu phi chức năng đã nêu: - Khả năng dễ sử dụng: sử dụng nền tảng application nên chỉ cần bật tắt, thông báo hiển thị ra màn hình dos. Rất dễ sử dụng. - Khả năng dễ triển khai: chỉ cần cài đặt môi trường .net 4.0 và oda bản 11 64bit để triển khai. - Khả năng dễ bảo trì: vì phát triển trên nền tảng application, việc nâng cấp sửa chữa phiên bản rất dễ dàng. - Tính sẵn sàng của hệ thống: hệ thống làm việc 24/24h trừ những khoảng thời gian bảo trì, nâng cấp. Hệ thống triển khai trên môi trường win server, dưới dạng các application và cơ chế timer sẽ hoạt động 24/24h trừ các thời gian bảo trì, nâng cấp. - Hiệu năng: với trung bình một tháng có 15 triệu hồ sơ được gửi lên, khoảng 350 hồ sơ trung bình một phút, nhưng với những thời điểm cao điểm lượng hồ sơ tăng gấp nhiều lần. Hệ thống phải đảm bảo xử lý độ trễ các hồ sơ không quá 1h: Với yêu cầu về thời gian thực thi, như bảng thời gian thực thi giám định hồ sơ ở trên cho thấy một phút chức năng giám định hồ sơ có thể xử lý khoảng 1077hs. Điều này có thể đáp ứng được nhu cầu vào những ngày bình thường, lượng hồ sơ gửi lên khoảng 350hs một phút. Nhưng với những ngày cao điểm, lượng hồ sơ được gửi lên trong một thời điểm sẽ tăng lên rất nhiều. Hiện tại chức năng sẽ xử lý được lượng hồ sơ tăng gấp 3 lần bình thường. Nhưng như thế là chưa đủ. Vì vậy vào những thời điểm cao điểm, nếu lượng hồ sơ tăng vọt thì cần tăng lượng application xử lý để hạn chế độ trễ của việc giám định. Đây cũng là một ưu điểm khi phát triển chức năng bằng Application. Với chức năng giám định tự động hiện tại đã thể hiện một vài tính chất của hệ thống kiến trúc hướng dịch vụ như sau: - Sử dụng dịch vụ bất đồng bộ: các yêu cầu được đưa lên hệ thống message queue, bên gửi thông điệp không cần chờ bên nhận xử lý thông điệp xử lý xong. Hiện tại chức năng giám định tự động chưa thể hiện được các tính chất của hệ thống kiến trúc hướng dịch vụ sau: - Tính kết nối lỏng lẻo: các service hiện tại đang kết nối với nhau 84 - Sử dụng lại dịch vụ: các dịch vụ hiện tại đang chạy trên cùng dải wan, chưa cung cấp một dịch vụ công khai trên mạng. - Quản lý chính sách: vì chưa công khai một dịch vụ nên hiện tại các dịch vụ chưa cung cấp một chính sách để giao tiếp. - Khả năng cộng tác: hiện tại các dịch vụ chỉ có thể cộng tác trong cùng một ngôn ngữ C#. Trong tương lai gần bài toán công khai dịch vụ giám định tự động cho cơ sở khám chữa bệnh thực hiện giám định tự động công khai để có thể kiểm tra hồ sơ một cách dễ dàng trước khi đẩy dữ liệu sẽ tiết kiệm được thời gian ngân sách. Vì vậy trong tương lai định hướng của đề tài sẽ phát triển một đầu webservice cung cấp các đầu hàm hỗ trợ giám định tự động và sử dụng các đầu dịch vụ hiện tại để xử lý. Khi đó các tính chất về kiến trúc hướng dịch vụ như tính sử dụng lại dịch vụ, quản lý chinh sách, khả năng cộng tác sẽ được thỏa mãn. 4.4. Kết luận Chương 4 đã trình bày về chi tiết cài đặt các dịch vụ, ngôn ngữ, công cụ lập trình. Môi trường phát triển cùng các thư viện sử dụng. Chương này cũng đưa ra môi trường triển khai cho các dịch vụ. Kết quả thực nghiệm của các dịch vụ giám định hồ sơ, đánh giá giám định hồ sơ dựa vào các yêu cầu phi chức năng của chức năng cũng như đánh giá các tính chất mà chức năng đã đáp ứng được của hệ thống kiến trúc hướng dịch vụ và những tính chất chưa đáp ứng được, giải pháp để đáp ứng được các tính chất đó. 85 KẾT LUẬN Luận văn đã trình bày kiến trúc hướng dịch vụ SOA, phương pháp xây dựng một ứng dụng dựa trên kiến trúc hướng dịch vụ SOA cụ thể là phương pháp top-down. Từ đó áp dụng vào bài toán giám định tự động. Luận văn đã phân tích và xây dựng thành công: - Bộ service giám định hồ sơ: GetDataKB, ProcessDataKB, SendDataKB - Bộ service giám định danh mục: GetData, ProcessData, SendData - Bộ quy tắc hồ sơ: Quy tắc thẻ, quy tắc mức hưởng, quy tắc thuốc, quy tắc dịch vụ kỹ thuật, quy tắc vật tư y tế và quy tắc khác về máu, thanh toán ngày giường - Bộ quy tắc danh mục: Quy tắc thuốc thầu tỉnh, vật tư thầu tỉnh, thuốc bệnh viện, dịch vụ kỹ thuật bệnh viện, vật tư y tế bệnh viện. Hiện tại bộ service hồ sơ có thể xử lý được khoảng trên 40 hồ sơ/giây, đóng vai trò đắc lực hỗ trợ giám định viên phát hiện xử lý sai phạm trong quá trình thanh quyết toán bảo hiểm y tế. Giúp tiết kiệm ngân sách hàng năm của nhà nước. Nhưng hạn chế của giải pháp này là phải định nghĩa trước được bộ quy tắc cần phải chạy, vì vậy trong tương lai định hướng phát triển của em sẽ theo hướng mà sẽ mã hóa các bộ quy tắc trước được lưu trữ trong file hoặc database dưới dạng chuỗi base64 hoặc json. Trong service ProcessDataKB thực hiện giám định, sẽ cần phát triển tính năng đọc được chuỗi mã hóa quy tắc để tìm ra những quy tắc giám định. Với giải pháp này khi thêm quy tắc mới chỉ cần thêm một chuỗi mã hóa quy tắc mà không cần sửa lại service xử lý. Hiện tại với giám định tự động chưa có yêu cầu công khai như một dịch vụ nhưng trong tương lai giám định tự động có thể sẽ được công khai rộng rãi như một dịch vụ, để các cơ sở thực hiện giám định tự động trước khi gửi hồ sơ để tránh sai phạm, mất thời gian gửi dữ liệu. Chức năng sẽ công khai một đầu webservice để cơ sở thực hiện gửi hồ sơ dạng file xml, tận dụng các bộ service nghiệp vụ như hiện tại để xử lý và trả lại kết quả cho webservice thông qua hệ thống message queue. 86 TÀI LIỆU THAM KHẢO Tiếng Việt [1]. Công văn 510/BHXH-CSYT, thanh toán BHYT cho một số dịch vụ kỹ thuật y tế chuyển sang cơ sở KCB khác để thực hiện. [2]. Công văn 9324/BYT - BH, trích xuất đầu ra dữ liệu yêu cầu thanh toán BHYT. [3]. Đặng Đức Hạnh, Trương Ninh Thuận, Giáo trình Phân tích Thiết kế hướng đối tượng, Nhà xuất bản đại học quốc gia Hà Nội. [4]. Nguyễn Thị Dung, Đề tài nghiên cứu khoa học Kiến trúc hướng dịch vụ (Service- Oriented - Architecture). [5]. Quy trình giám định bảo hiểm y tế, kèm theo quyết định số 1456/QĐ-BHXH. [6]. Quyết định 3465/QĐ-BYT, về việc ban hành bộ mã danh mục dùng chung áp dụng trong khám bệnh, chữa bệnh và thanh toán bảo hiểm y tế [7]. Thông tư 27/2013/TT-BYT, ban hành danh mục vật tư y tế thuộc phạm vi thanh toán của quỹ bảo hiểm y tế. [8]. Thông tư 40/2014/TT-BYT, ban hành và hướng dẫn thực hiện danh mục thuốc tân dược thuộc phạm vi thanh toán của quỹ bảo hiểm y tế. [9]. Thông tư 05/2016/TT-BYT, quy định về kê đơn thuốc trong điều trị ngoại trú. Tiếng Anh [10]. IBM Red Book Team (2004), Parttern: Service- Oriented Architecture and Web Services. [11]. RabbitMQ tutorials, https://www.rabbitmq.com/getstarted.html. [12]. Rabbitmq beginner, https://www.cloudamqp.com/blog/2015-05-18-part1- rabbitmq-for-beginners-what-is-rabbitmq.html [13]. Solr architure, https://lucene.apache.org/solr/guide/6_6/a-quick- overview.html. [14]. Solr tutorial, [15]. Document of redis, https://redis.io/documentation. [16]. Redis tutorial, https://www.tutorialspoint.com/redis/ 87 PHỤ LỤC  Danh sách các trường dữ liệu trong các bảng danh mục tương ứng Các danh mục dùng chung được BYT ban hành: DM_THUOC: Danh mục thuốc được BYT ban hành, có số đăng ký công bố ID, TEN, MA, HIEULUC, STT, DUONGDUNG, DONVITINH, VANBANQUYETDINH_ID, HOATCHAT, QUYCACH, SODK, TIEUCHUAN, MIEUTA, BAOCHE, TUOITHO, STTTHONGTU, NGUONGOC, NUOCDANGKY, DIACHIDANGKY, CONGTYDANGKY, DIACHISANXUAT, NUOCSANXUAT, CONGTYSANXUAT,MADUONGDUNG, MADONVITINH, TUNGAY, DENNGAY, HAMLUONG, LOAI, NHOMTHUOC_ID, GHICHU. DM_THUOC_KK: Danh mục thuốc sau khi nhà sản xuất đăng ký số đăng ký với cơ quan quản lý dược, kèm theo giá bán. ID, STT, TEN, HOATCHAT, HAMLUONG, BAO_CHE, SO_DANG_KY, QUYCACH, DONVITINH, GIABAN, NHASX, DONVIKEKHAI, NGAYKEKHAI, GHICHU, LOAIKEKHAI, NGAYCONGB, HIEULUC, TRANG_THAI DM_HOATCHAT: Theo thông tư 40 của BYT ban hành về hoạt chất của các thuốc tân dược ID, TEN, TEN_EN, MA, STT, STTHOATCHAT, HIEULUC, LOAITHUOC, VANBANQUYETDINH_ID, PHANLOAIHOATCHAT_ID, MIEUTA, HANG1, HANG2, HANG3, HANG4,DUONGDUNG, TYLE, HOICHAN, MANHOM, MAATC, DANGLUUHANH, PHATHANH, CHUANHOA, UNGTHU, CODIEUKIEN, MADUONGDUNG, DUONGDUNG_ID, MAVANBANQUYETDINH, TUNGAY, DENNGAY, DANGDUNG, DONVITINH DM_THUOCYHCT: Theo thông tư 05 của BYT ban hành về hoạt chất của các thuốc y học cổ truyền ID, TEN, TEN_EN, MA, STT, STTHOATCHAT, HIEULUC,TENKHOAHOC, TENKHOAHOCCAY, LOAITHUOC, VANBANQUYETDINH_ID, NHOMTHUOCYHCT_ID, MIEUTA, DUONGDUNG , NGUONGOC, TYLE, 88 MADUONGDUNG,DUONGDUNG_ID, TUNGAY, DENNGAY, CODIEUKIEN, HOICHAN, DANGLUUHANH DM_DICHVU_TD: Danh mục dịch vụ kỹ thuật dùng chung được BYT ban hành ID, MA, MA4350, MAGIA, TEN, TENGIA, LOAIPTTT, GIA, GIASAU, GHICHU, HIEULUC, VANBANQUYETDINH_ID, TUNGAY, DENNGAY, QUYETDINH, DOT, BANGGIA_DVKT_ID, NHOMDICHVU_ID, MA_NHOMDICHVU DM_VATTU: Danh mục vật tư dùng chung được BYT ban hành ID, TEN, MA, NHOMVATTU_ID, HIEULUC, STT, VANBANQUYETDINH_ID, TEN_EN, DONVITINH, MIEUTA, MANHOMVATTU, TUNGAY, DENNGAY, TYLE, KOTHANHTOAN, DIKEM_DICHVU DM_MUCHUONGBHYT: Danh mục mức hưởng của từng loại đối tượng khám chữa bệnh ID, NHOMDTBHYT_ID, MAHIEU, TYLE, MA, TEN, MIEUTA, STT, HIEULUC, VANCHUYEN DM_GIAXANG: Danh mục giá xăng do BHXH Việt Nam quản lý ID, DONGIA, TUNGAY, DENNGAY, MIEUTA, HIEULUC DM_MAU: Danh mục máu do BHXH Việt Nam quản lý ID, MA, TEN, LOAIMAU_ID, THETICH, GIATOIDA, MIEUTA, HIEULUC, VANBANQUYETDINH_ID, TUNGAY, DENNGAY DM_COSOKCB: Danh mục cơ sở khám chữa bệnh do BHXH Việt Nam cấp phát và quản lý ID, TEN, MA, MABHYT, DONVIHANHCHINH_ID, DIACHI, HANGBENHVIEN, TUYENCMKT, HIEULUC, MIEUTA, STT, TINHTHANH_ID, QUANHUYEN_ID, MATINHTHANH, MAQUANHUYEN, DONVI_ID, MACOSOKCBCHA, COSOKCBCHA_ID, MADONVI, THANNHANTAO, THAIGHEP, LOAIHOPDONG, DKKCBBD, HINHTHUCTT, LOAIBENHVIEN, KHAMTREEM, NGAYNGUNGHD, MATAICHINH, PKDAKHOA, UNGTHU, VIEMGAN, 89 TEBAOMAUTD, KHAMT7, KHAMCN, KHAMNGAYLE, MASOTHUE, DIENTHOAI, EMAIL, FAX, COQUANCHUQUAN, NGAYKYHOPDONG, KIEUBV, CAPCSKCB_MIN, TTPHEDUYET, SOHOPDONG, LYDO, TRANGTHAI, TUCHU, HANGDICHVU_TD, HANGTHUOC_TD, HANGVATTU_TD, BYT, SO_GPHD, KCB, NGAYCAPMA, NGAYDIEUCHINH, LOAI_DONVICHUQUAN, CHUA_PD43, NGAYKYHOPDONGLANDAU, GHICHU_TINHTHAYDOI, SL_THE_BH_DKBD, SL_THE_BH_DA_CAP, LOAI_CK, TEN_VIETTAT DM_TYLETRAITUYEN: Danh mục tỷ lệ trái tuyến, với những trường hợp đi khám trái tuyến, tỷ lệ hưởng sẽ được thể hiện trong bảng ID, STT, HANGBV, TUYENBV, BHYT_THANHTOAN, BN_THANHTOAN, TUNGAY, DENNGAY, HINHTHUC_KCB, QUYENLOI_THEOTHE, HIEULUC, MIEUTA Các danh mục thầu của tỉnh được thể hiện ở các bảng: DM_THUOC_THAU: Danh mục thuốc trúng thầu của tỉnh ID, TEN, MA, DUONGDUNG, HAMLUONG, HOATCHAT, SODK, QUYCACH, TIEUCHUAN, COSOKCB_ID, TINHTHANH_ID, HIEULUC, STT, STTHOATCHAT, DONVITINH, NHASX, NUOCSX, MADUONGDUNG, TENNHATHAU, QUYETDINH, GOITHAU, NHOMTHUOC, HANSUDUNG, NAM, MANHATHAU, DANGBAOCHE, LYDOTUCHOI, MIEUTA, MACOSOKCB, MATINHTHANH, LOAI, TUNGAY, DENNGAY, HOSO_ID, STATUS, RESULT, SOLUONG, CONGBO, TRANGTHAI, GOITHAU_ID, THUOC_ID, STTPHEDUYET, KETQUA, DONGGOI, NHOMTHAU, DONGIA, THANHTIEN, MA_GY, TT4005_ID, LANNHAP, MOTALOI, LISTCELLERROR, MADD_GY, AX_CD, AX_TD, KETQUA_TD, GIA, HOATCHAT2, TT3112_ID, HANTHAUCU, NGAY_NHAN, NGAY_AP_DUNG DM_VATTU_THAU: Danh mục vật tư trúng thầu của tỉnh TEN, MA, MIEUTA, NAM, NGAYCONGBO, QUYETDINHTHAU, DOTTHAU, HINHTHUCTHAU, DONVITINH, SOLUONG, QUYCACH, NHASX, NUOCSX, HIEULUC, MACOSOKCB, STT, MATHAU, NHATHAU, COSOKCB_ID, 90 TINHTHANH_ID, MATINHTHANH, MANHOMVATTU, TUNGAY, DENNGAY, SODK, STTPHEDUYET, GOITHAU_ID, VATTU_ID, KETQUA, ID, TRANGTHAI, STATUS, RESULT, LOAI, MAHIEU, THANHTIEN, MA_GY, TEN_GY, LANNHAP, MOTALOI, LISTCELLERROR, AX_CD, AX_TD, KETQUA_TD, TENCHITIET, LYDOTUCHOI, GIATHAU, NGAY_NHAN, NGAY_AP_DUNG DM_GIADICHVU_TINH: Danh mục dịch vụ kỹ thuật trúng thầu của tỉnh ID, TUNGAY, GIA, TINHTHANH_ID, HIEULUC, MADV, DENNGAY, MIEUTA, HANGBV, MATINHTHANH, TEN, STTPHEDUYET, KETQUA, TRANGTHAI, STATUS, QUYETDINH, RESULT, GIADICHVU_ID, DICHVU_ID, LYDOTUCHOI, GOITHAU_ID, MOTALOI, LISTCELLERROR, LANNHAP, MA37, TEN37, MATD, MA5084, TEN5084 Các danh mục của bệnh viện sử dụng được thể hiện ở các bảng sau: DM_THUOC_BV: Danh mục thuốc mà bệnh viện sử dụng ID, TEN, TEN_EN, MA, DUONGDUNG, HAMLUONG, HOATCHAT, SODK, QUYCACH, TIEUCHUAN, COSOKCB_ID, TINHTHANH_ID, HIEULUC, STT, STTHOATCHAT, DONVITINH, NHASX, NUOCSX, MADUONGDUNG, TENNHATHAU, QUYETDINH, GOITHAU, NHOMTHUOC, HANSUDUNG, NAM, MANHATHAU, DANGBAOCHE, LYDOTUCHOI, MIEUTA, MACOSOKCB, MATINHTHANH, LOAITHAU, DAGIAMDINH, TUNGAY, DENNGAY, HOSO_ID, STATUS, RESULT, THUOC_ID, LOAI, KETQUA, TRANGTHAI, MA_BV, CONGBO, THUOCTHAU_ID, NGOAIDINHSUAT, NHOM_THAU, TT4005_ID, MANHOM_9324, KHONGTHANHTOAN, MA_GY, HUONGDAN, MADD_GY, ISDEL, AX_ID, AX_CD, AX_TD, KETQUA_TD, RESULT_TD, GIA, GIABH, SOLUONG, KEY, TT3112_ID, TEN_BV, THUOCGOC_ID, NGAY_NHAN, NGAY_AP_DUNG, NGAY_HET_HAN, GHICHU, SOLUONG_BV, RESULTSOLUONG DM_DICHVU_BV: Danh mục dịch vụ kỹ thuật mà bệnh viện sử dụng ID, TEN, MA, TEN_EN, COSOKCB_ID, HIEULUC, STT, MIEUTA, MACOSOKCB, STATUS, MATINH, NGAYBATDAU, DAGIAMDINH, RESULT, 91 SOQUYETDINH, NHOMDICHVU_ID, TRANGTHAI, MAKHOA, STTPHEDUYET, SOMAYTH, SOCANBOCM, THOIGIANTH, SOCACHOPHEP, MATT, KETQUA, TENDICHVU_ID, TUNGAY, DENNGAY, DICHVU_TD_ID, GIADICHVU_ID, GIADICHVU_TINH_ID, LOAIPTTT, TINHTHANH_ID, NGOAIDINHSUAT, MANHOM_9324, TYLE, KHONGTHANHTOAN, QUYTRINH, ISDEL, AX_ID, MAGIA_GY, MA_GY, TEN_GY, AX_CD, AX_TD, KETQUA_TD, RESULT_TD, LYDOTUCHOI, PHEDUYET_ID, GIA, GIABYT, BANGGIA_DVKT_ID, TIENKHAM_ID, TIENGIUONG_ID, KEY, PHEDUYET_GIA_ID, CHUA_PD43, TEN_BV, NGAY_NHAN, NGAY_AP_DUNG DM_VATTU_BV: Danh mục vật tư mà bệnh viện sử dụng ID, MA_BYT, TEN, MA_BV, MIEUTA, HIEULUC, QUYCACH, NUOCSX, NHASX, DONVITINH, DINHMUC, COSOKCB_ID, SOLUONG, STT, MATINHTHANH, MANHOM, LOAITHAU, DAGIAMDINH, HOSO_ID, MACOSOKCB, STATUS, TUNGAY, DENNGAY, RESULT, SODK, NHATHAU, NHOMVATTU_ID, DASUDUNG, SOCATHUCHIEN, DINHMUCPD, KETQUA, VATTU_ID, TRANGTHAI, TEN_BV, MAHIEU, QUYETDINH, CONGBO, VATTUTHAU_ID, NGOAIDINHSUAT, TYLE, MANHOM_9324, KHONGTHANHTOAN, MA_GY, TEN_GY, ISDEL, AX_ID, AX_CD, AX_TD, KETQUA_TD, RESULT_TD, LYDOTUCHOI, GIA, GIABHYT, KEY, NGAY_NHAN, NGAY_AP_DUNG Hồ sơ khám chữa bệnh sẽ được thể hiện ở các bảng: XML1_9324: Thông tin cá nhân, bệnh án, tổng chi phí mà bệnh nhân sử dụng trong quá trình khám chữa bệnh ID, MA_LK, STT, MA_BN, HO_TEN, GIOI_TINH, DIA_CHI, MA_THE, MA_DKBD, TEN_BENH, MA_BENH, MA_BENHKHAC, MA_LYDO_VVIEN , MA_NOI_CHUYEN, MA_TAI_NAN, SO_NGAY_DTRI, KET_QUA_DTRI, TINH_TRANG_RV, NGAY_TTOAN, MUC_HUONG , T_THUOC, T_VTYT, T_TONGCHI, T_BNTT, T_BHTT, T_NGUONKHAC, T_NGOAIDS, NAM_QT, THANG_QT, MA_LOAI_KCB, MA_KHOA, MA_CSKCB, MA_KHUVUC, MA_PTTT_QT, CAN_NANG, COSOKCB_ID, TINHTHANH_ID, TRANGTHAI, HOSO_ID, KYGIAMDINH_ID, MIEUTA, STATUS, NGAY_SINH, NGAY_RA, 92 NGAY_VAO, GT_THE_TU, GT_THE_DEN, RESULTCHUNG, RESULTTHUOC, RESULTDICHVU, NGUOIGIAMDINH_ID, NGAYTHANHTOAN, DOTGIAMDINH_ID, TRONGMAU, LOAI_BN, NGAYNHAN, RESULTCHUNG_TD, RESULTTHUOC_TD, RESULTDICHVU_TD, TRANGTHAI_TD, THEODOI, GIAMDINHTIEP, KETQUA, STTMAU, KETQUA_TD, MA_LYDO_VVIEN_TD, MUC_HUONG_TD, LYDOXT, XUATTOAN, K_XETNGHIEM, K_CDHATDCN, K_THUOC, K_MAU, K_PTTT, K_VTYT, H_DVKT, H_THUOC, H_VTYT, TIENKHAM, VANCHUYEN, TIENGIUONG, K_XETNGHIEM_QT, K_CDHATDCN_QT, K_THUOC_QTK_MAU_QT, K_PTTT_QT, K_VTYT_QT, H_DVKT_QT, H_THUOC_QT, H_VTYT_QT, TIENKHAM_QT, VANCHUYEN_QT, TIENGIUONG_QT, T_BNTT_QT, MUC_HUONG_BV, MA_LYDO_VVIEN_BV, K_XETNGHIEM_KTL, K_CDHATDCN_KTL, K_THUOC_KTL, K_MAU_KTL, K_PTTT_KTL, K_VTYT_KTL, H_DVKT_KTL, H_THUOC_KTL, H_VTYT_KTL, TIENKHAM_KTL, VANCHUYEN_KTL, TIENGIUONG_KTL, T_NGOAIDS_QT, CHOTDLQUY_ID, CHOTDLNAM_ID, ISNEW, XML1_GOP_ID, PHANCONG_ID, KY_QT, GHICHUHS, T_TONGCHI_TD, T_BHTT_TD, T_TONGCHI_XT, QTTHE, LOAI_THE, ISEDIT, NGAY_XU_LY, MODIFIER_DATE, T_TONGCHI_XTTD XML2_9324: Thông chi tiết các thuốc mà bệnh nhân sử dụng trong quá trình khám chữa bệnh ID, MA_LK, STT, MA_THUOC, MA_NHOM, TEN_THUOC, DON_VI_TINH, HAM_LUONG, DUONG_DUNG, LIEU_DUNG, SO_DANG_KY, SO_LUONG, TY_LE, MA_KHOA, MA_BAC_SI, MA_BENH, MA_PTTT, COSOKCB_ID, TINHTHANH_ID, TRANGTHAI, HOSO_ID, XML1_9324_ID, KYGIAMDINH_ID, MIEUTA, STATUS, NGAY_YL, THUOC_ID, NGUOIGIAMDINH_ID, LYDO_ID, SOLUONG_TD, LYDO_TEN, MA_THUOC_GOC, SO_LUONG_BV, TY_LE_TD, TEN_THUOC_GOC, XML2_GOC_ID, DON_GIA, DON_GIA_BV, DON_GIA_TD, THANH_TIEN, KY_QT, DON_VI_TINH_GOC, THEMMOI, NGAY_YL_NUMBER, SL192021, DG192021, MA192021, SL_VUOTTHAU, MUC_HUONG, SL_DOT_NGTRU, TYLE_DOT_NGTRU 93 XML3_9324: Thông tin chi tiết các dịch vụ kỹ thuật, vật tư mà bệnh nhân sử dụng trong quá trình khám chữa bệnh ID, MA_LK, STT, MA_DICH_VU, MA_VAT_TU, MA_NHOM, TEN_DICH_VU, DON_VI_TINH, SO_LUONG, TYLE_TT, MA_KHOA, MA_BAC_SI, MA_BENH, NGAY_YL, NGAY_KQ, MA_PTTT, COSOKCB_ID, TINHTHANH_ID, TRANGTHAI, HOSO_ID, XML1_9324_ID, KYGIAMDINH_ID, MIEUTA, STATUS, NGUOIGIAMDINH_ID, LYDO_ID, SOLUONG_TD, LYDO_TEN, MA_VATTU_GOC, MA_DICHVU_GOC, MA_GIA_DV, THEMMOI, SO_LUONG_BV, TY_LE_TD, TEN_DICHVU_GOC, XML3_GOC_ID, DON_GIA, DON_GIA_BV, DON_GIA_TD, THANH_TIEN, KY_QT, T_NGUONKHAC, DON_VI_TINH_GOC, TYLE_APTRAN, NGAY_YL_NUMBER, NGAY_KQ_NUMBER, SL192021, DG192021, MA192021, MUC_HUONG, GOI_VTYT, SL_DOT_NGTRU, TYLE_DOT_NGTRU XML4_9324: Thông tin chỉ tiêu chỉ số kết quả cận lâm sang ID, MA_LK, STT, MA_DICH_VU, MA_CHI_SO, TEN_CHI_SO, GIA_TRI, MA_MAY, MO_TA, KET_LUAN, NGAY_KQ, HOSO_ID, KYGIAMDINH_ID, COSOKCB_ID, TINHTHANH_ID, TRANGTHAI, MIEUTA, STATUS, XML1_9324_ID, NGUOIGIAMDINH_ID, NGAYKETQUA, KY_QT XML5_9324: Thông tin chỉ tiêu theo dõi diễn biến lâm sang ID, MA_LK, STT, DIEN_BIEN, HOI_CHAN, PHAU_THUAT, NGAY_YL, HOSO_ID, KYGIAMDINH_ID, COSOKCB_ID, TINHTHANH_ID, TRANGTHAI, MIEUTA, STATUS, XML1_9324_ID, NGUOIGIAMDINH_ID, NGAYYLENH, MABACSI, KY_QT Một số bảng khác: DM_FUNCTION: danh sách các quy tắc hồ sơ, quy định bật hay tắc các quy tắc KEY, VALUE, DESCRIPTION, TYPE, RESULT, START_DATE, END_DATE, LYDO_ID, HIEULUC DM_FUNCTION_DM: danh sách các quy tắc danh mục, quy định bật hay tắt các quy tắc 94 KEY, VALUE, DESCRIPTION, TYPE, RESULT, START_DATE, END_DATE, HIEULUC Với các bảng XML1_9324 sẽ có quan hệ 1-n với các bảng XML2_9324, XML3_9324, XML4_9324, XML5_9324 với khóa ngoại là XML1_9324_ID.

Các file đính kèm theo tài liệu này:

  • pdfluan_van_phan_tich_va_xay_dung_chuc_nang_giam_dinh_tu_dong_t.pdf
Luận văn liên quan