Starting from:

$25

CSCE608-Project 1 Solved

This project provides you with an opportunity to have experience in building a database application for a real-world domain of your own interests. You will create a database using SQL, populate the database, write programs that manipulate the database, and develop an interface for user’s queries and modifications on the database.

Part A. E/R Diagram
Your first step is to identify a domain you would like to manage with your database, and to construct an Entity-Relationship diagram for the database. It is suggested that you pick an application that you will enjoy working with. It is especially nice if you pick an application where you can populate your database using real, as opposed to fabricated, data.

Try to pick an application with a schema that is relatively substantial, but not too enormous. For example, your E/R design should have in the range of five or so entity sets, and a similar number of relationship sets. You should certainly include different kinds of relationships (e.g., many-one, many-many) and different kinds of data (strings, integers, etc.), but your application need not necessarily require advanced features such as weak entity sets and ”is-a” relationships.

1.    Write a one-page description of the database application you propose to work with. Yourdescription should be brief, relatively complete and clear. If there are any unique or particularly difficult aspects of your proposed application, please point them out.

2.    Specify an E/R diagram for your proposed database. Underline key attributes for entitysets and include arrowheads indicating the multiplicity of relationship sets. If there are weak entity sets or ”is-a” relationships, make sure to notate them appropriately.

The appendix provides some suggested topics of the project for your consideration. You may revise yours to fit the applications of your own interests. You may also consult and discuss with the instructor or TA on your proposed application.

Part B. Relational Schema
In this second part of the project, you will produce a relational schema from the entityrelationship diagram you came up with in Part A.

1.    Using the method for translating an E/R diagram to relations, produce a set of relationsfor your database design.

2.    For each relation in your schema, specify the nontrivial functional dependencies for therelation. Any functional dependencies that actually hold in the real-world scenario that you are modeling should be specified. It is fine if some of your relations have no nontrivial functional dependencies.

3.    Check if each relation in your schema is in Boyce-Codd Normal Form (BCNF) with respectto the functional dependencies you specified. If not, decompose the relation into smaller relations so that each relation is in BCNF. No matter whether your relations from the E/R diagram are in BCNF or not, you should work through the relation normalization process, report and discuss the process and its results . Report how and why your relations are normalized if the normalization process produces new relations. If no new relations are produced, give descriptions on how your relations pass the BCNF test and provide explanations why your relations have no redundancy.

4.    (Optional) Discuss whether the Third Normal Form or the Fourth Normal Form would further improve the structures of your relations. You may further improve your relation structures if you feel needed.

Part C. Creating Your Database using SQL
In this part of the project, you will create a database schema for your database application using SQL, and you will populate the relations in your database with data sets.

 The CSE department provides accounts of PostgreSQL and MySQL database servers for each student, which can be activated through CSNET (http://csnet.cse.tamu.edu). It is recommended that you read this page https://wiki.cse.tamu.edu/index.php/How to Use MySQL, which contains detailed information about how to activate your database account and how to access the database. You may also find other useful information on CSE helpdesk website

(http://helpdesk.cse.tamu.edu). When connecting to the database, use your NetID as your user name. Also, you must use VPN when accessing CSNET and the database when your are off campus. VPN instructions are also available on CSE helpdesk website.

You may also download the Microsoft SQL Server Developer edition, which is free, from the

Internet.

To manage a database, you may use client software such as Unix software: mysql or psql.

They are available on the department servers compute.cs.tamu.edu and linux2.cs.tamu.edu. Graphical user-interface software might be helpful, such as MySQL Workbench, PHPMyAdmin, pgAdmin, or SQL Server Management Studio Express.

To create your database and populate it, you proceed as follows:

1.    familiarize yourself with an SQL relational DBMS (referenced above),

2.    create relations for your database based on your relational schema from Part B,

3.    generate database data: write a program in any programming language you like thatcreates large files of records for each of your database relations.

If you have available real data for your database, then your program will need to transform the data into files of records conforming to your database schema and to MySQL’s load format. Otherwise, you will need to write a program to fabricate data: your program will generate records conforming to your schema. Note that it is both fine and expected for your data values, strings especially, to be meaningless gibberish. The point of generating large amounts of data is so that you can experiment with a database of realistic size. The data you generate and load should be on the order of:

•     At least two relations with thousands of tuples

•     At least one relation with hundreds of tuples

If your application naturally includes relations that are expected to be relatively small (e.g., schools within a university), then it is fine to use some small relations, but please ensure that you have relations of the sizes prescribed above as well.

When writing a program to fabricate data, there are two important points to keep in mind:

•     Make sure not to generate duplicate values for key attributes.

•     Your database almost certainly includes relations that are expected to join with each other. For example, you may have a Student relation with an attribute CourseNum that is expected to join with attribute Number in relation Course. When generating data, be sure to generate values that actually do join – otherwise all of your interesting queries will have empty results! To order to ensure this, you may generate records for multiple relations (e.g., Course and Student) at the same time, or generate the records for one relation first, and then use the joining values for the other relation. For example, you could generate records for relation Course first, then use the Course.Number values when creating values for Student.CourseNum.

Part D. Developing a user interface
The application should have a clear purpose, and the interface must be user-friendly. Users do not need to know the details of the database or the SQL language to manipulate the data. Graphical interface is more desired than a text-based interface. Your program should consist of a continuous loop in which:

•     A list of at least five alternative options is offered to the user. (An additional alternative should be quit.)

•     The user selects an alternative.

•     The system prompts the user for appropriate input values.

•     The system accesses the database to perform the appropriate queries and/or modifications.

•     Data or an appropriate acknowledgment is returned to the user.

Both input and output in the interface should be in a format more convenient and pleasing than raw interactive SQL. Please include some ”interesting” queries or modifications, i.e., operations that require some of the more complex SQL constructs such as subqueries, aggregates, set operators, etc. As a general example, if your database is a campus applicant database, then your interface might include in its menu a number of useful queries on the database, with some queries performing statistical analysis requiring multiple levels of grouping, and other queries. To build the user interface,

1.    you can choose any combination of a programming language and a database system foryour application,

2.    set up or install a web server if you choose to write a web application. The departmentprovides a web server that hosts web pages written in Perl, PHP and C/C++,

3.    your software or web pages connect to the database using a connector. You will need toinstall a connector specific to the programming language of your application. CSE web server has the Perl & PHP connector installed for MySQL and PostgreSQL database. Some other connectors include:

More products