On Line Bank Project: Phase II Assignment UC Berkeley Computer Science 186 Fall 2002 Introduction to Database Systems September 30, 2002
Total Page:16
File Type:pdf, Size:1020Kb
On Line Bank Project: Phase II Assignment UC Berkeley Computer Science 186 Fall 2002 Introduction to Database Systems September 30, 2002 Overview of Phase II - Website Implementation This phase of the project will lead you through the steps of actually instantiating your database, and implementing a programmatic interface to it. The functions you write will interact with the database in a way that is consistent with the business requirements from Phase I. Your database will be an instance of the schema you designed in Phase I, possibly with modifications. The functions you implement will use embedded SQL to query and modify and the database. Part of the project will be graded automatically, and part will be graded in person with your TA. We will provide submission information closer to the deadline. Make sure your code runs smoothly on EECS instructional machines (rhombus, pentagon, and torus.cs.berkeley.edu) prior to submission since ALL grading will done on those. However, since all the software is freely available, you may find it easier to develop your code/website at home or on other machines you have access to. The instructions provided are designed to work with the EECS instructional machines and may not work as smoothly elsewhere. The TAs and Professor will only support EECS instructional machines. Steps of Phase II 1. Create PostgreSQL database (10%) 2. Implement Basic Functions (50%) 3. Implement Basic Webpage (15%) 4. Implement Decision Support (25%) 5. Prepare for Presentation 6. Submit Please spend some time to read this assignment completely before beginning. Create PostgreSQL Database (10%) Using the instructions online (http://inst.eecs.berkeley.edu/~cs186/doc/postgres.html), create a PostgreSQL database called fnfbc (you may use another name if you so choose). Place all your DDL commands (such as CREATE TABLE, CREATE VIEW, etc) in a file called schema.sql and import/run the commands in psql (using the \i schema.sql command from within psql). You may use any PostgreSQL data type you want except OIDs and arrays. You may not use PostgreSQL's Inheritance and Rules support. Use other features at your own risk (i.e. no TA support or sympathy). 1 Insert some test data into each table. We have provided some data located at the end of this assignment. You are free to reformat/augment/adjust the data to meet your particular schema requirements. One thing you may want to do is to renumber account numbers. We will provide more information about the testing procedures and test data later. It is useful to place the data in text files and then import the data. This way you can 'reset' your database with ease. You can either write the individual INSERT statements or use delimited files (such as comma separated files) and then use \copy to import the data. We recommend using comma separated files. When making a comma separated file for use with PostgreSQL, each row appears on its own line, with each field separated by a comma. The order of the fields must be the same as how they were listed in the CREATE TABLE statement. If there are not enough fields in the data file, the remaining columns are set to the default value or null. For example: CREATE TABLE import ( id int, name varchar(30), zipcode varchar(5), phonenumber varchar(12), CONSTRAINT import_pkey PRIMARY KEY(id) ); The data file (import.txt) would look like: 1,John Doe,12345,987-654-3210 2,Jane Doe,67890,123-456-7890 From within psql, you would run fnfbc=# \copy import from import.data using delimiters ',' Notice that the data file does not use quotes around strings, nor are their extra spaces between fields. Beware, blank lines are processed as insertions with default or null values for all columns. Each table must use its own data file and a separate import statement. Implement Basic Functions (50%) Now that you have a database with some data in it, you can issue SQL statements to it through PHP (or psql for practice). We will provide an API of basic functions you must implement, along with some supplemental files. You can get a copy of the provided files from ~cs186/fnfbc/*. • fnfbc.php is the basic API. It is designed to be included by other files that provide the web interface. You must provide implementations for all functions. DO NOT CHANGE any function declarations in this file. You may additional functions as you so desire. We will test using this API directly. 2 • datastruct.php contains some classes. It is designed to be included by the API. PHP does not directly support structs (as in C), so we used classes without any methods to provide the same feature/ease of use. DO NOT CHANGE any of the classes, although you may ADD methods to the classes or add additional classes if you wish. Again, we will be testing using these data structures. Before running the code be sure to modify the constants located at the top of fnfbc.php to reflect the host/port you are running PostgreSQL on as well as the userid/password. You can test to see if your code compiles by running: rhombus [1] ~/fnfnc > php scriptname at the command line from any x86 machine (same machines that run PostgreSQL). To actually run your code through a web browser, place your code in your public_html directory (or subdirectory) and use a web browser to request the file. The web server will run the file through php (if and only if the file ends .php) before sending the results to you. Most of your testing will be through the web server. Implement Basic Webpage (15%) Now that you have coded the API, it is time to link the API to webpages. We will use PHP scripts to gather input from the web and call the appropriate API functions, and display the results. Grading for this section will done during the presentation. We do not expect complex webpages, very basic HTML will suffice. Do not do anything that requires typing URLs directly. We encourage you to avoid JavaScript or and complicated browser technology like DHTML. All pages must work with IE5. You will need to use HTML forms. We will provide one screen as an example and template for you. The remaining files we have provided are: • findCustomer.php is designed to be used via the web using the minimal schema we have provided. It interfaces with the findCustomer() and findNextCustomer() API in fnfbc.php. This can be used as a template for other web pages and may be modified/deleted or otherwise changed as you see fit. • schema.sql contains a definition of customers for use with the provided test data and findCustomer.php. You are expected to change the schema to reflect the one you provided in Phase I with the appropriate changes. • customer.data contains test data with the following fields comma separated: taxid, last, first, address, city, state, zip, phone, password, online_enabled to match the provided schema. To test the code we have provided: 1. Create a new database (or use an existing one) 2. Load the schema from within psql using the \i schema.sql command 3. Load the test data from within psql using the \copy customers from customer.data with delimited ',' command 3 4. Place the 3 PHP scripts in your public_html directory (or subdirectory) 5. Make sure you've modified the the constants in fnfbc.php to reflect your database setup 6. Via the web, access the findCustomer.php webpage, http://inst.eecs.berkeley.edu/~cs186-XX/findCustomers.php 7. Try searching for "J%" - the % sign will match any set of characters when used with the LIKE operator in SQL. Implement Decision Support (25%) Using a database solely to record transaction information is useful and important. However, the ability to ask interesting queries over that data is even more important to businesses. Commonly referred to as decision support queries, these complex queries give CEO's and marketing staff insightful information about their business operations and allow them to tailor future offerings. Grading for this section will done during the presentation and will not utilize the provided API, so you are free to add whatever functions needed. You will implement a total of eight decision support questions. You should have a webpage for bank managers (or combine with an existing one) that has a menu of these queries (along with boxes to input query parameters). The results should be displayed on the web as well. You can add whatever functions you need to code to support the queries. You must support at least the following basic information queries: 1. Print out all transactions at a given branch for a given date 2. Print out all transactions for a given customer between a given range of dates You must support at least the following statistical queries: 1. Show the total activity for each branch and type of account (checking or savings) in ascending order for a given range of dates, i.e. Savings Berkeley $4000 Checking Fremont $6000 Savings Fremont $10000 Savings Walnut Creek $15000 Checking Berkeley $20000 Checking Walnut Creek $30000 Activity is defined as the sum of the absolute value for each transaction with an account from that branch. Note transfers should be counted twice, once for each account. 2. What is average amount of money each branch has in its vault over a specified period of dates? 3. Find pairs of customers where one customer withdraws a certain amount of money and another deposits that same amount in the same day (but not a direct transfer).