Difference between revisions of "PostgreSQL"
Jump to navigation
Jump to search
Line 10: | Line 10: | ||
[[ PostgreSQL Audit ]] | [[ PostgreSQL Audit ]] | ||
+ | [[ PostgresSQL Foreign Data ]] | ||
Revision as of 18:31, 5 August 2019
Pages
PostgreSQL Audit PostgresSQL Foreign Data
Cheat Sheet
Extensions
PostgreSQL Replication, Redundancy & Backup
PL/Python vs PL/pgsql
https://www.postgresql.org/docs/11/plpython.html
The writer of a function in untrusted PL/Python must take care that the function cannot be used to do anything unwanted, since it will be able to do anything that could be done by a user logged in as the database administrator.
Row Level Security (RLS)
- https://www.postgresql.org/docs/11/ddl-rowsecurity.html
- https://medium.com/@cazzer/designing-the-most-performant-row-level-security-strategy-in-postgres-a06084f31945
- https://blog.2ndquadrant.com/application-users-vs-row-level-security/
Quick Commands
Using variables
WITH myconstants (var1, var2) as ( values (5, 'foo') ) SELECT * FROM somewhere, myconstants WHERE something = var1 OR something_else = var2;
Random int between 1 & 100
SELECT floor(random() * (100-1+1) + 1)::int;
Function
CREATE OR REPLACE FUNCTION random_between(low INT ,high INT) RETURNS INT AS $$ BEGIN RETURN floor(random()* (high-low + 1) + low); END; $$ language 'plpgsql' STRICT;
use
SELECT random_between(1,100);
Complicated example
add temp table
CREATE TEMP TABLE usr (id int, dummy text); INSERT INTO usr VALUES (1,'foo') ,(2,'bar') ,(3,'baz') ,(4,'bee');
Function: ``` CREATE OR REPLACE FUNCTION x.foo()
RETURNS VOID AS
$BODY$ DECLARE
_r record; _dummy integer := 0; _ct integer := 0; _5mod_ct integer;
BEGIN
RAISE INFO 'Start... '; FOR _r IN SELECT * FROM usr WHERE id < 50 LIMIT 10 LOOP LOOP UPDATE usr SET dummy = 'foo' WHERE id = _r.id;
_ct := _ct + 1;
_5mod_ct := 5 % _ct;
EXIT WHEN _5mod_ct > 0; -- make sure this will be TRUE eventually!
RAISE INFO '_5mod_ct = 0; repeating UPDATE!';
END LOOP;
_dummy := 10 / _5mod_ct;
RAISE NOTICE '_5mod_ct: %, _dummy: %, user.id: %',
_5mod_ct, _dummy, _r.id;
END LOOP;
RAISE INFO 'Finished.';
END; $BODY$ LANGUAGE plpgsql;```
Testing
pgbench
https://www.2ndquadrant.com/en/blog/pg-phriday-postgres-zfs/