Đồ án Quản lý hộ khẩu cấp phường

• Quan hệ 1-∞(one – to – many ) Hai bảng có quan hệ một nhiều (one – to – many ) nếu đối với bảng thứ nhất có thể không có, hay có một hay nhiều trong bảng thứ hai. Quan hệ một nhiều còn được gọi là quan hệ cha con hay là quan hệ chính phục. Loại quan hệ này được dùng rất nhiều trong CSDL quan hệ. • Quan hệ ∞-∞.(many – to – many ) Hai bảng có quan hệ many – to – many khi đối với mọi hàng trong bảng thứ nhất có thể có nhiều hàng trong bảng thứ hai và đối với mọi bảng trong bảng thứ hai có thể có nhiều hàng trong bảng thứ nhất. Các quan hệ ∞-∞ không thể mô hình hóa trong nhiều phần mềm CSDL trong đó có cả Microsoft Assecc. Những quan

doc117 trang | Chia sẻ: Dung Lona | Lượt xem: 1260 | Lượt tải: 0download
Bạn đang xem trước 20 trang tài liệu Đồ án Quản lý hộ khẩu cấp phường, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
le với extension vb. Trong VB.NET tất cả mọi VB source files đều có extension.vb. System sẽ nhận diện ra loại VB file (form, class, module,. v. v.. ) nhờ đọc content của file, chớ không dựa vào file extension. Nếu bạn muốn đặt tên cho Class mới nầy là TheClass chẳng hạn, thì bạn có thể sửa tên nó trong Dialog. Khi bạn click button Open một file mới sẽ được cho thêm vào trong Project và nó chứa hai hàng code sau: Public Class TheClass End Class 2.7 Tạo một Class mới Class Keyword Trong một.vb file ta có thể viết nhiều Classes, code của mỗi Class nằm trong một Class... End Class block. Thí dụ: Public Class TheClass Public Sub Greeting() MessageBox.Show("Hello world", MsgBoxStyle.Information, "TheClass") End Sub End Class MessageBox.Show và MsgBoxStyle.Information trong VB.NET thay thế MsgBox và vbInformation trong VB6. Classes và Namespaces Nhắc lại là.NET dùng Namespace để sắp đặt các Classes cho thứ tự theo nhóm, loại. Namespaces được declared với một Block Structure giống như sau: Namespace Vovisoft Public Class TheClass Public Sub Greeting() MessageBox.Show("Hello world", MsgBoxStyle.Information, "TheClass") End Sub End Class End Namespace Muốn nói đến bất cứ Class, Structure, hay thứ gì được declared bên trong một Namespace... End Namespace block ta phải dùng tên Namespace trước. Thí dụ: Private myObject As Vovisoft.TheClass Một source file có thể chứa nhiều Namespaces, và bên trong mỗi Namespace lại có thể có nhiều Classes. Ngoài ra, Classes thuộc về cùng một Namespace có thể nằm trong nhiều files khác nhau trong một VB.NET project. Thí dụ ta có một source file với code như sau: Namespace Vovisoft Public Class TheClass ' Code End Class End Namespace Và một source file khác trong cùng project với code: Namespace Vovisoft Public Class TheOtherClass ' Code End Class End Namespace Vậy thì trong Namespace Vovisoft ta có hai Classes TheClass và TheOtherClass. Nhớ là, by default, Root Namespace của một VB.NET project là tên của project ấy. Khi ta dùng Namespace block structure là chúng ta đang thêm một tầng tên vào Root Namespace. Do đó, trong thí dụ trên nếu tên project là MyProject thì, từ bên ngoài project ấy, ta có thể declare một variable như sau: Private myObject As MyProject.Vovisoft.TheClass Tạo ra Methods Methods trong VB.NET có hai thứ: Sub và Function. Function thì phải return một kết quả. By default, parameters của Method là ByVal chớ không phải ByRef. Tức là nếu muốn parameter nào ByRef thì phải nhớ khai ra rõ ràng. Nhắc lại là khi một variable được passed vào trong một method bằng ByVal thì system cho method đó một copy (bản sao) của variable, do đó, trị số của variable không bị thay đổi bởi công tác của method. Ngược lại, nếu một variable được passed vào trong một method bằng ByRef thì method dùng chính variable đó, do đó, trị số của variable có thể bị thay đổi bởi công tác của method. Ta có thể giới hạn việc sử dụng một method bằng cách áp đặt một Access Modifier (sửa đổi quyền truy nhập) hay còn gọi là Scoping keyword (phạm vi hoạt động): Private - chỉ cho phép code trong cùng Class được gọi. Friend - chỉ cho phép code trong cùng project/component được gọi. Public - cho phép ai gọi cũng được. Protected - cho phép code trong subclasses (classes con, cháu) được gọi. Protected Friend - cho phép code trong cùng project/component hay code trong subclasses được gọi. Tạo ra Properties Trong VB.NET ta chỉ dùng một routine duy nhất cho mỗi Property, với hai chữ Get và Set như sau (không còn dùng chữ Let của VB6 nữa): Private mdescription As String Public Property Description() As String Set (ByVal Value As String) mdescription = Value End Set Get Description = mdescription End Get End Property ReadOnly và WriteOnly property Bây giờ nếu Property là ReadOnly ta sẽ lấy phần Set ra và viết: Public ReadOnly Property Age() As Integer Get Age = 3 End Get End Property hay WriteOnly ta sẽ ấy phần Get ra và viết: Private _data As Integer Public WriteOnly Property Data() As Integer Set (ByVal Value As Integer) _data = Value End Set End Property Default Properties Default Property là property của Object mà program dùng khi ta chỉ cho tên của Object và không nói rõ property nào. Thí dụ trong VB6 khi ta code: TextBox1 = "The house of rising sun" VB6 hiểu rằng ta muốn dùng Default Property text của Textbox1 nên code ấy tương đương với: TextBox1.text = "The house of rising sun" Trong VB6 khi ta dùng keyword Set với tên của Object, thí dụ như: Dim myTextBox As Textbox Set myTextBox = TextBox1 program sẽ hiểu là ta muốn nói đến chính Object myTextBox. Nếu không thì nó biết ta muốn nói đến Object Default Property mà làm biếng code cho rõ ra. Trong VB.NET Default Property phải là một Property array. Một Property array là một property được Indexed (nói đến từng Item bằng con số Index) giống như một array. Lý do chính của sự bắt buộc nầy là để khỏi lẫn lộn giữa hai trường hợp ta nói đến Default property của một Object hay chính Object ấy, vì trong VB.NET ta không còn dùng Set keyword cho Object assignment nữa (ta chỉ còn dùng keyword Set trong Property mà thôi). Bây giờ hể muốn nói đến Default Property của Object thì phải dùng Index. Thí dụ để nói đến chính Object, ta code: myValue = myObject để nói đến Default Property Item 3 của Object, ta code: myValue = myObject(3) Sự thay đổi từ VB6 nầy có nghĩa là một property array procedure phải nhận một parameter. Thí dụ: Private theData(100) As String Default Public Property Data(ByVal Index As Integer) As String Get Data = theData(Index) End Get Set(ByVal Value As String) theData(Index) = Value End Set End Property Ta không thể viết: TextBox1 = "Good morning!" như trong VB6 được nữa, mà phải viết: TextBox1.text = "Good morning!" Vì Property Text không còn là Default Property của TextBox. Overloading methods Một trong những chức năng đa diện (Polymorphism) hùng mạnh nhất của VB.NET là overload (quá tải, có rồi mà còn cho thêm) một method. Overloading có nghĩa là ta có thể dùng cùng một tên cho nhiều methods - miễn là chúng có danh sách các parameters khác nhau, hoặc là parameter dùng data type khác nhau (td: method nầy dùng Integer, method kia dùng String), hoặc là số parameters khác nhau (td: method nầy có 2 parameters, method kia có 3 parameters). Overloading không thể được thực hiện chỉ bằng cách thay đổi data type của Return value của Function. Phải có parameter list khác nhau mới được. Dưới đây là thí dụ ta dùng Overloading để code hai Functions tìm data, một cái cho String, một cái cho Integer: Public Function FindData(ByVal Name As String) As ArrayList ' find data and return result End Function Friend Function FindData(ByVal Age As Integer) As ArrayList ' find data and return result End Function Để ý là ta có thể cho mỗi overloading Function một phạm vi hoạt động (Scope on implementation) khác nhau. Trong thí dụ trên ta dùng Access Modifier Public cho Function đầu và Friend cho Function sau. Object Lifecycle Object Lifecycle (cuộc đời của Object) được dùng để nói đến khi nào Object bắt đầu hiện hữu và khi nào nó không còn nữa. Sở dĩ ta cần biết rõ cuộc đời của một Object bắt đầu và chấm dứt lúc nào là để tránh dùng nó khi nó không hiện hữu, tức là chưa ra đời hay đã khuất bóng rồi. New method Trong VB6, khi một Object thành hình thì Sub Class_Initialize được executed. Tương đương như vậy, trong VB.NET ta có Sub New(), gọi là Constructor. VB.NET bảo đảm Sub New() sẽ được CLR gọi khi Object được instantiated và nó chạy trước bất cứ code nào trong Object. Nếu Sub Class_Initialize của một Class Object trong VB6 không nhận parameter thì Sub New() trong VB.NET chẳng những có nhận parameters mà còn cho phép ta nhiều cách để gọi nó. Sự khác biệt trong Constructors của VB6 và VB.NET rất quan trọng. Phần 2: XÂY DỰNG CHƯƠNG TRÌNH Chương 1: GIỚI THIỆU HỆ THỐNG KHÁI NIỆM HỆ THỐNG THÔNG TIN QUẢN LÝ(MIS) Thông tin quản lý là thông tin mà nhà quản lý cần sử dụng để thực hiện tốt chức năng của họ. Hệ thống thông tin quản lý là một hệ thống tập hợp các thông tin hữu ích hay vô ích, có cấu trúc hoặc không có cấu trúc, hình thức hoặc phi hình thức, luân chuyển trong doanh nghiệp. Là một tập hợp các phương tiện xử lý thông tin thông qua mối liên hệ giữa chúng. Một hệ thông tin quản lý bao gồm ba hệ con: hệ quyết định, hệ tác nghiệp và hệ thông tin. + Hệ quyết định: thực hiện các tác vụ quản lý, đưa ra những quyết định chiến lược trong một thời gian ngắn hay dài hạn. + Hệ tác nghiệp: gồm các hoạt động thực hiện những công việc có tính cạnh tranh để đạt được mục tiêu đã xác định bởi hệ quyết định. + Hệ thông tin: thực hiện việc liên hệ giữa hệ quyết định với hệ tác nghiệp, bảo đảm hệ thống vận hành đạt mục tiêu. MIS cung cấp cho hệ ra quyết định những thông tin cần thiết trong quá trình ra quyết định( là các thông tin từ môi trường xung quanh hay từ hệ tác nghiệp). Chuyển các thông tin từ hệ ra quyết định cho hệ tác nghiệp và môi trường bên ngoài hoạt động hệ thống được đánh giá tốt hay xấu tùy thuộc vào chất lượng xử lý, tính phù hợp của thông tin. Mục đích, ý nghĩa. Mục đích của dự án phát triển một hệ thống thông tin là có được một sản phẩm đáp ứng được nhu cầu của người sử dụng mà nó được hòa hợp trong các hoạt động của tổ chức, chính xác về mặt kỹ thuật, tuân thủ các giới hạn về tài chính và thời gian định trước. Vì vậy, ngoài những yêu cầu trên, mục đích của dự án xây dựng phần mền quản lý hộ khẩu cấp phường phải úng dụng được tin học hóa vào việc quản lý hộ khẩu Phải trang bị được hệ thống CSDL của phần mền quản lý hộ khẩu sẽ bao gồm các vấn đề sau: Quản lý hộ khẩu: Cập nhật, thêm, sửa , xóa, tra cứu thông tin hộ khẩu Quản lý nhân khẩu: Cập nhật, thêm, sửa , xóa, tra cứu thông tin nhân khẩu Quản lý thông tin liên quan: Thêm, cập nhật Lập báo cáo Đây là một đề tài mang tính thực tế vì vậy mà trong quá trình thực hiện em luôn tìm hiểu, phân tích phương hướng về mọi mặt của đề tài. Để đáp ứng nhu cầu tin học hóa trong công tác hành chính, vấn đề quản lý hộ khẩu là một vấn đề quan trọng , đề tài “Quản lý hộ khẩu cấp phường” nhằm trợ giúp các công tác quản lý hộ khẩu trong bất kỳ một phường nào nhằm đạt hiệu quả cao nhất. Chương 2: KHẢO SÁT HỆ THỐNG MÔ TẢ HỆ THỐNG Nhiệm vụ cơ bản Một trong những giải pháp để quản lý hộ khẩu là Bộ công an – cơ quan chức năng,ủy ban pháp luật của Quốc hội phải thông qua việc xây dựng một chính phủ điện tử, quản lý theo một hệ thống thống nhất từ trên xuống, xây dựng cơ sở dữ liệu của mọi công dân trong một hệ thống. Cơ quan công can có thể quản lý, theo dõi và cập nhật thông tin của công dân qua hệ thống này, tất cả các thông tin đó thì luôn phải được cập nhật nếu có thay đổi có thể tìm kiếm để thay đổi những thông tin cần thiết. Ở mọi nơi mọi lúc có thể có mọi thông tin về công dân đó. Nhiệm vụ cơ bản của chương trình quản lý hộ khẩu là: Quản lý toàn bộ hộ khẩu Cập nhật hay sửa đổi thông tin khi có sự thay đổi về nhân khẩu Tìm kiếm thông tin của một hộ gia đinh bất kỳ Tách khẩu, chuyển khẩu Báo cáo, thống kê thông tin vào định kỳ. Xem thông tin khi có yêu cầu cần thiết Cơ cấu tổ chức và sự phân công trách nhiệm Cơ cấu tổ chức: Gồm 3 bộ phận chính: Bộ phận kiểm tra thủ tục: có nhiệm vụ hướng dẫn, kiểm tra hồ sơ trước khi xử lý thủ tục và cấp giấy. Ngoài những nhiệm vụ đó ra còn có thêm nhiệm vụ giải quyết khiếu nại tố cáo,khởi kiện về những hành cư trú trái phép Bộ phận xử lý thủ tục và cấp giấy tờ liên quan:thực hiện xử lý các hồ sơ đã hợp pháp, cung cấp giấy thường trú, tạm trú theo mẫu của pháp luật nhà nước. Do trưởng công an quận quản lý. Bộ phận thống kê lưu trữ : có nhiêm vụ thống kê, báo cáo số lượng nhân khẩu, hộ khẩu, tình trạng tạm vắng, tạm trú của phường vào mỗi định kỳ nhất định hoặc khi có yêu cầu của lãnh đạo, cấp trên. Thực hiện tra cứu tìm kiếm thông tin cá nhân khi cần thiết. Bảo đảm an toàn dữ liệu theo đúng nguyên tắc. Quy trình xử lý Qua quá trình khảo sát, ta nhận thấy các trường hợp cần xử lý thông tin và quy trình làm việc của hệ thống như sau: Mô hình chung, khi công dân đến làm thủ tục hay khai báo thông tin với cơ quan chức năng thì phải thực hiện theo đúng thứ tự qua từng bộ phận sau: Nếu có giấy tờ hay thủ tục có gì thiếu sót hay không chính xác thì bộ phận này phải có trách nhiệm chỉ rõ và hướng dẫn công dân theo đúng quy định. Nếu giấy tờ đã đúng và hợp pháp thì bộ phận này sẽ chuyển hồ sơ đến bộ phân Xử lý thủ tục và cấp giấy. Bộ phận này phải hoàn toàn chịu trách nhiệm trước pháp luật về sự sai sót trong quá trình kiểm tra. Bộ phận Xử lý thủ tục và cấp giấy. Sauk hi hồ sơ được chuyển từ bộ phận kiểm tra. Bộ phận này có trách nhiệm: Xác định yêu cầu cần giải quyết Hợp pháp hóa thủ tục. Xử lý yêu cầu: giải quyết, thực hiện ngay yêu cầu của công dân nếu có thể hoặc cấp giấy biên nhận và hẹn ngày cấp giấy tờ. Thu lệ phí của công dân theo đúng thông tư của bộ tài chính. Cung cấp thông tin đã xử lý cho bộ phận thông kê và báo cáo. Bộ phận Thông kê và báo cáo để lưu giữ hồ sơ vào cơ sở dữ liệu. Đến đây bộ phận thống kê có nhiệm vụ đảm bảo thông tin về hồ sơ, cập nhật, báo cáo tình hình hộ khẩu,m nhân khẩu vào cuối mỗi định kỳ quy đinh. Sau khi hoàn tất thủ tục thì hẹn công dân đến ngày cấp sổ, giấy tờ liên quan được ghi trên giấy biên nhận hẹn ngày trả(khoảng 10-15 ngày). Và khi đến ngày nhận thì công dân phải mang theo giấy hẹn ngày trả. CMTND đến gặp bộ phận Xử lý và cấp giấy tờ. Bộ phận này hoàn tất công viêuc bằng cách kiểm tra giấy hẹn và số CMTND nếu trùng khớp thì cấp sổ,giấy tờ không trùng thì không cấp Quy tắc xử lý Tất cả quá trình xử lý phải tuân thủ theo luật cư trú do Bộ Công An và pháp luật của Quốc hội ban hành. Ví dụ: Mọi công dân từ 15 tuổi trở lên vắng mặt qua đêm khỏi quận, thành phố nơi đang cư trú của mình đều phải khai báo tạm trú tạm vắng. Người có nhu cầu sinh sống, làm việc tại nơi không có hộ khẩu thường trú thì phải đăng kí tạm trú tại địa phương cư trú. Các mẫu biểu liên quan Sau đây là một số mẫu biểu liên quan khi khảo sát: Bản khai nhân khẩu Phiếu báo thay đổi hộ khẩu Cộng hoà xã hội chủ nghĩa Việt Nam Độc lập - Tự do - Hạnh phúc PHIẾU BÁO THAY ĐỔI HỘ KHẨU, NHÂN KHẨU Kính gửi.. Họ và tên người báo (*): Chỗ ở hiện nay: Điện thoại:. Quan hệ với chủ hộ (*): Họ và tên chủ hộ: Sổ hộ khẩu số:.. Chỗ ở hiện nay.... Điện thoại.. .. Nội dung thay đổi ... ..Ngàytháng ...năm. ngàytháng..năm Ý kiến của chủ hộ người viết báo cáo (Ghi rõ nội dung, ký và ghi rõ họ tên) (ký, ghi rõ họ tên) Giấy tạm vắng Tỉnh/TP.. Cộng hoà xã hội chủ nghĩa việt nam Quận/Huyện Độc lập tự do hạnh phúc Số hiệu:. GIẤY TẠM VẮNG (TRÚ) Họ tên:.Giới tính:.......................... Ngày sinh:............................CMTND: Nguyên quán:.. Thường trú tại: Lý do: Nơi đến: Thời gian: từ ngàythángnăm đến ngày..tháng..năm Trưởng công an Người viết đơn (ký tên, ghi rõ họ tên) (ký tên, ghi rõ họ tên) Giấy biên nhận hẹn ngày trả TP.. Cộng hoà xã hội chủ nghĩa Việt Nam Huyện Độc lập - Tự do - Hạnh phúc Số hiệu:....... GIẤY BIÊN NHẬN Họ tên người làm đơn: Ngày sinh:.Giới tính: Số CMTND: Nguyên quán: Chỗ ở hiện nay: Công việc thực hiện: Ngày trả: Trưởng công an Công dân làm thủ tục (ký tên, ghi rõ họ tên) (ký tên, ghi rõ họ tên) Hóa đơn thanh toán Tỉnh/TP.. Cộng hoà xã hội chủ nghĩa Việt Nam Quận/ huyện Độc lập - Tự do - Hạnh phúc Số hiệu:. BIÊN LAI THANH TOÁN Họ và tên:.. Giới tính................. Số CMTND: . Nguyên quán: Chỗ ở hiện nay:. Công việc thực hiện: Thành tiền:bằng chữ: Người thu Người nộp (ký, ghi rõ họ tên) (ký, ghi rõ họ tên) Hộ khẩu Giấy khai sinh: Giấy khai tử: Giấy chứng nhận kết hôn MÔ HÌNH TIẾN TRÌNH NGHIỆP VỤ Kí hiệu: Ta có thể hình dung quy trình làm viêu của bốn tôt chức trên mô hình nghiệp vụ như sau: Chương 3: PHÂN TÍCH HỆ THỐNG VỀ DỮ LIỆU SƠ ĐỒ PHÂN RÃ CHỨC NĂNG Các bước xây dựng Có thể sử dụng 2 phương pháp để xác định các chức năng nghiệp vụ: Bottom up: phân rã các chức năng lớn thành các chức năng nhỏ hơn chi chi tiết hơn. Top down: xuất phát từ những chức năng chi tiết gom nhóm lại thành các chức năng ở mức cao hơn. Các bước tiến hành xây dựng sơ đồ phân rã chức năng: Sử dụng phương pháp Bottom up, gồm 5 bước: Bước 1: Trong bảng khảo sát chi tiết hệ thống hiện tại, trong phần quy trình xử lý gạch chân tất cả các động từ + bổ ngữ liên quan đến công việc của hệ thống. Bước2: Trong danh sách các chức năng được chọn ở bước 1, tìm và loại bỏ những chức năng trùng lặp. Bước3: Trong danh sách các chức được chọn ở bước 2, gom nhóm những chức năng đơn giản do 1 người thực hiện lại. Bước4: Trong danh sách các chức năng được chọn ở bước 3, loại bỏ những chức năng không có ý nghĩa đối với hệ thống. Bước5: Chỉnh sửa lại tên các chức năng ở bước 4 cho hợp lý. Sử dụng phương pháp Top down:ở mức cáo nhất của nghiệp vụ, một chức năng chính sẽ làm được 1 trong 3 điều: Cung cấp sản phẩm Cung cấp dịch vụ Quản lý tài nguyên Kí hiệu sử dụng Biểu diễn: Hình chữ nhật: Mỗi chức năng được phân rã thành các chức năng con. Các chức năng con có quan hệ phân cấp với chức năng cha và được thể hiện như sau: Tên chức năng Áp dụng bài toán Sử dụng phương pháp Bottom up để xây dựng sơ đồ phân rã chức năng cho hệ thống. Thực hiện theo các bước sau: Bước1: Xác định được các chức năng chi tiết trong hệ thống là: Tiếp nhận hồ sơ, thủ tục. Kiểm tra chi tiết thủ tục, hồ sơ. Giải quyết khiếu nại, tố cáo và khởi kiện. Cung cấp thông tin khi có yêu cầu. Cung cấp mẫu hướng dẫn làm thủ tục. Cấp giấy tờ tạm trú, tạm vắng. Lập giấy biên nhận hẹn ngày trả. Cấp sổ hộ khẩu. Cấp giấy khai sinh Cấp giấy khai tử Cấp giấy chứng nhân kết hôn Cấp giấy bản sao của khai sinh Cấp giấy bản sao của khai tử Cấp giấy chuyển hộ khẩu. Lập hóa đơn thanh toán Thống kê số lượng nhân khẩu Thống kê hộ khẩu Thống kê số lượng người tạm trú, tạm vắng. Thống kê tổng hợp số dân theo độ tuổi Bước2: Gom nhóm chức năng chi tiết thành chức năng lớn hơn của hệ thống 1. Tiếp nhận hồ sơ, thủ tục. 2. Kiểm tra chi tiết thủ tục, hồ sơ 3. Giải quyết các khiếu nại, tố cáo và khởi kiện 4. Cung cấp thông tin khi có yêu cầu 5. Cung cấp mẫu hướng dẫn làm thủ tục Bộ phận kiểm tra và giải quyết khiếu nại tố cáo Hệ thống quản lý hộ khẩu 6. Cấp giấy tờ tạm vắng, tạm trú 7. Lập giấy biên nhận hẹn ngày trả. 8. Cấp sổ hộ khẩu 9. Cấp giấy chuyển hộ khẩu 10. Lập hoá đơn thanh toán 11.Cấp giấy khai sinh 12. Cấp giấy khai tử 13. Cấp bản sao giấy khai sinh 14. Bản sao giấy khai tử 15. Cấp giấy chứng nhận kết hôn Bộ phận xử lý và cấp sổ, giấy tờ liên quan 16 Thống kê số lượng nhân khẩu 17 Thống kê hộ khẩu 18 Thống kê số lượng người tạm trú, tạm vắng 19 Thống kê tổng hợp số dân theo độ tuổi Bộ phận lưu trữ, thống kê Biểu đồ phân cấp chức năng SƠ ĐỒ LUỒNG DỮ LIỆU Các bước xây dựng Ta xác định các luồng thông tin nghiệp vụ bằng phương pháp phân tích Top down dựa trên mô hình tiến trình nghiệp vụ của hệ thống. Quá trình phân tích chia thành 3 bước. Xây dựng biểu đồ luồng dữ liệu (DFD) mức ngữ cảnh để ta xác định giới hạn của hệ thống. Nó có chức năng biểu thị toàn bộ hệ thống ta đang nghiên cứu, chức năng này được nối với mọi tác nhân ngoài của hệ thống. Các luồng dữ liệu giữa các chức năng và tác nhân ngoài chỉ thông tin vào ra của hệ thống. Xây dựng biểu đồ luồng dữ liệu mức đỉnh, với mức đỉnh các tác nhân ngoài của hệ thống ở mức khung cảnh được giữ nguyên với các luồng thông tin vào ra. Trong hệ thống được phân ra thành các tiến trình với mức đỉnh là các chức năng chính bên trong hệ thống theo biểu đồ phân cấp chức năng ở mức 1. Xây dựng biểu đồ luồng dữ liệu mức dưới đỉnh, ta thực hiện phân rã đối với mỗi tiến trình của mức đỉnh dựa trên biểu đồ phân cấp chức năng. Ký hiệu sử dụng Sau đây là một số kí hiệu quy định trong sơ đồ: Biểu diễn: Hình chữ nhật: Tên tác nhân ngoài Tên chức năng Hình tròn, hình elip: tên chức năng Hướng luồng dữ liệu: Kho thông tin, dữ liệu: Dựa vào các bước xây dựng và các kí hiệu biểu diễn ta đi xây dựng sơ đồ luồng dữ liệu của hệ thống quản lý hộ khẩu cấp phường như sau: Bước 1: Xây dựng biểu đồ luồng dữ liệu mức ngữ cảnh (mức 0) của hệ thống quản lý hộ khẩu cấp phường: Bước 2: Xây dựng biểu đồ luồng dữ liệu mức đỉnh của hệ thống quản lý hộ khẩu: Bước 3: Xây dựng sơ đồ luồng dữ liệu mức dưới đỉnh của hệ thống quản lý hộ khẩu: a. Sơ đồ luồng dữ liệu mức 1.0: Kiểm tra giải quyết khiếu nại b. Sơ đồ luồng dữ liệu mức 2.0: Xử lý cấp giấy tờ liên quan c. Sơ đồ luồng dữ liệu mức 3.0: Lưu trữ thống kê Mô hình quan hệ Từ các hồ sơ liên quan trên ta xác định được các thực thể sau: Nhân khẩu Hộ khẩu Tạm trú/tạm vắng Giấy khai sinh Giấy khai tử Giấy kết hôn Bản sao giấy khai sinh Bản sao giấy khai tử Giấy hẹn Hóa đơn thanh toán Công việc Các thuộc tính của kiểu thực thể đã nêu trên là: Nhân khẩu( mã nhân khẩu, họ và tên, bí danh, tên gọi khác, giới tính,CMTND,sinh ngày, nơi sinh, nguyên quán, dân tộc, nơi đăng ký thường trú, nơi ở hiện nay, trình độ học vấn, trình độ ngoại ngữ, quan hệ với chủ hộ,khen thưởng, kỷ luật) Hộ khẩu( quyển số, tên chủ hộ, số thành viên, địa chỉ) Công việc( mã công việc, tên công việc) Khai tử(quyển số,số hiệu, họ tên người chứng tử,giới tính,ngày sinh,quê quán,nơi thường trú,dân tộc,quốc tịnh,CMND,ngày cấp, nơi cấp, ngày giờ chết, nơi chết, nguyên nhân chết, người khai, mối quan hệ, cán hộ hộ tịch, trạng thái,người cấp, chức vụ, nơi cấp, ghi chú) Kết hôn(quyển số, số hiệu, họ tên chồng,ngày sinh của chồng, dân tộc,quê quán,nơi thường trú,CMND,ngày cấp, nơi cấp, lần kết hôn,họ tên vợ, ngày sinh của vợ, dân tộc, quê quán, nơi thường trú, CMND,ngày cấp, lần kết hôn,cán bộ hộ tịch, người cấp, chức vụ, ngày cấp,nơi cấp giấy kết hôn, ghi chú, ngày xác nhân, nơi xác nhận) Khai sinh(quyển số, số hiệu, họ tên người được khai sinh, giới tính, ngày sinh, nơi sinh,dân tộc, quốc tịch,quê quán,họ tên bố,dân tộc,quốc tịch,ngày sinh,quê quán, nơi thường trú,họ tên mẹ, dân tộc, quốc tịch, ngày sinh, quê quán, nơi thường trú, tình trạng của cha và mẹ,người khai sinh, mối quan hệ, cán bộ hộ tịch, người cấp, chức vụ, ngày cấp,nơi cấp, trạng thái, ghi chú) Tạm trú/tạm vắng (số phiếu, họ và tên, ngày sinh, giới tính, CMD, nguyên quán, thường trú tại, lý do, nơi đến,thời gian) Bản sao giấy khai sinh (quyển sô, số hiệu,người đăng ký, CMND,địa chỉ, họ tên ngươi được khai sinh, sinh ngày, nơi sinh,họ tên cha, họ tên mẹ, nơi đăng ký giấy khai sinh, năm đăng ký giấy khai sinh, nơi đăng ký cấp bản sao, số bản sao yêu cầu) Bản sao giấy khai tử ( quyển số, số hiệu,họ tên người đăng ký, mối quan hệ, CMND,địa chỉ,họ tên người mất, ngày/tháng/năm mất, địa chỉ đăng ký chứng tử, cấp tại, số bản yêu cầu) Giấy hẹn(mã giấy hẹn, họ và tên, ngày sinh, CMND, nguyên quán, chỗ ở hiện nay, công việc, ngày trả) Hóa đơn (mã HD, họ tên, CMND, nguyên quán, chỗ ở hiện nay, công việc, thành tiền) è Chuẩn hóa các thực thể trên Nhân khẩu ( mã nhân khẩu, quyển số, họ và tên, ngày sinh, bí danh, giới tính, CMND, dân tộc, quê quán, học vấn, mối quan hệ, mã giấy thưởng, mã kỉ luật, nơi ở hiện nay) Hộ khẩu (quyển số, tên chủ hộ, số thành viên) Công việc(mã công việc, tên công việc) Khen thưởng( mã giấy khen,ngày khen thưởng,cơ quan khen thưởng, hình thức khen thưởng) Kỷ luật(mã kỉ luật,ngày kỷ luật, hình thức xử phạt, mức độ, thời gian, cơ quan xử lý) Tạm trú/tạm vắng( mã nhân khẩu,mã tạm trú tạm vắng,lý do, nơi đến, thời gian, ghi chú) Khai tử(quyển số,số hiệu, họ tên người chứng tử,giới tính,ngày sinh,quê quán,nơi thường trú,dân tộc,quốc tịnh,CMND,ngày cấp, nơi cấp, ngày giờ chết, nơi chết, nguyên nhân chết, người khai, mối quan hệ, cán hộ hộ tịch, trạng thái,người cấp, chức vụ, nơi cấp, ghi chú) Kết hôn(quyển số, số hiệu, họ tên chồng,ngày sinh của chồng, dân tộc,quê quán,nơi thường trú,CMND,ngày cấp, nơi cấp, lần kết hôn,họ tên vợ, ngày sinh của vợ, dân tộc, quê quán, nơi thường trú, CMND,ngày cấp, lần kết hôn,cán bộ hộ tịch, người cấp, chức vụ, ngày cấp,nơi cấp giấy kết hôn, ghi chú) Khai sinh(quyển số, số hiệu, họ tên người được khai sinh, giới tính, ngày sinh, nơi sinh,dân tộc, quốc tịch,quê quán,họ tên bố,dân tộc,quốc tịch,ngày sinh,quê quán, nơi thường trú,họ tên mẹ, dân tộc, quốc tịch, ngày sinh, quê quán, nơi thường trú, tình trạng của cha và mẹ,người khai sinh, mối quan hệ, cán bộ hộ tịch, người cấp, chức vụ, ngày cấp,nơi cấp, trạng thái, ghi chú) Bản sao giấy khai sinh(quyển sô, số hiệu,người đăng ký, CMND,địa chỉ, họ tên ngươi được khai sinh, sinh ngày, nơi sinh,họ tên cha, họ tên mẹ, nơi đăng ký giấy khai sinh, năm đăng ký giấy khai sinh, nơi đăng ký cấp bản sao, số bản sao yêu cầu) Bản sao giấy khai tử ( quyển số, số hiệu,họ tên người đăng ký, mối quan hệ, CMND,địa chỉ,họ tên người mất, ngày/tháng/năm mất, địa chỉ đăng ký chứng tử, cấp tại, số bản yêu cầu) Giấy hẹn( mã giấy hẹn,mã nhân khẩu,mã công việc,ngày trả) Hóa đơn( mã hóa đơn,mã giấy hẹn,thành tiền) Chương 4 :PHÂN TÍCH THIÊT KẾ HỆ THỐNG I. THIẾT KẾ CƠ SỞ DỮ LIỆU 1. Cơ sở dữ liệu: Bảng “NHÂN KHẨU”: tblnhankhau Tên trường Kiểu Cỡ Ràng buộc Ghi chú Manhankhau Int 4 Khóa chính NOT NULL Mã nhân khẩu Quyenso Varchar 50 NOT NULL Quyển số Hoten Nvarchar 50 NULL Họ và tên Ngaysinh Date/time 8 NULL Ngày sinh Bidanh Nvarchar 50 NULL Bí danh Gioitinh Nvarchar 50 NULL Giới tính CMND Nvarchar 50 NULL Chứng minh thư nhân dân Dantoc Nvarchar 50 NULL Dân tộc Quequan Nvarchar 50 NULL Quê quán Hocvan Nvarchar 50 NULL Học vấn Moiquanhe Nvarchar 50 NULL Mối quan hệ Magiaykhen Char 10 NOT NULL Mã giấy khen Makiluat Char 10 NOT NULL Mã kỉ luật Noiohiennay Nvarchar 50 NULL Nơi ở hiện nay Ghichu Nvarchar 50 NULL Ghi chú 2. Cơ sở dữ liệu: Bảng “HỘ KHẨU”: tblhokhau Tên trường Kiểu Cỡ Ràng buộc Ghi chú Quyenso Varchar 50 Khóa chính NOT NULL Quyển số Tenchuho Nvarchar 50 NOT NULL Tên chủ hộ Sothanhvien Int 4 NULL Số thành viên Ngaylap Date/time 8 NULL Ngày lập Ghichu Nvarchar 50 NULL Ghi chú 3. Cơ sở dữ liệu: Bảng “KHAI SINH”: tblkhaisinh Tên trường Kiểu Cỡ Ràng buộc Ghi chú Quyenso Varchar 50 Khóa chính NOT NULL Quyển số Sohieu Varchar 50 NOT NULL Số hiệu Hotennguoidcksinh Nvarchar 50 NULL Họ tên người được khai sinh Gioitinh Nvarchar 50 NULL Giới tính Ngaysinh Date/Time 8 NULL Ngày sinh Noisinh Nvarchar 50 NULL Nơi sinh Dantoc Nvarchar 50 NULL Dân tộc Quoctich Nvarchar 50 NULL Quốc tịch Quequan Nvarchar 50 NULL Quê quán Hotencha Nvarchar 50 NULL Họ tên bố Dantoccha Nvarchar 50 NULL Dân tộc bố Quoctichcha Nvarchar 50 NULL Quốc tịch bố Ngaysinhcha Date/time 8 NULL Ngày sinh bố Quequancha Nvarchar 50 NULL Quê quán bố Noithuongtrucha Nvarchar 50 NULL Nơi thường trú bố Hotenme Nvarchar 50 NULL Họ và tên mẹ Dantocme Nvarchar 50 NULL Dân tộc mẹ Quoctichme Nvarchar 50 NULL Quốc tịch mẹ Ngaysinhme Date/time 8 NULL Ngày sinh mẹ Quequanme Nvarchar 50 NULL Quê quán mẹ Noithuongtrume Nvarchar 50 NULL Nơi thường trú mẹ Tinhtranghonnhan Nvarchar 50 NULL Tình trạng hôn nhân Nguoikhai Nvarchar 50 NULL Người khai Moiquanhe Nvarchar 50 NULL Mối quan hệ Canbohotich Nvarchar 50 NULL Cán bộ hộ tịch Nguoicap Nvarchar 50 NULL Người cấp Chucvu Nvarchar 50 NULL Chức vụ Ngaycap Date/tme 8 NULL Ngày cấp Noicap Nvarchar 50 NULL Nơi cấp Trangthai Nvarchar 50 NULL Trạng thái Ghichu Nvarchar 50 NULL Ghi chú 4.2 Mô hình thực thể và quan hệ Các modul xử lý Sơ đồ khối quá trình đăng nhập Không hợp lệ Bắt đầu Nhâp Username và Password Kiểm tra tính hợp lệ Hạn chế quyền hạn Kết thúc Hợp lệ b. Sơ đồ khối quá trình nhập mới một hồ sơ. Bắt đầu Nhập thông tin về cán bộ Kiểm tra tính hợp lệ của thông tin Cập nhật Cơ sở dữ liệu Kết thúc Cập nhật Đúng Có Không Sai c.Sơ đồ khối chức năng thống kê báo cáo. Bắt đầu Nhập thông tin cần báo cáo, thống kê Thống kê,báo cáo In ấn ? Đưa thông tin ra màn hình Đưa thông tin ra máy in Kết thúc Không Có II. GIAO DIỆN CHƯƠNG TRÌNH Giao diện LoGin b.Giao diện đăng nhập c. Giao diên manu chính d. Giao diện cập nhật nhân khẩu e. Giao diện nhân khẩu f.Giao diện Khen thưởng – kỷ luật g. Giao diện khai sinh III. MỘT SỐ ĐOẠN MÃ LỆNH CHÍNH CỦA CHƯƠNG TRÌNH Phần modul Imports System.Data.SqlClient Module Module1 Public str As String Public bien As String Public user, pass, group, test, SQLstr As String Public Sub truyvan(ByVal SQL As String) Dim cnn As New SqlConnection(str) Try cnn.Open() Dim comm As New SqlCommand(SQL, cnn) comm.ExecuteNonQuery() Catch ex As Exception MsgBox(ex.Message.ToString) Finally If cnn.State = ConnectionState.Closed Then cnn.Open() cnn.Close() cnn.Dispose() End If End Try End Sub End Module *Code của Form Kết Nối Private Sub btnKetNoi_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles btnKetNoi.Click Dim myconnection As SqlConnection str = "server=" & TextBox1.Text & ";database=" & TextBox2.Text If RadioButton1.Checked And TextBox1.Text "" And TextBox2.Text "" Then str += ";integrated security=true" ElseIf (RadioButton2.Checked) And TextBox1.Text "" Or TextBox2.Text "" Or TextBox3.Text "" Or TextBox4.Text "" Then str += ";uid=" & TextBox3.Text & ";password=" & TextBox4.Text() Else MsgBox("Lỗi kết nối") End If myconnection = New SqlConnection(str) Try If myconnection.State = ConnectionState.Closed Then myconnection.Open() 'MsgBox("Kết nối thành công") dangnhap.Show() Me.Hide() Else MsgBox("thong so sai" & TextBox1.Text & vbCrLf & TextBox2.Text & vbCrLf & TextBox3.Text & vbCrLf & TextBox4.Text) End If Catch ex As Exception MsgBox(ex.ToString) End Try End Sub *Code của Form nhân khẩu Imports System.Data.SqlClient Public Class nhankhau Dim b, c As String Private Sub nhankhau_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load Dim conn As New SqlConnection(str) conn.Open() Dim adap As New SqlDataAdapter("select * from nhankhau", conn) Dim tbl As New DataTable adap.Fill(tbl) DataGridView1.DataSource = tbl Dim da As New SqlDataAdapter("select distinct quyenso from hokhau", conn) Dim tbl1 As New DataTable da.Fill(tbl1) ComboBox1.DataSource = tbl1 ComboBox1.DisplayMember = tbl1.Columns(0).ToString ComboBox1.ValueMember = tbl1.Columns(0).ToString Dim dap As New SqlDataAdapter("select distinct magiaykhen from khenthuong", conn) Dim tbl2 As New DataTable dap.Fill(tbl2) com1.DataSource = tbl2 com1.DisplayMember = tbl2.Columns(0).ToString com1.ValueMember = tbl2.Columns(0).ToString Dim dap1 As New SqlDataAdapter("select distinct makiluat from kyluat", conn) Dim tbl3 As New DataTable dap1.Fill(tbl3) com2.DataSource = tbl3 com2.DisplayMember = tbl3.Columns(0).ToString com2.ValueMember = tbl3.Columns(0).ToString End Sub Private Sub Button1_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button1.Click Dim a As String If RadioButton1.Checked Then a = "Nam" Else a = "Nữ" End If Dim conn As New SqlConnection(str) conn.Open() truyvan("insert into nhankhau values('" + ComboBox1.Text + "',N'" + txtten.Text + "',N'" + txtnsinh.Text + "',N'" + txtbidanh.Text + "',N'" + a + "','" + txtCMND.Text + "',N'" + txtdtoc.Text + "',N'" + txtque.Text + "',N'" + txthocvan.Text + "',N'" + txtquanhe.Text + "','" + com1.Text + "','" + com2.Text + "',N'" + txtnoio.Text + "',N'" + txtghichu.Text + "')") nhankhau_Load(sender, e) If txtquanhe.Text "Không có quan hệ" Then truyvan("update hokhau set sothanhvien=sothanhvien +1 where quyenso='" + ComboBox1.Text + "'and tenchuho N'" + txtten.Text + "'") 'pai khac ten chu ho vi moi lần nhập nếu trùng tên thì hệ thống cũng tự động tăng nhankhau_Load(sender, e) End If txtma.Text = "" ComboBox1.Text = "" txtten.Text = "" txtnsinh.Text = "" txtbidanh.Text = "" txtCMND.Text = "" txtdtoc.Text = "" txtque.Text = "" txthocvan.Text = "" txtquanhe.Text = "" com1.Text = "" com2.Text = "" txtnoio.Text = "" TextBox1.Text = "" txtghichu.Text = "" End Sub Private Sub Button2_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button2.Click Dim a As String If RadioButton1.Checked Then a = "Nam" Else a = "Nữ" End If Dim str1 As String = " " Dim conn As New SqlConnection(str) truyvan("update nhankhau set quyenso='" + ComboBox1.Text + "',hoten=N'" + txtten.Text + "',ngaysinh='" + txtnsinh.Text + "',bidanh=N'" + txtbidanh.Text + "',gioitinh=N'" + a + "',CMND='" + txtCMND.Text + "',dantoc=N'" + txtdtoc.Text + "',quequan=N'" + txtque.Text + "',hocvan=N'" + txthocvan.Text + "',moiquanhe=N'" + txtquanhe.Text + "',magiaykhen='" + com1.Text + "',makiluat='" + com2.Text + "',noiohiennay=N'" + txtnoio.Text + "',Ghichu=N'" + txtghichu.Text + "' where manhankhau= '" + txtma.Text + "'") nhankhau_Load(sender, e) txtma.Text = "" ComboBox1.Text = "" txtten.Text = "" txtnsinh.Text = "" txtbidanh.Text = "" txtCMND.Text = "" txtdtoc.Text = "" txtque.Text = "" txthocvan.Text = "" txtquanhe.Text = "" com1.Text = "" com2.Text = "" txtnoio.Text = "" TextBox1.Text = "" txtghichu.Text = "" End Sub Private Sub Button3_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button3.Click If MsgBox("Bạn có chắc muốn xóa bản ghi này không?", MsgBoxStyle.YesNo, "Xóa bản ghi") = MsgBoxResult.Yes Then truyvan("delete nhankhau where manhankhau='" + txtma.Text + "'and moiquanhe'chủ hộ'") truyvan("update hokhau set sothanhvien=sothanhvien -1 where quyenso='" + ComboBox1.Text + "'and tenchuho N'" + txtten.Text + "'") nhankhau_Load(sender, e) txtma.Text = "" ComboBox1.Text = "" txtten.Text = "" txtnsinh.Text = "" txtbidanh.Text = "" txtCMND.Text = "" txtdtoc.Text = "" txtque.Text = "" txthocvan.Text = "" txtquanhe.Text = "" com1.Text = "" com2.Text = "" txtnoio.Text = "" TextBox1.Text = "" End If truyvan("delete nhankhau where manhankhau='" + txtma.Text + "'") truyvan("update hokhau set sothanhvien=sothanhvien -1 where quyenso='" + ComboBox1.Text + "'and tenchuho N'" + txtten.Text + "'") nhankhau_Load(sender, e) txtma.Text = "" ComboBox1.Text = "" txtten.Text = "" txtnsinh.Text = "" txtbidanh.Text = "" txtCMND.Text = "" txtdtoc.Text = "" txtque.Text = "" txthocvan.Text = "" txtquanhe.Text = "" com1.Text = "" com2.Text = "" txtnoio.Text = "" TextBox1.Text = "" End Sub Private Sub DataGridView1_CellClick(ByVal sender As Object, ByVal e As System.Windows.Forms.DataGridViewCellEventArgs) Handles DataGridView1.CellClick txtma.Text = DataGridView1.Rows(e.RowIndex).Cells(0).Value.ToString ComboBox1.Text = DataGridView1.Rows(e.RowIndex).Cells(1).Value.ToString txtten.Text = DataGridView1.Rows(e.RowIndex).Cells(2).Value.ToString txtnsinh.Text = DataGridView1.Rows(e.RowIndex).Cells(3).Value.ToString txtbidanh.Text = DataGridView1.Rows(e.RowIndex).Cells(4).Value.ToString If DataGridView1.Rows(e.RowIndex).Cells(5).Value.ToString = "Nam" Then RadioButton1.Select() Else RadioButton2.Select() End If txtCMND.Text = DataGridView1.Rows(e.RowIndex).Cells(6).Value.ToString txtdtoc.Text = DataGridView1.Rows(e.RowIndex).Cells(7).Value.ToString txtque.Text = DataGridView1.Rows(e.RowIndex).Cells(8).Value.ToString txthocvan.Text = DataGridView1.Rows(e.RowIndex).Cells(9).Value.ToString txtquanhe.Text = DataGridView1.Rows(e.RowIndex).Cells(10).Value.ToString com1.Text = DataGridView1.Rows(e.RowIndex).Cells(11).Value.ToString com2.Text = DataGridView1.Rows(e.RowIndex).Cells(12).Value.ToString txtnoio.Text = DataGridView1.Rows(e.RowIndex).Cells(13).Value.ToString End Sub Private Sub txtten_MouseLeave(ByVal sender As Object, ByVal e As System.EventArgs) Handles txtten.MouseLeave txtquanhe.Text = b Dim conn As New SqlConnection(str) conn.Open() Dim sqlcom As String = "select * from hokhau where quyenso='" + ComboBox1.Text + "'" Dim comm As SqlCommand = New SqlCommand(sqlcom, conn) Dim dr As SqlDataReader = comm.ExecuteReader If dr.HasRows Then While dr.Read test = dr("tenchuho") If dr("tenchuho") = txtten.Text Then b = "Chủ hộ" End If dr.Close() Exit Sub End While End If End Sub Private Sub ComboBox1_SelectedValueChanged(ByVal sender As Object, ByVal e As System.EventArgs) Handles ComboBox1.SelectedValueChanged Dim myconn As New SqlConnection(str) myconn.Open() Dim mysql As String = "select tenchuho from hokhau where quyenso='" + ComboBox1.Text + "'" Dim mycomm As SqlCommand = New SqlCommand(mysql, myconn) Dim mydr As SqlDataReader = mycomm.ExecuteReader While mydr.Read() TextBox1.Text = mydr("tenchuho") End While myconn.Close() End Sub End Class *Code của Form Khai sinh Imports System.Data.SqlClient Public Class Khaisinh Dim gt, ttHonNhan, TrangThai As String Private Sub Button1_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button1.Click Dim gt, ttHonNhan, TrangThai As String If RDnam.Checked Then gt = "Nam" Else gt = "Nữ" End If If RDkethon.Checked Then ttHonNhan = "Có kết hôn" Else If RDko.Checked Then ttHonNhan = "Không kết hôn" Else If RDboroi.Checked Then ttHonNhan = "Con bỏ rơi" Else ttHonNhan = "Không xác định" End If End If End If If RD1.Checked Then TrangThai = "Đúng hạn" Else If RD2.Checked Then TrangThai = "Trễ hạn" Else TrangThai = "Không xác định" End If End If Dim conn As New SqlConnection(str) conn.Open() truyvan("insert into khaisinh values('" + cmbquyen.Text + "','" + txtsohieu.Text + "',N'" + txtten.Text + "',N'" + gt + "','" + CDate(DTPsinh.Text) + "',N'" + txtnoisinh.Text + "',N'" + cmbdtoc.Text + "',N'" + cmbquoctich.Text + "',N'" + txtque.Text + "',N'" + txtcha.Text + "',N'" + cmbcha.Text + "',N'" + cbmqch.Text + "','" + CDate(DTPcha.Text) + "',N'" + txtqcha.Text + "',N'" + txtttrucha.Text + "',N'" + txtme.Text + "',N'" + cbmme.Text + "',N'" + cbmqme.Text + "','" + CDate(DTPme.Text) + "',N'" + txtqme.Text + "',N'" + txtttrume.Text + "',N'" + ttHonNhan + "',N'" + txtnkhaisinh.Text + "',N'" + txtmqh.Text + "',N'" + txthotich.Text + "',N'" + txtngcap.Text + "',N'" + txtchucvu.Text + "','" + CDate(DTPngaycap.Text) + "',N'" + txtnoicap.Text + "',N'" + TrangThai + "',N'" + txtghichu.Text + "')") truyvan("update hokhau set sothanhvien=sothanhvien +1 where quyenso='" + cmbquyen.Text + "'") truyvan("insert into nhankhau values('" + cmbquyen.Text + "',N'" + txtten.Text + "',N'" + CDate(DTPsinh.Text) + "',N'',N'" + gt + "','',N'" + cmbdtoc.Text + "',N'" + txtque.Text + "',N'','Con','GK1','KL1',N'" + txtttrucha.Text + "',N'')") End Sub Private Sub Khaisinh_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load Dim conn As New SqlConnection(str) conn.Open() Dim adapter As New SqlDataAdapter("select quyenso from hokhau", conn) Dim tbl As New DataTable adapter.Fill(tbl) cmbquyen.DataSource = tbl cmbquyen.DisplayMember = tbl.Columns(0).ToString cmbquyen.ValueMember = tbl.Columns(0).ToString End Sub Private Sub Button2_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button2.Click ctkhaisinh.Show() End Sub Private Sub Button3_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button3.Click If RDnam.Checked Then gt = "Nam" Else gt = "Nữ" End If If RDkethon.Checked Then ttHonNhan = "Có kết hôn" ElseIf RDko.Checked Then ttHonNhan = "Không kết hôn" ElseIf RDboroi.Checked Then ttHonNhan = "Con bỏ rơi" Else ttHonNhan = "Không xác định" End If If RD1.Checked Then TrangThai = "Đúng hạn" ElseIf RD2.Checked Then TrangThai = "Trễ hạn" Else TrangThai = "Không xác định" End If truyvan("update khaisinh set hotennguoidcksinh=N'" + txtten.Text + "',gioitinh=N'" + gt + "',ngaysinh='" + DTPsinh.Text + "',noisinh=N'" + txtnoisinh.Text + "',dantoc=N'" + cmbdtoc.Text + "',quoctich=N'" + cmbquoctich.Text + "',quequan=N'" + txtque.Text + "',hotencha=N'" + txtcha.Text + "',dantoccha=N'" + cmbcha.Text + "',quoctichcha=N'" + cbmqch.Text + "',ngaysinhcha='" + DTPcha.Text + "',quequancha=N'" + txtqcha.Text + "',noithuongtrucha=N'" + txtttrucha.Text + "',hotenme=N'" + txtme.Text + "',dantocme=N'" + cbmme.Text + "',quoctichme=N'" + cbmqme.Text + "',ngaysinhme='" + DTPme.Text + "',quequanme=N'" + txtqme.Text + "',noithuongtrume=N'" + txtttrume.Text + "',tinhtranghonnhan=N'" + ttHonNhan + "',nguoikhai=N'" + txtnkhaisinh.Text + "',moiquanhe=N'" + txtmqh.Text + "',canbohotich=N'" + txthotich.Text + "',nguoicap=N'" + txtngcap.Text + "',chucvu=N'" + txtchucvu.Text + "',ngaycap='" + DTPngaycap.Text + "',noicap=N'" + txtnoicap.Text + "',trangthai=N'" + TrangThai + "',ghichu=N'" + txtghichu.Text + "' where sohieu='" + txtsohieu.Text + "' and quyenso='" + cmbquyen.Text + "'") Khaisinh_Load(sender, e) End Sub Private Sub Button5_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button5.Click truyvan("delete khaisinh where sohieu='" + txtsohieu.Text + "'and quyenso='" + cmbquyen.Text + "'") truyvan("update hokhau set sothanhvien=sothanhvien-1 where quyenso='" + cmbquyen.Text + "'") Khaisinh_Load(sender, e) txtcha.Text = "" txtchucvu.Text = "" txtghichu.Text = "" txthotich.Text = "" txtme.Text = "" txtmqh.Text = "" txtngcap.Text = "" txtnkhaisinh.Text = "" txtnoicap.Text = "" txtnoisinh.Text = "" txtqcha.Text = "" txtqme.Text = "" txtque.Text = "" txtsohieu.Text = "" txtten.Text = "" txtttrucha.Text = "" txtttrume.Text = "" cmbcha.Text = "" cmbdtoc.Text = "" cmbquoctich.Text = "" cmbquyen.Text = "" cbmme.Text = "" cbmqch.Text = "" cbmqme.Text = "" RD1.Checked = False RD2.Checked = False rd3.Checked = False RDboroi.Checked = False RDkethon.Checked = False RDko.Checked = False RDkxacdinh.Checked = False RDnam.Checked = False RDnu.Checked = False DTPcha.Value = Today End Sub Private Sub txtqme_KeyPress(ByVal sender As Object, ByVal e As System.Windows.Forms.KeyPressEventArgs) Handles txtqme.KeyPress If txtqme.Text = "nt" Then txtqme.Text = txtque.Text End If End Sub Private Sub txtttrume_KeyPress(ByVal sender As Object, ByVal e As System.Windows.Forms.KeyPressEventArgs) Handles txtttrume.KeyPress If txtttrume.Text = "nt" Then txtttrume.Text = txtttrucha.Text End If End Sub Private Sub Button7_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button7.Click Dim myconn As New SqlConnection(str) myconn.Open() Dim mysql As String = "select * from khaisinh where sohieu='" + txtsohieu.Text + "' and quyenso='" + cmbquyen.Text + "'" Dim mycomm As SqlCommand = New SqlCommand(mysql, myconn) Dim mydr As SqlDataReader = mycomm.ExecuteReader While mydr.Read() txtten.Text = mydr("hotennguoidcksinh") If mydr("gioitinh") = "Nam" Then RDnam.Checked = True Else RDnu.Checked = True End If DTPsinh.Text = mydr("ngaysinh") txtnoisinh.Text = mydr("noisinh") cmbdtoc.Text = mydr("dantoc") cmbquoctich.Text = mydr("quoctich") txtque.Text = mydr("quequan") txtcha.Text = mydr("hotencha") cmbcha.Text = mydr("dantoccha") cbmqch.Text = mydr("quoctichcha") DTPcha.Text = mydr("ngaysinhcha") txtqcha.Text = mydr("quequancha") txtttrucha.Text = mydr("noithuongtrucha") txtme.Text = mydr("hotenme") cbmme.Text = mydr("dantocme") cbmqme.Text = mydr("quoctichme") DTPme.Text = mydr("ngaysinhme") txtqme.Text = mydr("quequanme") txtttrume.Text = mydr("noithuongtrume") If mydr("tinhtranghonnhan") = "Có kết hôn" Then RDkethon.Checked = True ElseIf mydr("tinhtranghonnhan") = "Không kết hôn" Then RDko.Checked = True ElseIf mydr("tinhtranghonnhan") = "Bỏ rơi" Then RDboroi.Checked = True Else RDkxacdinh.Checked = True End If txtnkhaisinh.Text = mydr("nguoikhai") txtmqh.Text = mydr("moiquanhe") txthotich.Text = mydr("canbohotich") txtngcap.Text = mydr("nguoicap") txtchucvu.Text = mydr("chucvu") DTPngaycap.Text = mydr("ngaycap") txtnoicap.Text = mydr("noicap") If mydr("trangthai") = "Đúng hạn" Then RD1.Checked = True ElseIf mydr("trangthai") = "Trễ hạn" Then RD2.Checked = True Else rd3.Checked = True End If txtghichu.Text = mydr("ghichu") End While myconn.Close() End Sub Private Sub Button8_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button8.Click txtten.Text = "" RDnam.Checked = False RDnu.Checked = False DTPsinh.Text = "" txtnoisinh.Text = "" cmbdtoc.Text = "" cmbquoctich.Text = "" txtque.Text = "" txtcha.Text = "" cmbcha.Text = "" cbmqch.Text = "" DTPcha.Text = "" txtqcha.Text = "" txtttrucha.Text = "" txtme.Text = "" cbmme.Text = "" cbmqme.Text = "" DTPme.Text = "" txtqme.Text = "" txtttrume.Text = "" RDkethon.Checked = False RDko.Checked = False RDboroi.Checked = False RDkxacdinh.Checked = False txtnkhaisinh.Text = "" txtmqh.Text = "" txthotich.Text = "" txtngcap.Text = "" txtchucvu.Text = "" DTPngaycap.Text = "" txtnoicap.Text = "" RD1.Checked = False RD2.Checked = False rd3.Checked = False txtghichu.Text = "" End Sub Private Sub Button4_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button4.Click test = cmbquyen.Text bien = txtsohieu.Text Dim frm As New baocao frm.MdiParent = xulythongtin frm.Show() End Sub Private Sub cmbquyen_SelectedIndexChanged(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles cmbquyen.SelectedIndexChanged Dim myconn As New SqlConnection(str) myconn.Open() Dim mysql As String = "select * from nhankhau where quyenso='" + cmbquyen.Text + "' and moiquanhe=N'chủ hộ'" Dim mycomm As SqlCommand = New SqlCommand(mysql, myconn) Dim mydr As SqlDataReader = mycomm.ExecuteReader While mydr.Read() txtcha.Text = mydr("hoten") cmbcha.Text = mydr("dantoc") DTPcha.Text = mydr("ngaysinh") txtqcha.Text = mydr("quequan") txtttrucha.Text = mydr("noiohiennay") End While myconn.Close() myconn.Open() Dim mysql1 As String = "select * from nhankhau where quyenso='" + cmbquyen.Text + "' and moiquanhe=N'Vợ'" Dim mycomm1 As SqlCommand = New SqlCommand(mysql1, myconn) Dim mydr1 As SqlDataReader = mycomm1.ExecuteReader While mydr1.Read() txtme.Text = mydr1("hoten") cbmme.Text = mydr1("dantoc") DTPme.Text = mydr1("ngaysinh") txtqme.Text = mydr1("quequan") txtttrume.Text = mydr1("noiohiennay") End While myconn.Close() End Sub End Class *Code Form Báo cáo Kết Hôn Private Sub BCKetHon_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load Dim conn As New SqlConnection(str) conn.Open() Dim sqlstr As String sqlstr = "select * from kethon where quyenso='" + test + "'and sohieu='" + bien + "'" Dim ad As New SqlDataAdapter(sqlstr, conn) Dim ds As New DataSet ad.Fill(ds, "DTKetHon") Dim dts As New ReportDataSource dts.Name = "DSKetHon_DTKetHon" dts.Value = ds.Tables("DTKetHon") ReportViewer1.LocalReport.ReportEmbeddedResource = "quanlynhankhau.RptKetHon.rdlc" 'rdlc là đuôi của report ReportViewer1.LocalReport.DataSources.Add(dts) Me.ReportViewer1.RefreshReport() End Sub End Class KẾT LUẬN Chương trình Quản lý hộ khẩu sẽ giúp cho việc tin học hóa trong Phường cũng như công tác hành chính, cán bộ được tốt hơn, chính xác và khóa học hơn, làm tăng năng suất và hiệu quả công việc. Trên cơ sở đó giúp cho Lãnh đạo quản lý hộ khẩu, nhân khẩu một cách tự động hóa, tránh được những sai sót, những hạn chế mà cách quản lý thủ công gây ra, đáp ứng được yêu cầu lãnh đạo, chỉ đạo của cấp trên trong mọi tình huống kịp thời nhất. Chương trình Quản lý hộ khẩu cấp phường hoàn thành tương đối tốt đáp ứng được nhu cầu cập nhật, truy vấn thông tin nhanh chóng và giải quyết được việc tổ chức nhất quán CSDL trong lưu trữ thông tin. Tuy nhiên, chương trình vẫn còn nhược điểm, thiếu sót cần được hoàn thiện trong thời gian tới. Em xin chân thành cảm ơn các thầy cô giáo trong khoa CNTT trường DHDL Phương Đông đã nhiệt tình dạy dỗ, trang bị kiến thức giúp em trong cả khóa học và hoàn thành tốt đồ án này. Đặc biệt, em xin chân thành cảm ơn thầy Trần Văn Lộc, người đã tận tình chỉ bảo, giúp đỡ em hoàn thành tốt đồ án tốt nghiệp này. Hà Nội, ngày 22 tháng 4 năm 2009 Sinh viên Nguyễn Thị Hoài Thu TÀI LIỆU THAM KHẢO 1. Phân tích và Thiết kế hệ thống – TS Lê Văn Phùng 2. Cơ sở Dữ Liệu – TS Lê Văn Phùng 3. Bài giảng VisualBasic.Net – Nguyễn Bá Tiến 4. Hệ quản trị CSDL SQL Server - Phan Hiền LỜI CAM ĐOAN “Em xin cam đoan đây là công trình nghiên cứu của riêng em. Những tài liệu trong đồ án tốt nghiệp là hoàn toàn trung thực. Các kết quả nghiên cứu do chính em thực hiện dưới sự chỉ đạo của thầy giáo hướng dẫn”. TRƯỜNG ĐẠI HỌC DÂN LẬP PHƯƠNG ĐÔNG KHOA CÔNG NGHỆ THÔNG TIN ******* PHIẾU ĐÁNH GIÁ ĐỒ ÁN TỐT NGHIỆP Kính gửi: Ban chủ nhiệm khoa Công nghệ thông tin Đề nghị đọc, nhận xét, đánh giá đồ án với tiêu đề: “Tìm hiểu và xây dựng chương trình quản lý hộ khẩu cấp phường” theo các nội dung cụ thể dưới đây: Ý nghĩa lý luận, thực tiễn của đề tài. Đặt vấn đề: Cơ sở đặt vấn đề (0,5 điểm). Mức độ rõ ràng trong phương pháp trình bày vấn đề (1 điểm). Tính logic và hợp lý (0,5 điểm). Cách giải quyết vấn đề: Cơ sở lý luận và phương pháp luận ( 2 điểm). Độ tin cậy, cập nhập, tính chính xác về nguồn gốc của số liệu, tài liệu (1 điểm). Mức độ phù hợp của phương pháp xử lý thông tin ( 1 điểm). Mức độ hoàn thành mục tiêu, nhiệm vụ ( 1 điểm). Mức độ nắm vững kiến thức và vận dụng (1 điểm). Kết luận và kiến nghị (1 điểm). Bố cục, văn phòng (1 điểm). Xếp loại (xuất sắc, giỏi, khá, trung bình khá, trung bình, kém ), cho điểm( số nguyên). Hà Nội, ngày tháng năm 2009 Ký tên Nguyễn Thị Hoài Thu

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

  • doc2526.doc
Tài liệu liên quan