ABC Markets sell products to customers. The relational diagram shown in Figure P10.6 represents the main entities for ABC's database. Note the following important characteristics: A customer may make many purchases, each one represented by an invoice. The CUS_BALANCE is updated with each credit purchase or payment and represents the amount the customer owes. The CUS_BALANCE is increased (+) with every credit purchase and decreased (–) with every customer payment. The date of last purchase is updated with each new purchase made by the customer. The date of last payment is updated with each new payment made by the customer. An invoice represents a product purchase by a customer. An INVOICE can have many invoice LINEs, one for each product purchased. The INV_TOTAL represents the total cost of the invoice, including taxes. The INV_TERMS can be "30," "60," or "90" (representing the number of days of credit) or "CASH," "CHECK," or "CC." The invoice status can be "OPEN," "PAID," or "CANCEL." A product's quantity on hand (P_QTYOH) is updated (decreased) with each product sale. A customer may make many payments. The payment type (PMT_TYPE) can be one of the following: "CASH" for cash payments. "CHECK" for check payments. "CC" for credit card payments. The payment details (PMT_DETAILS) are used to record data about check or credit card payments: The bank, account number, and check number for check payments. The issuer, credit card number, and expiration date for credit card payments. Note: Not all entities and attributes are represented in this example. Use only the attributes indicated. Using this database, write the SQL code to represent each of the following transactions. Use BEGIN TRANSACTION and COMMIT to group the SQL statements in logical transactions. a. On May 11, 2018, customer 10010 makes a credit purchase (30 days) of one unit of product 11QER/31 with a unit price of $110.00; the tax rate is 8 percent. The invoice number is 10983, and this invoice has only one product line. b. On June 3, 2018, customer 10010 makes a payment of $100 in cash. The payment ID is 3428.
ABC Markets sell products to customers. The relational diagram shown in Figure P10.6 represents the main entities for ABC's
- A customer may make many purchases, each one represented by an invoice.
- The CUS_BALANCE is updated with each credit purchase or payment and represents the amount the customer owes.
- The CUS_BALANCE is increased (+) with every credit purchase and decreased (–) with every customer payment.
- The date of last purchase is updated with each new purchase made by the customer.
- The date of last payment is updated with each new payment made by the customer.
- An invoice represents a product purchase by a customer.
- An INVOICE can have many invoice LINEs, one for each product purchased.
- The INV_TOTAL represents the total cost of the invoice, including taxes.
- The INV_TERMS can be "30," "60," or "90" (representing the number of days of credit) or "CASH," "CHECK," or "CC."
- The invoice status can be "OPEN," "PAID," or "CANCEL."
- A product's quantity on hand (P_QTYOH) is updated (decreased) with each product sale.
- A customer may make many payments. The payment type (PMT_TYPE) can be one of the following:
- "CASH" for cash payments.
- "CHECK" for check payments.
- "CC" for credit card payments.
- The payment details (PMT_DETAILS) are used to record data about check or credit card payments:
- The bank, account number, and check number for check payments.
- The issuer, credit card number, and expiration date for credit card payments.
Note: Not all entities and attributes are represented in this example. Use only the attributes indicated.
Using this database, write the SQL code to represent each of the following transactions. Use BEGIN TRANSACTION and COMMIT to group the SQL statements in logical transactions.
a. On May 11, 2018, customer 10010 makes a credit purchase (30 days) of one unit of product 11QER/31 with a unit price of $110.00; the tax rate is 8 percent. The invoice number is 10983, and this invoice has only one product line.
b. On June 3, 2018, customer 10010 makes a payment of $100 in cash. The payment ID is 3428.
data:image/s3,"s3://crabby-images/1f7c6/1f7c6cbfcb81ce63c9102e60d3601b8a6dce46ee" alt="### FIGURE P10.6: The ABC Markets Relational Diagram
The diagram depicted above is a relational database schema for ABC Markets, illustrating the relationships between different entities involved in the business process. Each entity is represented as a table, with its attributes listed as fields. The connections between the tables denote the relationships between the entities.
#### Entities and Their Attributes:
1. **CUSTOMER**
- **CUS_CODE**: Primary Key
- CUS_LNAME
- CUS_FNAME
- CUS_INITIAL
- CUS_AREACODE
- CUS_PHONE
- CUS_CREDITLIMIT
- CUS_BALANCE
- CUS_DATELSTPMT
- CUS_DATELSTPUR
2. **INVOICE**
- **INV_NUMBER**: Primary Key
- CUS_CODE (Foreign Key referencing CUSTOMER)
- INV_DATE
- INV_TOTAL
- INV_TERMS
- INV_STATUS
3. **LINE**
- **INV_NUMBER**: Primary Key (Composite with LINE_NUMBER)
- **LINE_NUMBER**: Primary Key (Composite with INV_NUMBER)
- P_CODE (Foreign Key referencing PRODUCT)
- LINE_UNITS
- LINE_PRICE
4. **PRODUCT**
- **P_CODE**: Primary Key
- P_DESCRIPT
- P_INDATE
- P_QOH (Quantity on Hand)
- P_MIN (Minimum Order Quantity)
- P_PRICE
- P_DISCOUNT
- V_CODE (Foreign Key referencing VENDOR)
5. **PAYMENTS**
- **PMT_ID**: Primary Key
- PMT_DATE
- CUS_CODE (Foreign Key referencing CUSTOMER)
- PMT_AMT
- PMT_TYPE
- PMT_DETAILS
6. **VENDOR**
- **V_CODE**: Primary Key
- V_NAME
- V_CONTACT
- V_AREACODE
- V_PHONE
- V_STATE
- V_ORDER
### Explanation of Relationships:
- The **CUSTOMER** table is linked to the **INVOICE** table via the CUS_CODE, allowing for tracking of customer purchases and invoices.
- The **INVOICE** table is connected to the **LINE** table by INV_NUMBER, indicating that each invoice can have multiple line items.
- The **"
data:image/s3,"s3://crabby-images/00039/00039eaf710a9765f6db01fc5b9812260bf5cade" alt=""
Trending now
This is a popular solution!
Step by step
Solved in 3 steps
data:image/s3,"s3://crabby-images/e0cbe/e0cbe7c1cfa79a285a06530332b315bcf077d9a4" alt="Blurred answer"
data:image/s3,"s3://crabby-images/60092/600925f3c879aa48326d2697cc12cbd501c16012" alt="Database System Concepts"
data:image/s3,"s3://crabby-images/b5b1d/b5b1d5cf4b4f0b9fa5f7299e517dda8c78973ae2" alt="Starting Out with Python (4th Edition)"
data:image/s3,"s3://crabby-images/861e9/861e9f01dc31d6a60742dd6c59ed7da7e28cd75d" alt="Digital Fundamentals (11th Edition)"
data:image/s3,"s3://crabby-images/60092/600925f3c879aa48326d2697cc12cbd501c16012" alt="Database System Concepts"
data:image/s3,"s3://crabby-images/b5b1d/b5b1d5cf4b4f0b9fa5f7299e517dda8c78973ae2" alt="Starting Out with Python (4th Edition)"
data:image/s3,"s3://crabby-images/861e9/861e9f01dc31d6a60742dd6c59ed7da7e28cd75d" alt="Digital Fundamentals (11th Edition)"
data:image/s3,"s3://crabby-images/134f1/134f1b748b071d72903e45f776c363a56b72169f" alt="C How to Program (8th Edition)"
data:image/s3,"s3://crabby-images/3a774/3a774d976e0979e81f9a09e78124a494a1b36d93" alt="Database Systems: Design, Implementation, & Manag…"
data:image/s3,"s3://crabby-images/307b2/307b272f255471d7f7dc31378bac8a580ae1c49c" alt="Programmable Logic Controllers"