PostgreSQL/Date Timezone/timestamp — различия между версиями
Admin (обсуждение | вклад) м (1 версия) |
|
(нет различий)
|
Текущая версия на 10:14, 26 мая 2010
Using timestamp values correctly
postgres=#
postgres=# CREATE TABLE "shipments" (
postgres(# "id" integer DEFAULT nextval(""shipments_ship_id_seq""::text) NOT NULL,
postgres(# "customer_id" integer,
postgres(# "isbn" text,
postgres(# "ship_date" timestamp with time zone
postgres(# );
CREATE TABLE
postgres=#
postgres=# insert into shipments values (375, 142, "039480001X","2004-01-06 09:19:21-01");
INSERT 0 1
postgres=# insert into shipments values (323, 671, "0451160916","2004-02-14 10:26:41-02");
INSERT 0 1
postgres=# insert into shipments values (998, 1045, "0590445065","2004-03-12 12:39:47-03");
INSERT 0 1
postgres=#
postgres=#
postgres=# -- Using timestamp values correctly
postgres=#
postgres=# CREATE FUNCTION add_shipment (integer, text) RETURNS timestamp AS "
postgres"# DECLARE
postgres"# -- Declare aliases for function arguments.
postgres"# customer_id ALIAS FOR $1;
postgres"# isbn ALIAS FOR $2;
postgres"#
postgres"# shipment_id INTEGER;
postgres"# right_now timestamp;
postgres"#
postgres"# BEGIN
postgres"# right_now := ""now"";
postgres"#
postgres"# SELECT INTO shipment_id id FROM shipments ORDER BY id DESC;
postgres"#
postgres"# shipment_id := shipment_id + 1;
postgres"#
postgres"# INSERT INTO shipments VALUES ( shipment_id, customer_id, isbn, right_now );
postgres"#
postgres"# RETURN right_now;
postgres"# END;
postgres"# " LANGUAGE "plpgsql";
CREATE FUNCTION
postgres=#
postgres=# select add_shipment(1, "123");
add_shipment
-------------------------
2006-10-18 19:15:49.125
(1 row)
postgres=#
postgres=# select * from shipments;
id | customer_id | isbn | ship_date
-----+-------------+------------+----------------------------
375 | 142 | 039480001X | 2004-01-06 02:19:21-08
323 | 671 | 0451160916 | 2004-02-14 04:26:41-08
998 | 1045 | 0590445065 | 2004-03-12 07:39:47-08
999 | 1 | 123 | 2006-10-18 19:15:49.125-07
(4 rows)
postgres=#
postgres=# drop FUNCTION add_shipment (integer, text);
DROP FUNCTION
postgres=# drop table shipments;
DROP TABLE
postgres=#
postgres=#