Question

In: Computer Science

Using Triggers (5 pts.) Execute the following SQL to create the customer_audit table in the premier...

  1. Using Triggers (5 pts.)
    1. Execute the following SQL to create the customer_audit table in the premier schema.

CREATE TABLE IF NOT EXISTS customer_audit (

customer_num CHAR(3) NOT NULL,

  customer_name VARCHAR(35) NOT NULL,

street VARCHAR(15),

city VARCHAR(15),

state CHAR(2),

zip CHAR(5),

credit_limit DECIMAL(8,2),

date_changed DATETIME NOT NULL,

changed_by VARCHAR(45) NOT NULL);

  1. Notice that the audit table does not have a primary key defined. Explain why this might be acceptable.

  1. Based on the current attributes in the customer_audit table, suggest a possible primary key and explain why it might be unique.
  1. Create a trigger that will insert a record into the customer_audit table when the customer data is changed. Only insert a new record if the attributes that are being audited change. The attributes being audited are those that exist in the customer_audit table. For example the customer.balance attribute is not being audited so if it is the only attribute that changes as part of the transaction then we do not need to insert a new record into the audit table. Provide the SQL used to create this trigger.

  1. Write an SQL update statement that will change a customer and cause an audit record to be created. Provide the SQL statement you executed for this.

  1. Write an SQL statement that will display what is in the customer_audit table. Provide the SQL used.

Solutions

Expert Solution

Q. Notice that the audit table does not have a primary key defined. Explain why this might be acceptable. Answer:

  • I notice that Audit table does not have a primary key defined. This is acceptable because sometimes you can have tables without a primary key for storing all records that company wants to knew.
  • Basically, A table should have a primary key so that you could identify each row uniquely with it.
  • Technically, you can have tables without a primary key, but you'll be breaking good database design rules.

Q. Based on the current attributes in the customer_audit table, suggest a possible primary key and explain why it might be unique. Answer: Based on the current attributes in customer_audit table, I think an only possible primary key is customer_num attribute Because customer number is unique number for all customer.

Q. Create a trigger that will insert a record into the customer_audit table when the customer data is changed. Only insert a new record if the attributes that are being audited change. The attributes being audited are those that exist in the customer_audit table. For example the customer.balance attribute is not being audited so if it is the only attribute that changes as part of the transaction then we do not need to insert a new record into the audit table. Provide the SQL used to create this trigger.

Answer:

CREATE OR REPLACE TRIGGER display_Updation_audit BEFORE DELETE OR INSERT OR UPDATE ON customer_audit FOR EACH ROW WHEN (Customer_num > 0) DECLARE BEGIN dbms_output.put_line('New customer_num: ' || :NEW.customer_num);   dbms_output.put_line('New customer_name: ' || :NEW.customer_name);   dbms_output.put_line('New street: ' || :NEW.street);   dbms_output.put_line('New city: ' || :NEW.city);   dbms_output.put_line('New state: ' || :NEW.state);   dbms_output.put_line('New zip: ' || :NEW.zip);   dbms_output.put_line('New credit_limit: ' || :NEW.credit_limit);   dbms_output.put_line('New date_changed: ' || :NEW.date_changed);     dbms_output.put_line('New changed_by: ' || :NEW.changed_by);    END;

Use of Trigger:

  • Maintain Audit of database
  • store history for certain action of query

Q. Write an SQL update statement that will change a customer and cause an audit record to be created. Provide the SQL statement you executed for this.

Answer:

  • SQL Statement:
  • UPDATE customer_audit  SET credit_limit = 5000 WHERE credit_limit > 5000;
  • When we execute this query in database then after sometimes customer shopping and they reach their to credit_limit but if customer wants to buy more product then customer have to create new customer_ num for them And that cause an audit record to be created.

Q. Write an SQL statement that will display what is in the customer_audit table. Provide the SQL used.

Answer:

SQL Statement:

  • SELECT * FROM customer_audit;
  • This will display all the records present in customer_audit.

SQL Use:

  • SQL is used for administering, updating, maintaining and manipulating the databases or tables
  • SQL is usually used to fetch data, update the records,attributes of the table, or operate on the structure of the database or tables.
  • SQL can be used for both relational and multidimensional types of databases.

Related Solutions

