Xây dựng, phát triển và nâng cấp các hệ thống thông tin trong các doanh nghiệp trong mọi lĩnh vực đã trở thành một yêu cầu, một tất yếu cuả thời đại. Với mỗi doanh nghiệp tuỳ thuộc vào lĩnh vực hoạt động mà đòi hỏi cho mình một hệ thống thông tin phù hợp. Đối với các doanh nghiệp kinh doanh, một trong những hệ thống thông tin cơ bản là hệ thống thông tin quản lý khách hàng. Hệ thống quản lý khách hàng hoạt động tốt sẽ tạo điều kiện thuận lợi cho sự phát triển của doanh nghiệp.
Với những kiến thức có được sau 4 năm học và sự giúp đỡ của thầy cô, bạn bè, em đã hoàn thành luận văn tốt nghiệp đại học này. Trong luận văn, em đã quan tâm đến vấn đề quản lý khách hàng và tính cước sử dụng 178 tại Trung tâm Viễn thông Hà Nội. Chương trình đã đáp ứng được những yêu cầu cơ bản đối với một hệ thống thông tin. Ngoài ra, với giao diện thân thiện, đơn giản đã tạo cho người dùng sự dễ dàng và thuận tiện khi sử dụng.
97 trang |
Chia sẻ: aloso | Lượt xem: 1671 | Lượt tải: 1
Bạn đang xem trước 20 trang tài liệu Luận văn Xây dựng hệ thống thông tin quản lý khách hàng và tính cước dịch vụ 178 tại Trung tâm Viễn thông Hà Nội - Công ty Viễn thông Quân đội (Viettel), để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
thiết bị hiện đại của tin học, chịu sự quản lý của một hệ thống chương trình máy tính, nhằm cung cấp thông tin cho nhiều người sử dụng khác nhau và cho những mục đích khác nhau.
Ngôn ngữ lập trình Visual Foxpro
Visual Foxpro giúp triển khai các ứng dụng quản lý một cách dễ dàng, giảm bớt được khối lượng lập trình nặng nhọc.
Visual Foxpro hỗ trợ được lập trình hướng đối tượng, hỗ trợ khả năng thiết kế giao diện trực quan.
Với Visual Foxpro cho phép người dùng sử dụng các câu lệnh đơn giản, hiệu quả và giao tác với người dùng bằng một giao diện thân thiện.
Đây là ngôn ngữ lập trình rất thích hợp với chương trình quản lý khách hàng và tính cước mà em đang xây dựng, chính vì vậy em chọn ngôn ngữ này cho thiết kế chương trình quản lý khách hàng và tính cước của luận văn này.
Chương III
PHân tích, thiết kế hệ thống thông tin quản lý khách hàng và tính cước sử dụng 178 tại trung tâm viễn thông hà nội
I. Phân tích yêu cầu
1. Phân tích yêu cầu bài toán
Quản lý khách hàng là bài toán không mới, bởi với bất kỳ doanh nghiệp kinh doanh nào thì khách hàng là một yếu tố quan trọng quyết định sự thành công hay thất bại của doanh nghiệp đó. Tuy nhiên, khách hàng của mỗi doanh nghiệp đều có những điểm khác biệt không giống với doanh nghiệp khác.
Khách hàng của Trung tâm Viễn thông Hà Nội hiện nay chủ yếu là khách hàng sử dụng dịch vụ 178 để gọi điện thoại liên tỉnh và quốc tế. Các khách hàng này đều thuộc địa bàn Hà Nội. Do đó những thông tin về những khách hàng này là không nhiều. Khách hàng quản lý theo khu vực với những cộng tác viên được giao nhiệm vụ thu cước.
Về xác định giá cước dựa vào thời gian cuộc gọi và vùng theo quy định. Giá cước không cố định, biến đổi theo thời điểm và theo vùng.
Cách tính cước cho các cuộc gọi sử dụng dịch vụ 178 cụ thể là:
+ Gọi liên tỉnh: Vùng 1: 727 đồng/1 phút
Vùng 2: 1190 đồng/1 phút
Vùng 3: 1490 đồng/1 phút
+ Gọi quốc tế: 0.58 $/1 block trong đó 1 block = 6 giây.
Thời gian liên lạc tính đối với gọi liên tỉnh quy tròn theo đơn vị phút. Còn đối với gọi quốc tế phút đầu tính tròn, từ phút thứ hai tính theo block 6 giây.
Quy trình quản lý dữ liệu khách hàng:
- Hàng ngày, phòng tính cước nhận được từ Trung tâm dữ liệu thô về thông tin các cuộc gọi (gọi là file cước) của khách hàng sử dụng dịch vụ 178 (gọi chung là gọi VoIP). Dữ liệu này bao gồm dữ liệu về cuộc gọi đi trong nước và cuộc gọi đi quốc tế của các thuê bao Hà Nội.
- Dữ liệu này đã được trung tâm xử lý tuy nhiên vẫn còn chưa chính xác hoàn toàn.
- Nhân viên phòng tính cước sẽ lọc ra những khách hàng mới chưa có trong cơ sở dữ liệu. Trên cơ sở số điện thoại của khách hàng, nhân viên sẽ tra cứu địa chỉ của khách hàng đó. Tiếp theo với địa chỉ có được, tách ra phường, quận và ghép khách hàng cho cộng tác viên thu cước. Các thông tin này sẽ được cập nhật vào cơ sở dữ liệu.
- Với file cước này, nhân viên sẽ phải tính tiền của các cuộc gọi. Hết một chu kỳ cước là từ ngày 01 đến ngày cuối cùng của tháng, số liệu cước phát sinh trong tháng được xử lý chuẩn. Với số liệu chuẩn, nhân viên sẽ in hoá đơn, in bảng kê chi tiết các cuộc gọi.
- Hàng tháng, phòng tính cước nhận thông tin sửa đổi, cập nhật thêm thông tin của khách hàng từ cộng tác viên. Một khách hàng có thể có một hoặc nhiều thuê bao nên phải tách gộp thuê bao của khách hàng.
- Khi có thắc mắc của khách hàng hay có yêu cầu tra cứu dữ liệu của phòng kinh doanh, nhân viên phòng tính cước sẽ tra cứu những dữ liệu này thông qua các câu lệnh thi hành trực tiếp trên các bảng dữ liệu có được.
- Khi có thay đổi giá cước và phân chia lại cộng tác viên thì sẽ được cập nhật lại.
2. Mô tả bài toán quản lý khách hàng và tính cước
Các chức năng chính:
- Quản lý khách hàng theo cộng tác viên.
- Cập nhật, sửa đổi thông tin của khách hàng khi có yêu cầu.
- Xử lý các cuộc gọi và cập nhật thông tin chi tiết về các cuộc gọi. Các trường hợp cần xử lý cuộc gọi bao gồm:
Các cuộc gọi lạ, là một trong những cuộc gọi sau:
+ Số máy hoặc số bị gọi có độ dài số không đúng quy định.
+ Số máy hoặc số bị gọi xuất hiện các ký tự không phải là số.
+ Đầu số của số máy, số bị gọi không đúng quy định.
Các cuộc gọi trùng là các cuộc gọi:
+ Có cùng số máy chủ gọi và bị gọi.
+ Có cùng thời gian liên lạc.
+ Có cùng thời gian bắt đầu hoặc thời gian kết thúc.
+ Số máy chủ gọi không phải là thuê bao của ISDN.
+ Số máy chủ gọi không phải là mã của một chùm trung kế.
Các cuộc gọi chờm là các cuộc gọi:
+ Có cùng số máy chủ gọi.
+ Số máy chủ gọi không phải là thuê bao của ISDN.
+ Số chủ gọi không phải là mã giả cho một chùm trung kế số.
+ Thời điểm bắt đầu của một cuộc gọi trong nhóm sau hoặc bằng thời điểm bắt đầu của một cuộc gọi bất kỳ trong nhóm hoặc thời điểm bắt đầu của một cuộc gọi trong nhóm trước hoặc bằng thời điểm kết thúc của một cuộc gọi bất kỳ trong nhóm.
Các cuộc gọi liên tiếp là các cuộc gọi có thời gian ngắn là nhóm bao gồm các cuộc gọi sau:
+ Có cùng số máy chủ gọi.
+ Có cùng số máy bị gọi.
+ Thời gian liên lạc dưới 60 giây.
+ Khoảng cách giữa thời gian kết thúc cuộc gọi và thời gian bắt đầu cuộc gọi sau dưới 30 giây.
+ Nhóm các cuộc có ít nhất 3 cuộc trở lên.
- Tách, gộp thuê bao.
- Tra cứu cước nóng và dữ liệu khách hàng
- Lên các báo cáo:
+ Báo cáo về doanh thu trong nước, quốc tế theo khoảng thời gian hoặc theo chu kỳ tuỳ theo yêu cầu nghiệp vụ của phòng kinh doanh thu cước.
+ Báo cáo về các thuê bao bỏ dùng, mới dùng theo chu kỳ tùy theo yêu cầu của bộ phận chăm sóc khách hàng.
+ Các bảng kê chi tiết các cuộc gọi của khách hàng.
+ Báo cáo theo yêu cầu của phòng ban, lãnh đạo.
Dữ liệu vào:
- Thông tin về khách hàng.
- Thông tin về chi tiết các cuộc gọi.
- Các thay đổi về cước.
Sơ đồ luồng thông tin – IFD
- Xem xét sơ đồ IFD của quá trình :
+ Tính cước phát sinh của khách hàng.
+ Cập nhật thông tin của khách hàng.
- Các ký pháp sử dụng để biểu diễn sơ đồ luồng thông tin:
+ Xử lý:
Thủ công Giao tác người – máy Tin học hoá hoàn toàn
+ Kho dữ liệu:
Thủ công Tin học hóa
+ Dòng thông tin
+ Điều khiển
Hình 3.1. Sơ đồ IFD quá trình tính cước của khách hàng
Hình 3.2. Sơ đồ IFD quá trình cập nhật thông tin của khách hàng
II. Mô hình hoá các yêu cầu của hệ thống
Sơ đồ chức năng của hệ thống
Hình 3.3. Mô hình chức năng của hệ thống 2. Sơ đồ luồng dữ liệu của hệ thống
Hình 3.4. Sơ đồ ngữ cảnh của hệ thống
Hình 3.5. Sơ đồ luồng dữ liệu mức 0 của hệ thống
Hình 3.6. Sơ đồ luồng dữ liệu phân rã mức 1 của chức năng “Ghi thông tin cuộc gọi”
Hình 3.7. Sơ đồ luồng dữ liệu mức 1 của chức năng “Cập nhật dữ liệu khách hàng”
Hình 3.8. Sơ đồ luồng dữ liệu mức 1 của chức năng “Tra cứu”
Hình 3.9. Sơ đồ luồng dữ liệu mức 1 chức năng “Báo cáo”4. Các phích từ điển dữ liệu chính của chương trình
- Các phích xử lý lôgic
Phích xử lý lôgic Xử lý cuộc gọi
Tên tiến trình : Xử lý cuộc gọi.
Tiến trình : 1.2
Mô tả: Xử lý cuộc gọi như : cuộc gọi trùng, cuộc gọi liên tiếp, cuộc gọi chờm.
Các luồng dữ liệu vào : thông tin về cuộc gọi nhận được từ Trung tâm điện thoại cố định .
Các luồng dữ liệu ra : thông tin đã xử lý đầy đủ.
Kho dữ liệu của xử lý : tệp hồ sơ cuộc gọi hoàn chỉnh.
Phích xử lý lôgic Ghi thông tin khách hàng
Tên xử lý : Ghi thông tin khách hàng.
Tiến trình : 2.1
Mô tả : Hàng ngày đều có những khách hàng mới sử dụng dịch vụ 178 . Cán bộ phòng tin học sẽ ghi lại các thông tin về những khách hàng mới này.
Các luồng dữ liệu vào : thông tin về cuộc gọi.
Các luồng dữ liệu ra : thông tin về khách hàng
Kho dữ liệu của xử lý : tệp hồ sơ khách hàng.
Phích xử lý lôgic sửa thông tin khách hàng
Tên xử lý : sửa thông tin khách hàng.
Tiến trình : 2.2
Mô tả : Sửa đổi thông tin khách hàng theo yêu cầu.
Các luồng dữ liệu vào : thông tin sửa đổi của khách hàng.
Các luồng dữ liệu ra : thông tin đã sửa đổi.
Kho dữ liệu của xử lý : tệp hồ sơ khách hàng.
Mô tả lôgic của xử lý : hàng tháng, sau khi cộng tác viên thu tiền sử dụng của khách hàng thường có những thông tin mà khách hàng muốn sửa đổi như : thông tin về địa chỉ, thông tin về mã số thuế… Cán bộ phòng tin học sẽ xem thông tin của khách hàng trước khi sửa đổi. Sau đó sửa đổi các thông tin theo yêu cầu và lưu trữ vào cơ sở dữ liệu.
Phích xử lý lôgic tra cứu cước nóng
Tên xử lý : tra cứu cước nóng.
Tiến trình : 3.1
Mô tả : tra cứu thông tin về các cuộc gọi của khách hàng theo yêu cầu của khách hàng hay các phòng ban như : phòng kinh doanh, phòng chăm sóc khách hàng...
Các luồng dữ liệu vào : yêu cầu tra cứu của khách hàng hay phòng ban.
Các luồng dữ liệu ra : thông tin về các cuộc gọi của khách hàng hay tiền cước phát sinh.
Kho dữ liệu của xử lý : tệp thông tin về cuộc gọi.
Mô tả lôgic của xử lý : khi cán bộ phòng tin học tra cứu thông tin về khách hàng mới sử dụng dịch vụ 178 sẽ có những khách hàng hỏi về thông tin các cuộc gọi đã sử dụng dịch vụ 178 như : ngày, giờ, nơi gọi đến, số máy gọi đến, tiền cước…. Hay khi các phòng ban muốn biết nhanh chóng doanh thu trong những khoảng thời gian nào đó để phục vụ công tác chuyên môn, các phòng ban sẽ yêu cầu tra cứu cước nóng. Khi có những yêu cầu này, cán bộ phòng tin học sẽ xem xét yêu cầu tra cứu của khách hàng hay phòng ban và trả lời các yêu cầu đó.
Phích xử lý lôgic tra cứu dữ liệu khách hàng
Tên xử lý : tra cứu dữ liệu khách hàng.
Tiến trình : 3.2
Mô tả : tra cứu thông tin về khách hàng theo yêu cầu của các phòng ban hay phục vụ yêu cầu của chính các cán bộ phòng tin học.
Các luồng dữ liệu vào : yêu cầu tra cứu của nhân viên hay phòng ban.
Các luồng dữ liệu ra : thông tin khách hàng cần tra cứu.
Kho dữ liệu của xử lý : tệp hồ sơ khách hàng.
Mô tả lôgic của xử lý : khi cần biết thông tin về một khách hàng hay một thuê bao, cán bộ phòng tin học sẽ tra cứu những thông tin này dựa theo một tiêu thức nào đó để có thể có được những thông tin đầy đủ hơn.
6. Phích xử lý lôgic Báo cáo về cước
Tên xử lý : Báo cáo liên quan đến cước.
Tiến trình : 4.1
Mô tả : lập các báo cáo liên quan đến cước theo yêu cầu của các phòng ban hay của lãnh đạo như : báo cáo doanh thu trong nước, quốc tế, số cuộc gọi, lưu lượng cuộc gọi, sản lượng cuộc gọi…
Các luồng dữ liệu vào : yêu cầu báo cáo của phòng ban hay lãnh đạo.
Các luồng dữ liệu ra : các báo cáo liên quan đến cước.
Kho dữ liệu của xử lý : tệp thông tin về cuộc gọi.
Mô tả lôgic của xử lý : hàng tháng, phòng kinh doanh có yêu cầu các báo cáo liên quan đến cước. Hay khi cần, phòng kinh doanh và lãnh đạo cũng cần những báo cáo này, cán bộ phòng tin học khi nhận được yêu cầu sẽ lên các báo cáo tuỳ thuộc vào những tiêu thức như : thời gian, trong nước hay quốc tế..
7. Phích xử lý lôgic Báo cáo về khách hàng
Tên xử lý : Báo cáo liên quan đến khách hàng sử dụng dịch vụ 178.
Tiến trình : 4.2
Mô tả : lập các báo cáo liên quan đến khách hàng theo yêu cầu của các phòng ban như : báo cáo thuê bao bỏ dùng, mới dùng trong nước và quốc tế, số lượng khách hàng mới phát sinh trong tháng…
Các luồng dữ liệu vào : yêu cầu báo cáo của phòng ban hay lãnh đạo.
Các luồng dữ liệu ra : các báo cáo liên quan đến khách hàng.
Kho dữ liệu của xử lý : tệp hồ sơ khách hàng.
Mô tả lôgic của xử lý : hàng tháng, bộ phận chăm sóc khách hàng có yêu cầu các báo cáo liên quan đến thuê bao bỏ dùng, mới dùng dịch vụ 178…. Hay khi cần, phòng kinh doanh cũng cần những báo cáo này, cán bộ phòng tin học khi nhận được yêu cầu sẽ lên các báo cáo tuỳ thuộc vào những tiêu thức như : thời gian, trong nước hay quốc tế..
III. Thiết kế hệ thống thông tin quản lý khách hàng
Thiết kế cơ sở dữ liệu lôgic
Phương pháp thiết kế cơ sở dữ liệu bằng phương pháp mô hình hoá
Bước 1: mô tả mối quan hệ giữa các thực thể trong bài toán quản lý khách hàng và tính cước sử dụng 178
+ Mỗi khách hàng có một hoặc nhiều thuê bao sử dụng dịch vụ 178.
+ Mỗi thuê bao có một hoặc nhiều cuộc gọi gọi liên tỉnh hay quốc tế có sử dụng dịch vụ 178.
+ Mỗi cuộc gọi gọi đến một nơi nhất định.
+ Mỗi một nơi có một hoặc nhiều cuộc gọi được thực hiện.
+ Mỗi một tỉnh thuộc một loại vùng nhất định. Mỗi một vùng như thế sẽ có một hoặc nhiều tỉnh tuỳ thuộc vào sự quy định chung của công ty.
+ Mỗi một vùng thuê bao lại có một mức giá cước nhất định tuỳ thuộc vào mức cước quy định của công ty.
+ Mỗi khách hàng thuộc một phường nhất định.
+ Mỗi quận huyện có một hay nhiều phường.
+ Mỗi quận huyện có một hay nhiều cộng tác viên thu tiền cước.
+ Mỗi cộng tác viên phụ trách thu tiền của khách hàng trong một hay nhiều phường tuỳ thuộc vào sự phân công của phòng kế hoạch và lao động.
- Mô tả các thực thể :
STT
Kiểu thực thể
ý nghĩa
1
Khách hàng
Các khách hàng sử dụng dịch vụ 178.
2
Thuê bao
Một khách hàng có một hay nhiều thuê bao.
3
Chi tiết cuộc gọi
Thông tin về cuộc gọi mà thuê bao đã thực hiện.
4
Cộng tác viên
Nhân viên thu tiền của khách hàng.
5
Cước vùng
Mức giá cước được quy định cho từng vùng nhất định.
6
Tỉnh( thành phố)
Là nơi các cuộc gọi đến.
7.
Phường( xã)
Là các đơn vị hành chính mà các khách hàng trú tại.
8
Quận(huyện)
Một quận (huyện) có một hoặc nhiều phường(xã).
Bước 2: Vẽ sơ đồ quan hệ thực thể ( ERD)
Hình 3.10. Sơ đồ quan hệ thực thể của hệ thống
Bước 3: Đưa ra một số thuộc tính riêng có của thực thể. Lúc này mô hình quan hệ thực thể như sau :
Hình 3.11. Sơ đồ quan hệ thực thể với một số thuộc tính riêng có của thực thể
Bước 4 : chuyển đổi sơ đồ quan hệ thực thể (ERD) sang sơ đồ cấu trúc dữ liệu (DSD)
Hình 3.12. Sơ đồ cấu trúc dữ liệu của hệ thống
Thiết kế biểu mẫu (form) và báo cáo (report)
Form Đăng nhập hệ thống
- Tên form : Login
- Mục đích : kiểm tra tính hợp lệ và quyền của người sử dụng trước khi tham gia vào chương trình.
- Kết cấu :
+ Một nhãn với hướng dẫn thực hiện để truy nhập chương trình.
+ Một textbox cho phép nhập tên truy nhập của người sử dụng.
+ Một textbox cho phép nhập mật khẩu của người sử dụng.
+ Một combobox cho phép chọn năm làm việc.
+ Hai nút:
- Nút Đăng nhập : nếu tên và mật khẩu đúng sẽ cho phép vào chương trình.
- Nút Thoát: thoát khỏi form.
Form sửa thông tin của khách hàng
- Tên form: Sửa khách hàng
- Mục đích: sửa đổi thông tin khách hàng và các thuê bao của khách hàng đó.
- Kết cấu:
+ Có 2 textbxox để điền thông tin về khách hàng cần sửa đổi thông tin đó là số thuê bao đại diện hoặc mã khách hàng.
+ Các nhãn và textbox thể hiện thông tin chi tiết về khách hàng cần sửa đổi .
+ Các nút lệnh:
Nút Sửa đổi : cho phép sửa đổi thông tin về khách hàng.
Nút Lưu : lưu giữ thông tin đã sửa đổi.
Nút Chi tiết thuê bao : cho phép hiện ra một bảng chứa thông tin về các thuê bao của khách hàng.
Nút Thoát : thoát khỏi form.
Khi nhấn nút Chi tiết thuê bao ta sẽ có bảng chi tiết về thuê bao.Với bảng này ta có thể thêm, sửa, xoá thông tin về các thuê bao của khách hàng cần sửa đổi thông tin.
Form cập nhật thông tin chi tiết cuộc gọi
- Tên form : Cập nhật cuộc gọi
- Mục đích : cập nhật thông tin chi tiết về các cuộc gọi của các thuê bao sử dụng gọi điện thoại đường dài và quốc tế sử dụng dịch vụ 178.
- Kết cấu :
+ Một combobox : cho phép điền đường dẫn đến các tệp muốn cập nhật thông tin.
+ Nút lệnh Browse : cho phép chọn đường dẫn mà không cần phải tự điền đường dẫn vào combobox.
+ Nút Thực hiện : thực hiện cập nhật thông tin cuộc gọi từ các tệp theo đường dẫn.
+ Nút Thoát : thoát khỏi form.
Report chi tiết cuộc gọi của khách hàng.
- Tên report : báo cáo cước khách hàng.
- Mục đích : trình bày thông tin chi tiết về các cuộc gọi của khách hàng theo từng thuê bao (số máy).
- Kết cấu của report :
+ Phần tên report : bảng kê chi tiết cuộc gọi khách hàng. Thông tin về thời gian, tỷ giá của chu kỳ cước.
+ Phần thân report : hiện thông tin chi tiết về các cuộc gọi của thuê bao dưới dạng bảng bao gồm : ngày gọi, thời gian bắt đầu gọi, thời gian đã gọi, số máy gọi đến, tiền cước, nơi gọi đến.
+ Phần cuối report : tính tổng số tiền cước của thuê bao và của khách hàng.
3. Thiết kế giao diện và hội thoại
Thiết kế giao diện của chương trình
Chương trình sử dụng giao diện thực đơn ( menu)
Các chức năng được phân cấp như sau:
Hình 3.13. Sơ đồ modul “Cập nhật” của chương trình
Hình 3.14. Sơ đồ modul “Tìm kiếm” của chương trình
Hình 3.15. Sơ đồ modul “Báo cáo” của chương trình
Hình 3.16. Sơ đồ modul “Hệ thống” của chương trình
Thiết kế các hội thoại
- Chương trình sử dụng rất nhiều hội thoại để giao tiếp với người sử dụng, nhằm tránh điền thông tin không chính xác và tạo sự thân thiện với người dùng.
- Hội thoại thông báo cho người dùng khi người dùng không điền thông tin về thuê bao khi người dùng muốn xem cước nóng của thuê bao:
- Hội thoại dùng khi người dùng muốn xoá thông tin về xã phường. Mục đích khẳng định lại thực sự có muốn xoá không :
- Hội thoại dùng khi người dùng cập nhật dữ liệu về cuộc gọi mà dữ liệu này đã được cập nhật. Mục đích ngăn ngừa không cho cập nhật hai lần cùng một dữ liệu.
4. Thiết kế cơ sở dữ liệu mức vật lý
Cơ sở dữ liệu bao gồm các bảng với các thuộc tính như sau :
Bảng khách hàng (khach_hang.dbf)
Lưu thông tin về các khách hàng sử dụng dịch vụ 178.
Tên trường
Kiểu và kích thước
Giải thích
Ma_kh
Character (15)
Mã khách hàng
Ten_kh
Character (55)
Tên khách hàng
Dia_chi
Character (85)
Địa chỉ
Ngaybd
Date(8)
Ngày bắt đầu sử dụng dịch vụ 178
Mst
Character (15)
Mã số thuế
Ma_xp
Character (10)
Mã xã phường
Ma_ctv
Character (15)
Mã cộng tác viên
Bảng thuê bao (thue_bao.dbf)
Một khách hàng có một hoặc nhiều thuê bao, bảng thuê bao sẽ lưu thông tin về các thuê bao trực thuộc các khách hàng cụ thể.
Tên trường
Kiểu và kích thước
Giải thích
So_may
Character (10)
Số máy
Ten_tbao
Character (55)
Tên thuê bao
Dia_chi
Character (85)
Địa chỉ
Ma_kh
Character (20)
Mã khách hàng
Bảng chi tiết cuộc gọi (chitiet_cuocgoi.dbf)
Lưu thông tin về các cuộc gọi mà các thuê bao thực hiện gọi đường dài và quốc tế có sử dụng dịch vụ 178
Tên trường
Kiểu và kích thước
Giải thích
Ma_cg
Character (35)
Mã cuộc gọi
Ngay
Date (8)
Ngày
Giobd
Character (6)
Giờ bắt đầu
So_may
Character (10)
Số máy
Sobg
Character (25)
Số bị gọi
Tgll
Numeric (8)
Thời gian liên lạc
Donvi
Numeric (8)
Đơn vị( quy theo phút hay block)
Vung
Character (10)
Vùng gọi
Bảng mã vùng (vung.dbf)
Mỗi cuộc gọi đều gọi đến một tỉnh hay thành phố trong nước hoặc quốc tế. Bảng mã vùng sẽ lưu thông tin về các vùng mà sử dụng được dịch vụ 178 gọi đến.
Tên trường
Kiểu và kích thước
Giải thích
Ma_vung
Character (15)
Mã vùng
Ten_vung
Character (40)
Tên vùng
Loai_gia
Character (8)
Loại giá cước
Bảng cước theo vùng (cuoctheo_vung.dbf)
Mỗi cuộc gọi thực hiện đều gọi đến một tỉnh hay một thành phố trong nước hay quốc tế. Và các tỉnh, thành phố này lại được phân theo các vùng nhất định. Với mỗi vùng lại có một mức giá cước. Giá cước tính theo đôla Mỹ với gọi quốc tế. Bảng này sẽ lưu các thông tin đó.
Tên trường
Kiểu và kích thước
Giải thích
Loai_gia
Character (6)
Loại giá cước
Ten_vung
Character (20)
Tên vùng
Ty_gia
Numeric (8.2)
Tỷ giá đôla Mỹ trong chu kỳ cước
Bảng xã phường (xa_phuong.dbf)
Mỗi khách hàng thuộc một phường nhất định.Bảng này lưu trữ các thông tin về phường( xã) nơi khách hàng thuộc về.
Tên trường
Kiểu và kích thước
Giải thích
Ma_xp
Character (10)
Mã phưỡng xã
Ten_xp
Character (35)
Tên phường xã
Ma_qh
Character (10)
Mã quận huyện
Bảng danh mục quận huyện (dm_quanhuyen.dbf)
Bảng này lưu trữ thông tin về quận, huyện. Mỗi quận, huyện có một hay nhiều phường, xã.
Tên trường
Kiểu và kích thước
Giải thích
Ma_qh
Character (10)
Mã quận huyện
Ten_qh
Character (30)
Tên quận huyện
Bảng cộng tác viên (dm_ctv.dbf)
Bảng này lưu trữ thông tin về các cộng tác viên. Mỗi khách hàng quản lý thu tiền cước của một hay nhiều cộng tác viên thuộc một hay nhiều phường thuộc một quận, huyện nhất định.
Tên trường
Kiểu và kích thước
Giải thích
Ma_ctv
Character (10)
Mã cộng tác vien
Ten_ctv
Character (35)
Tên cộng tác viên
Ma_qh
Character (10)
Mã quận huyện
IV. Triển khai hệ thống thông tin quản lý khách hàng và tính cước
1. Một số thuật toán sử dụng trong chương trình
Thuật toán đăng nhập chương trình
Thuật toán báo cáo cước nóng khách hàng
Thuật toán sửa đổi thông tin khách hàng
2. Một số giao diện của chương trình
Form cập nhật khách hàng : cho phép cập nhật thông tin về khách hàng mới hàng ngày. Có thể cập nhật từng khách hàng hoặc cập nhật nhiều khách hàng cùng một lúc.
Form danh mục mã vùng: cho phép thêm, sửa, xoá thông tin về mã vùng gọi 178.
Khi chọn nút thêm (hay ấn F4) form thêm vùng sẽ được mở với các nút : ghi và thoát.
Khi nhấn nút sửa( hay ấn F3) để sửa thông tin cho vùng gọi VoIP quốc tế Canada, form sửa thông tin vùng sẽ được mở với các nút : nhận và thoát.
Khi ấn nút xoá( hay ấn F8) để xoá thông tin vùng gọi VoIP quốc tế Canada, sẽ mở hộp thoại sau:
Form gộp thuê bao. (Một khách hàng có nhiều thuê bao, tuy nhiên có những thuê bao trong cùng một công ty nhưng lại không cùng mã khách hàng với mã khách hàng của công ty. Khi có yêu cầu, sẽ gộp những thuê bao này vào cùng với công ty).
Form tra cứu thông tin khách hàng
Form tra cước nóng thuê bao
Giả sử cho thuê bao (4).7236066 từ ngày 01/12/2004 đến 15/12/2004 ta có kết quả sau :
Form báo cáo doanh thu quốc tế
Giả sử chọn báo cáo từ ngày 01/12/2004 đến 15/12/2004 ta có kết quả :
Form báo cáo thuê bao mới, bỏ dùng
Giả sử chọn thời gian từ 01/12/2004 đến 15/12/2004 ta có kết quả sau :
Form thêm mới, sửa đổi, xoá thông tin người dùng chương trình
Khi chọn nút sửa, ta có kết quả :
Hướng dẫn cài đặt và sử dụng
Để chương trình có thể chạy được thì cần đạt được một số yêu cầu sau :
Phần cứng
Một máy PC với các thông só:
Bộ xử lý có tốc độ tối thiểu là 350
Ram 32 trở lên
ổ cứng còn trống ít nhất 150 MB
Máy in
Phần mềm
Chương trình chạy được trong môi trường của hệ điều hành : Win9X, Win2K, WinXP.
Yêu cầu cài đặt Visual Foxpro.
Hướng dẫn sử dụng
Để sử dụng chương trình, yêu cầu sao lưu toàn bộ thư mục có tên “QLKH” vào ổ C (hoặc ổ D) giữ nguyên tên hoặc đổi tên (Ví dụ : quan_ly_khach_hang).
Chạy chương trình với đường dẫn phù hợp với bắt buộc phải có qlkh.app
Ví dụ: C:\QLKH\qlkh.app
hoặc C:\ quan_ly_khach_hang\qlkh.app
Kết luận
Xây dựng, phát triển và nâng cấp các hệ thống thông tin trong các doanh nghiệp trong mọi lĩnh vực đã trở thành một yêu cầu, một tất yếu cuả thời đại. Với mỗi doanh nghiệp tuỳ thuộc vào lĩnh vực hoạt động mà đòi hỏi cho mình một hệ thống thông tin phù hợp. Đối với các doanh nghiệp kinh doanh, một trong những hệ thống thông tin cơ bản là hệ thống thông tin quản lý khách hàng. Hệ thống quản lý khách hàng hoạt động tốt sẽ tạo điều kiện thuận lợi cho sự phát triển của doanh nghiệp.
Với những kiến thức có được sau 4 năm học và sự giúp đỡ của thầy cô, bạn bè, em đã hoàn thành luận văn tốt nghiệp đại học này. Trong luận văn, em đã quan tâm đến vấn đề quản lý khách hàng và tính cước sử dụng 178 tại Trung tâm Viễn thông Hà Nội. Chương trình đã đáp ứng được những yêu cầu cơ bản đối với một hệ thống thông tin. Ngoài ra, với giao diện thân thiện, đơn giản đã tạo cho người dùng sự dễ dàng và thuận tiện khi sử dụng.
Dù đã rất cố gắng nhưng do trình độ của bản thân còn hạn chế nên chương trình chưa được như mong muốn. Sau khi có điều kiện, chương trình sẽ được nâng cấp, mở rộng đi sâu hơn nữa để có thể trở thành phần mềm có ích và có khả năng ứng dụng trong nhiều doanh nghiệp.
Qua quá trình thực tập cùng với thời gian làm luận văn, em đã có được những kinh nghiệm quý báu cho bản thân. Em xin chân thành cảm ơn thầy giáo TS. Trương Văn Tú, các thầy cô giáo trong Khoa Tin học kinh tế và các cán bộ phòng tính cước Trung tâm Viễn thông Hà Nội đã giúp đỡ và chỉ bảo em.
Tài liệu tham khảo
TS. Trương Văn Tú – TS. Trần Thị Song Minh
Giáo trình hệ thống thông tin quản lý, Hà Nội, 2000.
TS. Hàn Viết Thuận (chủ biên)
Giáo trình tin học đại cương, NXB lao động – xã hội, 2002.
VN – Guide và Đinh Xuân Lân tổng hợp và biên dịch
Những bài thực hành Visual Foxpro, NXB Thống kê, Hà nội, 2004.
Nguyễn Ngọc Minh
Sử dụng và khai thác Visaual Foxpro 6.0, NXB Giáo dục, 2000.
Phụ lục
Một số chương trình nguồn cơ bản
Cập nhật thông tin cuộc gọi
* XU LY CAC CUOC GOI VA APPEN DU LIEU LUON
set talk on
set safe off
set date dmy
close table all
local m,n,p,i, ng
m=dd
local cStartDir
m.cStartDir = Lower(sys(5)+curdir())
use &m
*if not open ('&m') then
*=messagebox(' khong co')
*return
*else
count to Scd
index on dtoc(Ngay)+allt(Giobd)+allt(So_may)+allt(Sobg) to T uniq
wait wind ' Dang xu ly cuoc goi va cap nhat du lieu' nowait
copy to m.cStartDir+'Trunggian'
close data
*endi
Creat table m.cStartDir+' Filexuly' (ma_cg C(36),Ngay D,Giobd C(6),;
So_may C(10),Sobg C(18),Tgll N(8),donvi N(10),tien N(10),mabc C(10),vung C(10))
sele a
use m.cStartDir+' filexuly'
appen from m.cStartDir+'trunggian'
count to Scc
Trung=Scd-Scc
* ghep ma cuoc goi cho tung cuoc goi
repl all ma_cg with dtoc(ngay)+giobd+so_may
* ghep ma buu cuc cho tung cuoc goi
repl all mabc with 'PTO' for left((sobg),7)='1780210'
repl all mabc with 'LCU' for left((sobg),6)='178023'
repl all mabc with 'BGG' for left((sobg),7)='1780240'
repl all mabc with 'BNH' for left((sobg),7)='1780241'
repl all mabc with 'LSN' for left((sobg),6)='178025'
repl all mabc with 'TQG' for left((sobg),6)='178027'
repl all mabc with 'NBH' for left((sobg),6)='178030'
repl all mabc with 'HPG' for left((sobg),6)='178031'
repl all mabc with 'HDG' for left((sobg),7)='1780320'
repl all mabc with 'QNH' for left((sobg),6)='178033'
repl all mabc with 'HTY' for left((sobg),6)='178034'
repl all mabc with 'NDH' for left((sobg),7)='1780350'
repl all mabc with 'HNM' for left((sobg),7)='1780351'
repl all mabc with 'THA' for left((sobg),6)='178037'
repl all mabc with 'NAN' for left((sobg),6)='178038'
repl all mabc with 'HTH' for left((sobg),6)='178039'
repl all mabc with 'DLC' for left((sobg),6)='178050'
repl all mabc with 'DNG' for left((sobg),7)='1780511'
repl all mabc with 'HUE' for left((sobg),6)='178054'
repl all mabc with 'PYN' for left((sobg),6)='178057'
repl all mabc with 'KHA' for left((sobg),6)='178058'
repl all mabc with 'GLI' for left((sobg),6)='178059'
repl all mabc with 'DNI' for left((sobg),6)='178061'
repl all mabc with 'BTN' for left((sobg),6)='178062'
repl all mabc with 'VTU' for left((sobg),6)='178064'
repl all mabc with 'BDG' for left((sobg),7)='1780650'
repl all mabc with 'TNH' for left((sobg),6)='178066'
repl all mabc with 'DTP' for left((sobg),6)='178067'
repl all mabc with 'CTO' for left((sobg),6)='178071'
repl all mabc with 'LAN' for left((sobg),6)='178072'
repl all mabc with 'TGG' for left((sobg),6)='178073'
repl all mabc with 'BTE' for left((sobg),6)='178075'
repl all mabc with 'AGG' for left((sobg),6)='178076'
repl all mabc with 'KGG' for left((sobg),6)='178077'
repl all mabc with 'BLU' for left((sobg),7)='1780781'
repl all mabc with 'STG' for left((sobg),6)='178079'
repl all mabc with 'HCM' for left((sobg),5)='17808'
* ghep ma 178 cuoc goi
repl all vung with '1780210' for mabc ='PTO'
repl all vung with '1780240' for mabc ='BGG'
repl all vung with '1780241' for mabc ='BNH'
repl all vung with '178025' for mabc ='LSN'
repl all vung with '178027' for mabc ='TQG'
repl all vung with '178030' for mabc ='NBH'
repl all vung with '178031' for mabc ='HPG'
repl all vung with '1780320' for mabc='HDG'
repl all vung with '178033' for mabc='QNH'
repl all vung with '178034' for mabc ='HTY'
repl all vung with '1780350' for mabc ='NDH'
repl all vung with '1780351' for mabc ='HNM'
repl all vung with '178037' for mabc='THA'
repl all vung with '178038' for mabc='NAN'
repl all vung with '178039' for mabc='HTH'
repl all vung with '178050' for mabc='DLC'
repl all vung with '1780511' for mabc='DNG'
repl all vung with '178054' for mabc='HUE'
repl all vung with '178057' for mabc='PYN'
repl all vung with '178058' for mabc='KHA'
repl all vung with '178059' for mabc ='GLI'
repl all vung with '178061' for mabc='DNI'
repl all vung with '178062' for mabc ='BTN'
repl all vung with '178064' for mabc='VTU'
repl all vung with '1780650' for mabc='BDG'
repl all vung with '178066' for mabc ='TNH'
repl all vung with '178067' for mabc='DTP'
repl all vung with '178071' for mabc ='CTO'
repl all vung with '178072' for mabc ='LAN'
repl all vung with '178073' for mabc='TGG'
repl all vung with '178075' for mabc='BTE'
repl all vung with '178076' for mabc='AGG'
repl all vung with '178077' for mabc ='KGG'
repl all vung with '1780781' for mabc ='BLU'
repl all vung with '178079' for mabc='STG'
repl all vung with '17808' for mabc='HCM'
repl all vung with '178023' for mabc='LCU'
*sele filexuly
count to m
go top
n = alltr(str(day(ngay)))
p = alltr(str(month(ngay)))
i = alltr(str(year(ngay)))
ng =ngay
sele b
use chitiet_cuocgoi
inde on ngay to c3
seek ng
if found() then
if messagebox(' Dữ liệu này đã được cập nhật. Có nhập lại không', 36, ' Thông báo')= 6 then
appen_cuocgoi.command1.setfocus
return
else
appen_cuocgoi.release
endi
else
appen from m.cStartDir+' filexuly'
=messagebox(" Đã cập nhật được : "+ alltr(str(m))+ " cuộc gọi trong ngày "+ n+'/'+p+'/'+i, 16, 'Thông báo' )
endi
use in chitiet_cuocgoi
use in m.cStartDir+'filexuly'
use in m.cStartDir+'trunggian2'
release m,n,p,i,ng
Sửa dữ liệu khách hàng
Hiện thông tin khách hàng theo thuê bao đại diện
LPARAMETERS nKeyCode, nShiftAltCtrl
if nkeycode = 13 then
set date dmy
close table all
public m,n
m = alltr(thisform.text1.value)
if len(m) 8 then
=messagebox('Khong tim thay khach hang nao ',16)
thisform.text1.setfocus
else
sele 1
use thue_bao
n = lookup(thue_bao.ma_kh, alltr(m), thue_bao.so_may)
if empty(n) then
=messagebox('Khong tim thay khach hang nao ',16)
thisform.text1.setfocus
else
sele 2
use khach_hang alias khach_hang
p= alltr(lookup(khach_hang.ten_kh, alltr(n), khach_hang.ma_kh))
q= alltr(lookup(khach_hang.dia_chi, alltr(n), khach_hang.ma_kh))
t= alltr(lookup(khach_hang.ma_xp, alltr(n), khach_hang.ma_kh))
c= alltr(lookup(khach_hang.ma_ctv, alltr(n), khach_hang.ma_kh))
b= alltr(lookup(khach_hang.ma_st, alltr(n), khach_hang.ma_kh))
d= lookup(khach_hang.ngay_bd, alltr(n), khach_hang.ma_kh)
thisform.txtmakh.value = n
thisform.txtten.value = p
thisform.txtdiachi.value=q
thisform.txtmaqh.value=t
thisform.txtmactv.value=c
thisform.txtmst.value=b
thisform.txtngay.value=d
thisform.txtmakh.readonly =.T.
thisform.txtten.readonly =.T.
thisform.txtdiachi.readonly =.T.
thisform.txtmaqh.readonly =.T.
thisform.txtmactv.readonly =.T.
thisform.txtngay.readonly=.T.
thisform.txtmst.readonly=.T.
use in khach_hang
use in thue_bao
** TEN XA PHUONG
sele 3
use maphuong
mp=lookup(ten_xp, alltr(t), ma_xp)
thisform.lbtenqh.caption= PADR(ALLTRIM(mp),20)
use in maphuong
** TEN CONG TAC VIEN
sele 4
use congtac_vien
mc=lookup(ten_ctv, alltr(c), ma_ctv)
thisform.lbtenctv.caption= PADR(ALLTRIM(mc),35)
use in congtac_vien
**
thisform.command3.enabled= .T.
thisform.command4.enabled= .T.
endi
endi
endi
Lưu trữ thông tin đã sửa đổi
SET SAFETY off
SET EXACT on
Private m_mk,m_tk, m_dc, m_qh, m_ctv, m_st, m_ngay
m_mk=thisform.txtmakh.Value
m_tk=thisform.txtten.Value
m_dc=thisform.txtdiachi.Value
m_xp=thisform.txtmaqh.Value
m_ctv=thisform.txtmactv.Value
m_st=thisform.txtmst.Value
m_ngay= thisform.txtngay.Value
IF EMPTY(thisform.txtmakh.Value)
MESSAGEBOX("Ma khach hang khong the de trong")
thisform.txtmakh.setfocus
ELSE
IF EMPTY(thisform.txtten.Value) then
MESSAGEBOX("Tên khách hàng không được để trống!")
thisform.txtten.setfocus
ELSE
use khach_hang
LOCATE FOR ma_kh=m_mk AND ten_kh=m_tk AND dia_chi= m_dc AND ma_xp = m_xp AND ma_ctv= m_ctv;
AND ma_st=m_st AND ngay_bd=m_ngay AND ma_kh m_mk
IF FOUND() then
MESSAGEBOX("Mã khách hàng và tên khách hàng đã có!")
ELSE
replace ma_kh WITH m_mk FOR ma_kh=m_mk
replace ten_kh WITH m_tk FOR ma_kh=m_mk
replace dia_chi WITH m_dc FOR ma_kh=m_mk
replace ma_xp WITH m_xp FOR ma_kh=m_mk
replace ma_ctv WITH m_ctv FOR ma_kh=m_mk
replace ma_st WITH m_st FOR ma_kh=m_mk
replace ngay_bd WITH m_ngay FOR ma_kh=m_mk
use in khach_hang
thisform.command4.enabled=.T.
thisform.command3.enabled=.T.
ENDIF
ENDIF
ENDIF
Hiện danh mục thuê bao theo khách hàng
ZOOM WINDOW SCREEN MAX &&_SCREEN.WINDOWSTATE = 2
M_ScrRow = SROW()
M_ScrCol = SCOL()
m_font_name='vntime'
m_font_size=12
DEFINE WINDOW M_WinBrw FROM 00, 01 TO 450,610 COLOR SCHEME 10 FONT M_Font_name, M_Font_Size
*CLOSE FLOAT GROW MINIMIZE ZOOM SYSTEM FONT M_Font_name, M_Font_Size
public m
m = alltr(edit_kh_2.txtmakh.value)
if not used("thue_bao") then
sele 3
use thue_bao orde so_may alias thue_bao
set filter to ma_kh= m
ON KEY LABEL F3 DO form edit_tbao
ON KEY LABEL F4 DO form add_tbao
ON KEY LABEL F8 DO xoa_tbao
BROWSE;
NOAPPEND NOMODIFY NODELETE ;
WINDOW M_WinBrw ;
TITLE 'Chi tiết thuê bao' + [. F3 - Sửa , F4-Thêm , F8 - Xoá , Esc-Quay ra] ;
FONT '.Vntime', 12
ON KEY LABEL F3
ON KEY LABEL F4
ON KEY LABEL F8
endi
return
use in thue_bao
*** Xoa thue bao
PROCEDURE xoa_tbao
PRIVATE _Ans, _RecNo
*USE IN thue_bao exclusive
_RecNo = RECNO()
_Ans = messageBox(' Có chắc chắn xoá không?', 4+32+256, 'Chú ý')
IF _Ans # 6
GO _Recno
RETURN .T.
ENDIF
GO _Recno
M.Status="*"
DELETE
*SET DELETED on
pack
RETURN .T.
***
close all
Báo cáo cước nóng khách hàng
set talk off
set safe off
set date FREN
local c, a, m
public _fromdate, _todate,_year,_month,_ty_gia
_fromdate= thisform.txtfromdate.value
_todate= thisform.txttodate.value
_year=alltr(thisform.combo2.value)
_month= alltr(thisform.combo1.value)
a= alltr(thisform.text1.value)
C= 'QT'
* CHON TY GIA
close table all
use cuoctheo_vung
_ty_gia=lookup(ty_gia, alltr(c),cuoctheo_vung.loai_vung)
use in cuoctheo_vung
* Kiem tra du lieu nhap vao
* khong chon so thue bao
if empty(thisform.text1.value) then
= messagebox(' Không chọn số thuê bao', 16 )
thisform.text1.setfocus
return
else
if left(alltr(a),1)'4' then
= messagebox('Phải thêm số 4 trước số máy',16)
thisform.text1.setfocus
return
else
if len(a) 8 then
= messagebox('Không có số thuê bao này',16)
thisform.text1.setfocus
return
else
use thue_bao
inde on so_may to c1
seek a
if found() then
m= alltr(so_may)
else
= messagebox('Không có số thuê bao này',16)
thisform.text1.setfocus
return
endi
use in thue_bao
endi
endi
endi
**** khong chon nam
if empty(thisform.combo2.value) then
= messagebox(' Khong chon nam cho chu ky cuoc', 16 )
thisform.combo2.setfocus
return
endi
** khong chon chu ky cuoc
if thisform.opg2.value=1 then
if empty(thisform.combo1.value) then
= messagebox(' Khong chon chu ky cuoc', 16 )
thisform.combo1.setfocus
return
endi
else
IF (Thisform.txtToDate.Value > DATE()) OR (Thisform.txtFromDate.Value > THISFORM.txtToDate.Value)
=messagebox(' Du lieu ngay nhap khong chinh xac', 64, 'Chu y' ) = 6
THISFORM.txtToDate.Setfocus
RETURN
ENDIF
endi
*** bat dau
IF thisform.opg2.value=1 then
do form frmdoi
create cursor rpt_cuoc_kh ( so_may C(15), ten_tbao C(40),dia_chi C(80), ;
ngay D, giobd C(6), sobg C(20), tgll N(5), donvi N(5),tien N(8), ten_vung C(35))
SELECT Thue_bao.so_may, Thue_bao.ten_tbao, Thue_bao.dia_chi,;
Chitiet_cuocgoi.ngay, Chitiet_cuocgoi.giobd, Chitiet_cuocgoi.sobg,;
Chitiet_cuocgoi.tgll, Chitiet_cuocgoi.donvi,;
Chitiet_cuocgoi.donvi*Cuoctheo_vung.gia_cuoc*Cuoctheo_vung.ty_gia AS tien,;
Ma_vung.ten_vung;
FROM cdtt!cuoctheo_vung INNER JOIN cdtt!ma_vung;
INNER JOIN cdtt!chitiet_cuocgoi;
INNER JOIN cdtt!thue_bao ;
ON Thue_bao.so_may = Chitiet_cuocgoi.so_may ;
ON Ma_vung.ma_vung = Chitiet_cuocgoi.vung ;
ON Cuoctheo_vung.loai_vung = Ma_vung.loai_vung;
WHERE Chitiet_cuocgoi.donvi >= 1 AND MONTH(chitiet_cuocgoi.ngay)= val(_MONTH);
AND YEAR(chitiet_cuocgoi.ngay) = val(_year);
AND like(m,thue_bao.so_may);
ORDER BY thue_bao.so_may;
INTO CURSOR cuoc_kh
SCAN
INSER INTO rpt_cuoc_kh VALUE (cuoc_kh.so_may, cuoc_kh.ten_tbao, cuoc_kh.dia_chi,;
cuoc_kh.ngay,cuoc_kh.giobd,cuoc_kh.sobg, cuoc_kh.tgll,;
cuoc_kh.donvi, cuoc_kh.tien,cuoc_kh.ten_vung)
ENDSCAN
sele rpt_cuoc_kh
repl all tien with tien *0.7 for ngay={^2004/12/04} or ngay={^2004/12/05} or ngay ={^2004/12/11} or ngay ={^2004/12/12} or ngay ={^2004/12/18};
or ngay ={^2004/12/19} or ngay ={^2004/12/25} or ngay ={^2004/12/26} or ngay ={^2005/01/01} or ngay ={^2005/01/02} or ngay ={^2005/01/08} or ngay ={^2005/01/09} ;
or ngay ={^2005/01/15} or ngay ={^2005/01/16} or ngay ={^2005/01/22} or ngay ={^2005/01/23} or ngay ={^2005/01/29} or ngay ={^2005/01/30}
repl all tien with tien*0.7 for giobd {^2004/12/11}and ngay {^2004/12/12}and ngay {^2004/12/18};
and ngay {^2004/12/19} and ngay {^2004/12/25} and ngay {^2004/12/26} and ngay {^2005/01/01} and ngay {^2005/01/02} and ngay {^2005/01/08} and ngay {^2005/01/09} ;
and ngay {^2005/01/15} and ngay {^2005/01/16} and ngay {^2005/01/22} and ngay {^2005/01/23} and ngay {^2005/01/29} and ngay {^2005/01/30}
repl all tien with tien*0.7 for giobd >='230000' and ngay != {^2004/12/04}and ngay!={^2004/12/05} and ngay {^2004/12/11}and ngay {^2004/12/12}and ngay {^2004/12/18};
and ngay {^2004/12/19} and ngay {^2004/12/25} and ngay {^2004/12/26} and ngay {^2005/01/01} and ngay {^2005/01/02} and ngay {^2005/01/08} and ngay {^2005/01/09} ;
and ngay {^2005/01/15} and ngay {^2005/01/16} and ngay {^2005/01/22} and ngay {^2005/01/23} and ngay {^2005/01/29} and ngay {^2005/01/30}
if Reccount() = 0 then
frmdoi.release
= messagebox(' Khong co du lieu de bao cao', 16, 'Thong bao')
return
endi
do case
case thisform.opg3.value =1
frmdoi.release
report form rpt_cuoc_tb_thang preview
case thisform.opg3.value =2
frmdoi.release
report form rpt_cuoc_tb_thang to printe noconsole
endcase
use in rpt_cuoc_kh
ELSE
do form frmdoi
create cursor rpt_cuoc_kh ( so_may C(15), ten_tbao C(40),dia_chi C(80), ;
ngay D, giobd C(6), sobg C(20), tgll N(5), donvi N(5),tien N(8), ten_vung C(35))
SELECT Thue_bao.so_may, thue_bao.ten_tbao, thue_bao.dia_chi, Chitiet_cuocgoi.ngay, Chitiet_cuocgoi.giobd,;
Chitiet_cuocgoi.sobg, Chitiet_cuocgoi.tgll, Chitiet_cuocgoi.donvi,;
Chitiet_cuocgoi.donvi* Cuoctheo_vung.gia_cuoc* Cuoctheo_vung.ty_gia AS tien,;
Ma_vung.ten_vung;
FROM cdtt!thue_bao INNER JOIN cdtt!chitiet_cuocgoi;
INNER JOIN cdtt!ma_vung;
INNER JOIN cdtt!cuoctheo_vung ;
ON Cuoctheo_vung.loai_vung = Ma_vung.loai_vung ;
ON Ma_vung.ma_vung = Chitiet_cuocgoi.vung ;
ON Thue_bao.so_may = Chitiet_cuocgoi.so_may ;
WHERE Chitiet_cuocgoi.donvi >= 1 AND BETWEEN(chitiet_cuocgoi.ngay, _fromdate,_todate) AND YEAR(chitiet_cuocgoi.ngay)=val(_year);
AND like(m,thue_bao.so_may);
ORDER BY thue_bao.so_may;
INTO CURSOR cuoc_kh
SCAN
INSER INTO rpt_cuoc_kh VALUE (cuoc_kh.so_may, cuoc_kh.ten_tbao, cuoc_kh.dia_chi,;
cuoc_kh.ngay,cuoc_kh.giobd,cuoc_kh.sobg, cuoc_kh.tgll,;
cuoc_kh.donvi, cuoc_kh.tien,cuoc_kh.ten_vung)
ENDSCAN
sele rpt_cuoc_kh
repl all tien with tien *0.7 for ngay={^2004/12/04} or ngay={^2004/12/05} or ngay ={^2004/12/11} or ngay ={^2004/12/12} or ngay ={^2004/12/18};
or ngay ={^2004/12/19} or ngay ={^2004/12/25} or ngay ={^2004/12/26} or ngay ={^2005/01/01} or ngay ={^2005/01/02} or ngay ={^2005/01/08} or ngay ={^2005/01/09} ;
or ngay ={^2005/01/15} or ngay ={^2005/01/16} or ngay ={^2005/01/22} or ngay ={^2005/01/23} or ngay ={^2005/01/29} or ngay ={^2005/01/30}
repl all tien with tien*0.7 for giobd {^2004/12/11}and ngay {^2004/12/12}and ngay {^2004/12/18};
and ngay {^2004/12/19} and ngay {^2004/12/25} and ngay {^2004/12/26} and ngay {^2005/01/01} and ngay {^2005/01/02} and ngay {^2005/01/08} and ngay {^2005/01/09} ;
and ngay {^2005/01/15} and ngay {^2005/01/16} and ngay {^2005/01/22} and ngay {^2005/01/23} and ngay {^2005/01/29} and ngay {^2005/01/30}
repl all tien with tien*0.7 for giobd >='230000' and ngay != {^2004/12/04}and ngay!={^2004/12/05} and ngay {^2004/12/11}and ngay {^2004/12/12}and ngay {^2004/12/18};
and ngay {^2004/12/19} and ngay {^2004/12/25} and ngay {^2004/12/26} and ngay {^2005/01/01} and ngay {^2005/01/02} and ngay {^2005/01/08} and ngay {^2005/01/09} ;
and ngay {^2005/01/15} and ngay {^2005/01/16} and ngay {^2005/01/22} and ngay {^2005/01/23} and ngay {^2005/01/29} and ngay {^2005/01/30}
if Reccount() = 0 then
frmdoi.release
= messagebox(' Khong co du lieu de bao cao', 16, 'Thong bao')
return
endi
do case
case thisform.opg3.value =1
frmdoi.release
report form rpt_cuoc_tb_ngay preview
case thisform.opg3.value =2
frmdoi.release
report form rpt_cuoc_tb_ngay to printe noconsole
endcase
use in rpt_cuoc_kh
use in cuoc_kh
endi
release c,a,m
Tách thuê bao
Hiện thông tin các thuê bao của khách hàng có thuê bao cần tách
LPARAMETERS nKeyCode, nShiftAltCtrl
if nkeycode = 13 then
close table all
public _ma_kh
local m, n
m = alltr(thisform.text2.value)
if len(m) 8 then
=messagebox('Khong tim thay khach hang nao ',16)
else
sele 1
use thue_bao
n = lookup(thue_bao.ma_kh, alltr(m), thue_bao.so_may)
if empty(n) then
=messagebox('Khong tim thay khach hang nao ',16)
thisform.text2.setfocus
return
else
sele so_may, ten_tbao,dia_chi, ma_kh from cdtt!thue_bao where like(n, ma_kh) into cursor thu
sele thu
_ma_kh= alltr(thu.ma_kh)
if reccount() 0 then
thisform.list1.clear
SCAN
thisform.list1.AddListItem(so_may,recno(),1)
thisform.list1.AddListItem(ten_tbao,recno(),2)
thisform.list1.AddListItem(dia_chi,recno(),3)
thisform.list1.AddListItem(ma_kh,recno(),4)
ENDSCAN
else
= messagebox(' Không tìm thấy khách hàng nào', 16, 'Thông báo')
thisform.text2.setfocus
return
endi
THISform.lbtotal.Caption = PADR(ALLTRIM(STR(THISform.list1.ListCount)),5)
use in thu
use in thue_bao
endi
endi
endi
release m, n
Thực hiện việc tách thuê bao
close all
set talk off
set safe off
local m, sm,dc,tbao,sm1
sm = alltr(thisform.text1.value)
if len(sm) 8 then
=messagebox('Không tìm thấy số thuê bao này ',16)
thisform.text1.setfocus
return
else
sele so_may, ten_tbao, dia_chi, ma_kh from cdtt!thue_bao where alltr(so_may)= alltr(sm) and alltr(ma_kh) = alltr(_ma_kh) into cursor thu
sele thu
sm1= alltr(thu.so_may)
dc= thu.dia_chi
tbao= thu.ten_tbao
if reccount() 0 then
m= "HNI" +alltr(sm1)+"tttt"
sele 1
use khach_hang
inde on ma_kh to c1
seek _ma_kh
if found() then
cngbd= khach_hang.ngay_bd
cmst= khach_hang.ma_st
cmctv= khach_hang.ma_ctv
cmxp=khach_hang.ma_xp
endi
inser into khach_hang( ma_kh, ten_kh, dia_chi, ngay_bd, ma_st, ma_xp, ma_ctv) values (m, tbao, dc ,cngbd, cmst, cmxp, cmctv)
sele 2
use thue_bao
repl ma_kh with alltr(m) for alltr(so_may)=alltr(sm)
else
=messagebox('Không tìm thấy số thuê bao này ',16)
thisform.text1.setfocus
return
endi
endi
use in khach_hang
use in thue_bao
local m, sm,dc,tbao,sm1
if messagebox(' Có tiếp tục tách nữa không?' , 36, ' Thông báo') = 6 then
thisform.text1.setfocus
return
else
thisform.release
endi
5.Tìm kiếm thông tin khách hàng
Tìm kiếm chính xác theo thuê bao đại diện
LPARAMETERS nKeyCode, nShiftAltCtrl
if nkeycode = 13 then
close table all
public m,n
m = alltr(thisform.pg.p1.text1.value)
sele 1
use thue_bao
n = lookup(thue_bao.ma_kh, alltr(m), thue_bao.so_may)
if empty(n) then
=messagebox('Khong tim thay khach hang nao ',16)
thisform.pg.p1.text1.setfocus
else
sele 2
use khach_hang alias khach_hang
p= alltr(lookup(khach_hang.ten_kh, alltr(n), khach_hang.ma_kh))
q= alltr(lookup(khach_hang.dia_chi, alltr(n), khach_hang.ma_kh))
t= alltr(lookup(khach_hang.ma_xp, alltr(n), khach_hang.ma_kh))
c= alltr(lookup(khach_hang.ma_ctv, alltr(n), khach_hang.ma_kh))
b= alltr(lookup(khach_hang.ma_st, alltr(n), khach_hang.ma_kh))
d= lookup(khach_hang.ngay_bd, alltr(n), khach_hang.ma_kh)
thisform.pg.p1.txtmakh.value = n
thisform.pg.p1.txtten.value = p
thisform.pg.p1.txtdiachi.value=q
thisform.pg.p1.txtmaqh.value=t
thisform.pg.p1.txtmactv.value=c
thisform.pg.p1.txtmst.value=b
thisform.pg.p1.txtngay.value=d
use in khach_hang
use in thue_bao
** TEN XA PHUONG
sele 3
use maphuong
m=lookup(ten_xp, alltr(t), ma_xp)
thisform.pg.p1.lbtenqh.caption= PADR(ALLTRIM(m),20)
use in maphuong
** TEN CONG TAC VIEN
sele 4
use congtac_vien
m=lookup(ten_ctv, alltr(c), ma_ctv)
thisform.pg.p1.lbtenctv.caption= PADR(ALLTRIM(m),30)
use in congtac_vien
**
sele so_may, ten_tbao, dia_chi from cdtt!thue_bao where ma_kh = alltr(n) into cursor thu
sele thu
if reccount() 0 then
thisform.pg.p1.list2.clear
SCAN
thisform.pg.p1.list2.AddListItem(so_may,recno(),1)
thisform.pg.p1.list2.AddListItem(ten_tbao,recno(),2)
thisform.pg.p1.list2.AddListItem(dia_chi,recno(),3)
ENDSCAN
endi
THISform.pg.p1.lbtotal.Caption = PADR(ALLTRIM(STR(THISform.pg.p1.list2.ListCount)),5)
use in thu
endi
endi
Tìm kiếm tương đối theo tên khách hàng
LPARAMETERS nKeyCode, nShiftAltCtrl
if nkeycode = 13 then
close table all
public m,n
n= upper(alltr(thisform.pg.p2.text1.value))
sele ma_kh,ten_kh,dia_chi from cdtt!khach_hang where n $ upper(alltr(ten_kh)) into cursor thu
sele thu
if reccount() = 0 then
=messagebox('Khong tim thay khach hang nao ',16)
thisform.pg.p2.text1.setfocus
else
thisform.pg.p2.list2.clear
SCAN
thisform.pg.p2.list2.AddListItem(ma_kh,recno(),1)
thisform.pg.p2.list2.AddListItem(ten_kh,recno(),2)
thisform.pg.p2.list2.AddListItem(dia_chi,recno(),3)
ENDSCAN
endi
THISform.pg.p2.label3.Caption = PADR(ALLTRIM(STR(THISform.pg.p2.list2.ListCount)),5)
use in thu
endi
6. Thêm, sửa, xoá thông tin người dùng
Sự kiện click để lựa chọn công việc
LPARAMETER ccode
ccode=cCurrentUser
THISFORM.CurrentKey = ALLTRIM(cCode)
*set procedure to ctmatma
DO CASE
CASE thisform.opg1.value= 1
THISform.Caption = "Tạo người dùng mới"
THISform.cmdAdd.Caption = "\<Thêm"
*THISform.txtUsername.Enabled = .F.
*THISform.txtPassword.Enabled = .F.
*THISform.txtright.Enabled = .F.
*THISform.txtConfirm.Enabled = .F.
CASE thisform.opg1.value= 2
THISform.txtUsername.Enabled = .F.
THISform.txtPassword.Enabled = .T.
THISform.txtright.Enabled = .T.
THISform.txtConfirm.Enabled = .T.
THISform.Caption = "Sửa đổi thông tin người dùng "
THISform.cmdAdd.Caption = "\<Lưu"
SELECT * FROM usertab WHERE ALLTRIM(Username) == ALLTRIM(cCode) INTO CURSOR GetUserinfo
THISform.txtUsername.Value = Username
THISform.txtPassword.Value = Lower(alltr(Password))
THISform.txtConfirm.Value = THISform.txtPassword.Value
THISform.txtright.Value = quyen
USE IN GetUserInfo
*THISform.cmdRight.Enabled = .F.
CASE thisform.opg1.value= 3
THISform.Caption = "Xoá bỏ thông tin người dùng"
THISform.cmdAdd.Caption = "\<Xoá"
SELECT * FROM usertab WHERE ALLTRIM(Username) == ALLTRIM(cCode) into CURSOR GetUserinfo
THISform.txtUsername.Value = Username
THISform.txtPassword.Value = Lower(alltr(Password))
THISform.txtConfirm.Value = THISform.txtPassword.Value
THISform.txtright.Value = quyen
USE IN GetUserInfo
*THISform.cmdRight.Enabled = .F.
ENDCASE
Nút lưu
set safe off
set talk off
set date dmy
*set procedure to ctmatma
DO CASE
CASE THISFORM.opg1.value=1
DO CASE
CASE THIS.Caption = "\<Thêm"
THIS.Caption = "\<Lưu"
THISform.txtUsername.Enabled = .T.
*THISform.txtPassword.Enabled = .T.
*THISform.txtright.Enabled = .T.
*THISform.txtConfirm.Enabled = .T.
*THIS.Parent.cmdRight.Enabled = .F.
THIS.Parent.txtUsername.Value = ""
THIS.Parent.txtPassword.Value = ""
THIS.Parent.txtConfirm.Value = ""
THIS.Parent.txtright.Value=""
THIS.Parent.txtUsername.Setfocus
CASE THIS.Caption = "\<Lưu"
*THISform.txtUsername.Enabled = .F.
*THISform.txtPassword.Enabled = .F.
*THISform.txtright.Enabled = .F.
*THISform.txtConfirm.Enabled = .F.
cUsername = alltr(THIS.Parent.txtUsername.Value)
cPassword = alltr(THIS.Parent.txtPassword.Value)
cConfirm = alltr(THIS.Parent.txtConfirm.Value)
cright=alltr(THIS.Parent.txtright.Value)
IF EMPTY(cUsername)
messagebox(' Tên không được để trống', 16, 'Thông báo')
THIS.Parent.txtUsername.Setfocus
RETURN
ENDIF
IF EMPTY(cPassword)
messagebox(' Mật khẩu không được để trống', 16, 'Thông báo')
THIS.Parent.txtpassword.Setfocus
RETURN
ENDIF
IF EMPTY(cright)
messagebox(' Quyền không được để trống', 16, 'Thông báo')
THIS.Parent.txtright.Setfocus
RETURN
ENDIF
SELECT Username FROM Usertab WHERE !Deleted() ;
AND ALLTRIM(Username) == cUsername INTO CURSOR GetUsername
IF Reccount() # 0
= messagebox(' Đã có tên người dùng này', 16, 'Thông báo')
THIS.Parent.txtUsername.Setfocus
USE IN GetUsername
RETURN
ENDIF
USE IN GetUsername
IF cPassword == cConfirm
INSERT INTO Usertab VALUE (cUsername, Upper(cPassword), cright)
USE IN Usertab
THIS.Caption = "\<Thêm"
ELSE
= messagebox( "Mật khẩu không đúng, hãy kiểm tra lại.", 16, 'Thông báo')
THIS.Parent.txtPassword.Setfocus
RETURN
ENDIF
ENDCASE
CASE THISFORM.opg1.value= 2
DO CASE
CASE THIS.Caption = "\<Sửa"
CASE THIS.Caption = "\<Lưu"
cUsername = alltr(THISFORM.txtUsername.Value)
cPassword = alltr(THISFORM.txtPassword.Value)
cright = alltr(THISFORM.txtright.Value)
UPDATE Usertab SET Password = upper(cPassword),quyen = cright ;
WHERE ALLTRIM(Username) == ALLTRIM(cUsername)
USE IN Usertab
THIS.Caption = "\<Sửa"
THIS.Enabled = .F.
*THISFORM.cmdRight.Enabled = .T.
ENDCASE
CASE THISFORM.opg1.value= 3
IF THIS.Caption = "\<Xoá"
if messagebox(' Bạn có chắc chắn xoá không?' , 36, 'Thông báo') = 6 then
close table all
use usertab exclusive
inde on username to c4
m= alltr(thisform.txtusername.value)
seek m
if found()
delete
pack
endi
return
else
return
endi
ENDIF
ENDCASE
Các file đính kèm theo tài liệu này:
- 34052.doc