Databaseontwerp
Lis Sulmont
Curriculum Manager
SUM(), AVG(), COUNT(), MIN(), MAX(), GROUP BY, etc.INNER JOIN, LEFT JOIN, RIGHT JOIN, FULL JOINWHERE, HAVING, UNIQUE, NOT NULL, AND, OR, >, <, etc.GRANT privilege(s) of REVOKE privilege(s)
ON object
TO role of FROM role
SELECT, INSERT, UPDATE, DELETE, etc. $$
GRANT UPDATE ON ratings TO PUBLIC;
$$
REVOKE INSERT ON films FROM db_user;
UPDATE films SET kind = 'Dramatic' WHERE kind = 'Drama';
Niet alle views zijn updatable
INSERT INTO films (code, title, did, date_prod, kind)
VALUES ('T_601', 'Yojimbo', 106, '1961-06-16', 'Drama');
Niet alle views zijn insertable
INSERT INTO films (code, title, did, date_prod, kind)
VALUES ('T_601', 'Yojimbo', 106, '1961-06-16', 'Drama');
Niet alle views zijn insertable
DROP VIEW view_name [ CASCADE | RESTRICT ];
RESTRICT (default): geeft een fout als er objecten van de view afhangenCASCADE: dropt de view en alle afhankelijke objectenCREATE OR REPLACE VIEW view_name AS new_query
view_name al, dan wordt die vervangennew_query moet dezelfde kolomnamen, volgorde en datatypes genereren als de oude queryAls dit niet kan, drop de bestaande view en maak een nieuwe
ALTER VIEW [ IF EXISTS ] name ALTER [ COLUMN ] column_name SET DEFAULT expression
ALTER VIEW [ IF EXISTS ] name ALTER [ COLUMN ] column_name DROP DEFAULT
ALTER VIEW [ IF EXISTS ] name OWNER TO new_owner
ALTER VIEW [ IF EXISTS ] name RENAME TO new_name
ALTER VIEW [ IF EXISTS ] name SET SCHEMA new_schema
ALTER VIEW [ IF EXISTS ] name SET ( view_option_name [= view_option_value] [, ... ] )
ALTER VIEW [ IF EXISTS ] name RESET ( view_option_name [, ... ] )
Databaseontwerp