Using SQL create a new database called school_app. Create a student table with fields id (auto...
Using SQL create a new database called school_app. Create a student table with fields id (auto increment), first_name, last_name. Create a course table with fields id (auto increment), course code (such as ITC or MTH), and course number (such as 100 or 295). Note that the relationship between student and course is many-to-many (n:m). Create a join table called student_course that implements the n:m relationship with fields id (auto increment), student_id, course_id, and grade (which has values 0, 1, 2,...
Create a ‘Student’ table using SQL query. The table must have at least five attributes from...
Create a ‘Student’ table using SQL query. The table must have at least five attributes from your choice with different data types.
USING SQL Create a table named Zones with the attributes and assumptions indicated below. Attributes: the...
USING SQL Create a table named Zones with the attributes and assumptions indicated below. Attributes: the zone ID, the lowest and the highest accepted temperature. Assumptions: the ID will be the primary key and have one or two digits, the temperatures (in Fahrenheit) will be at most two digits and a possible minus sign, none of the temperatures can be NULL. Populate table Zones so that it has the following rows: id lowerTemp higherTemp 2 -50 -40 3 -40 -30...
DBMS Create/Insert/Update SQL I need the create, insert, and update SQL statement for this table as...
DBMS Create/Insert/Update SQL I need the create, insert, and update SQL statement for this table as if it were being added to MySQL (please give explanations for each line of SQL code and a copy of the code as it would be entered into the query by itself: Customer PK Customer ID Text Phone Number int name text address ID int email text FK vendor ID int Vendor is the name of the table the FK comes from.
Use a single SQL statement to create a relational table and to load into the table...
Use a single SQL statement to create a relational table and to load into the table department name, subject code, year of running and session of running that offered by the departments. Note that a running subject offered by a department means a lecturer of the department has been assigned to teach the subject. Next, enforce the appropriate consistency constraints on the new table.    When ready use SELECT statement to list the contents of the relational table created and...
DBMS Create/Insert/Update SQL I need the create, insert, and update SQL statement for this table: Customer...
DBMS Create/Insert/Update SQL I need the create, insert, and update SQL statement for this table: Customer PK Customer ID Text Phone Number int name text address ID int email text FK vendor ID int Vendor is the name of the table the FK comes from.
1. write SQL statements to create the following two tables: a) Department table that contains the...
1. write SQL statements to create the following two tables: a) Department table that contains the following columns(dept_no,deptname,location) set the deptno to be the primary key. b) Employee table contains the following columns(emp_no,empname,deptno,salary)set the emp_no to be the primary key and dept_no to be the foreign key. 2. Write SQL statements to Insert the following 3 rows in Employee table:        (101,’Sami’,’D-101’,5000)        (102,’Yousef’,’D-101’,4000)        (103,’Sami’,’D-102’,7000) 3. Write SQL statements to Insert the following 3 rows in Department table:       ...
Create a new SQL table in your phpMyAdmin account that collects the following fields (columns) -  (10...
Create a new SQL table in your phpMyAdmin account that collects the following fields (columns) -   1) The name of a medicine, sanitizer, or tip/trick for protecting yourself against transmission or fight the disease - STRING 2) The amount of money the item costs - NUMBER 3) The UPC code of the item - NUMBER 4) Manufacturing country of the item - STRING Connect to the SQL database with your HTML code, and make sure to show the results of...
Write the SQL DDL to create the following 5 tables for an App store: Publisher, Category,...
Write the SQL DDL to create the following 5 tables for an App store: Publisher, Category, App, AppVersion, AppVersionReview: A Publisher table where each publisher is identified by an integer id and has a name (up to 40 characters). (1 mark) A Category table where each category has an id (integer), a name (up to 50 characters), and a parentId to identify its parent category. The parentId should be a foreign key to the Category table. (1.5 marks) An App...
Create a new SQL Developer SQL worksheet and create/run the following TWO (2) queries and save...
Create a new SQL Developer SQL worksheet and create/run the following TWO (2) queries and save your file as Comp2138LabTest1_JohnSmith100123456.sql (replace JohnSmith 100123456 with your name and student ID). Please place comment that includes your name and your student ID at the top of your script and number your queries using comments sections. Each query carries equal weight. A selection of the expected result set has been shown below for your convenience. Your output should match with this sample output....
ADVERTISEMENT
ADVERTISEMENT
ADVERTISEMENT