summaryrefslogtreecommitdiff
path: root/src/backend
AgeCommit message (Collapse)Author
2001-01-01CLUSTER forgot to create a TOAST table for the clustered relation.Tom Lane
2001-01-01Ensure attcacheoff is written out as -1 when writing pg_attributeTom Lane
tuples for a relation. Needed to prevent Assert failure in CLUSTER.
2001-01-01Update comment.Tom Lane
2000-12-31Reverse #if test to be defined(__osf__) rather than not-any-of-a-lot-Tom Lane
of-others.
2000-12-31NetBSD/Alpha porting fixes from tom@minnesota.com.Tom Lane
2000-12-30Be more careful about the difference between signed and unsigned ints.Tom Lane
Bug is revealed by OID regress test on 64-bit platforms.
2000-12-301. WAL needs in zero-ed content of newly initialized page.Vadim B. Mikheev
2. Log record for PageRepaireFragmentation now keeps array of !LP_USED offnums to redo cleanup properly.
2000-12-30Fixed misprint in heap update WALoging.Vadim B. Mikheev
2000-12-30Paranoia about possible values of errno after a shmget/semget failure.Tom Lane
In theory we should always get EEXIST if there's a key collision, but if the kernel code tests error conditions in a weird order, perhaps EACCES or EIDRM could occur too.
2000-12-29Fix failure in CreateCheckPoint on some Alpha boxes --- it's not OK toTom Lane
assume that TAS() will always succeed the first time, even if the lock is known to be free. Also, make sure that code will eventually time out and report a stuck spinlock, rather than looping forever. Small cleanups in s_lock.h, too.
2000-12-29MUST update (in-memory) data page BEFORE XLogInsert to logVadim B. Mikheev
NEW page content if WAL will decide to backup page.
2000-12-29nbtree_xlog_newroot: set meta flag in meta page opaque.Vadim B. Mikheev
2000-12-28New WAL version - CRC and data blocks backup.Vadim B. Mikheev
2000-12-28Let's try this again on accepting the correct range of Oid input valuesTom Lane
for 64-bit platforms ...
2000-12-27Fix portability problems recently exposed by regression tests on Alphas.Tom Lane
1. Distinguish cases where a Datum representing a tuple datatype is an OID from cases where it is a pointer to TupleTableSlot, and make sure we use the right typlen in each case. 2. Make fetchatt() and related code support 8-byte by-value datatypes on machines where Datum is 8 bytes. Centralize knowledge of the available by-value datatype sizes in two macros in tupmacs.h, so that this will be easier if we ever have to do it again.
2000-12-23Compute reasonable cost and output-row-count estimates for LIMIT planTom Lane
nodes.
2000-12-23Replace overly-cute coding with code that (a) has defined behaviorTom Lane
according to the ANSI C spec, (b) gets the boundary conditions right, and (c) is about a third as long and three times more intelligible.
2000-12-22Small cleanup of temp-table handling. Disallow creation of a non-tempTom Lane
table that inherits from a temp table. Make sure the right things happen if one creates a temp table, creates another temp that inherits from it, then renames the first one. (Previously, system would end up trying to delete the temp tables in the wrong order.)
2000-12-22Repair not-too-well-thought-out code to do rangechecking of OIDs onTom Lane
64-bit machines. Also, make oidvectorin use the same code as oidin.
2000-12-22Avoid XLogFlush for clean buffers in BufferSync.Vadim B. Mikheev
2000-12-22Improve error message for case where DROP TABLE is rejected becauseTom Lane
table has a child table.
2000-12-22Add 'ONLY' to queries generated by RI triggers, so as to preserve pre-7.1Tom Lane
semantics of RI operations. Eventually we ought to look at making RI work properly across inheritance trees, but not for 7.1 ...
2000-12-22Change default output formatting for CIDR to be unabbreviated, perTom Lane
recommendation from Paul Vixie. Add a new abbrev() function to produce abbreviated format as text. No forced initdb, but new function is not available unless you do an initdb or add the pg_proc row manually.
2000-12-22Clean up CREATE TYPE/OPERATOR/AGGREGATE productions, so that parserTom Lane
will not accept types named with operator names or vice versa.
2000-12-22Revise lock manager to support "session level" locks as well as "transactionTom Lane
level" locks. A session lock is not released at transaction commit (but it is released on transaction abort, to ensure recovery after an elog(ERROR)). In VACUUM, use a session lock to protect the master table while vacuuming a TOAST table, so that the TOAST table can be done in an independent transaction. I also took this opportunity to do some cleanup and renaming in the lock code. The previously noted bug in ProcLockWakeup, that it couldn't wake up any waiters beyond the first non-wakeable waiter, is now fixed. Also found a previously unknown bug of the same kind (failure to scan all members of a lock queue in some cases) in DeadLockCheck. This might have led to failure to detect a deadlock condition, resulting in indefinite waits, but it's difficult to characterize the conditions required to trigger a failure.
2000-12-21Fix longstanding bug with VIEW using BETWEEN: OffsetVarNodes would getTom Lane
applied to the duplicated subtree twice. Probably someday we should fix the parser not to generate multiple links to the same subtree, but for now a quick copyObject() is the path of least resistance.
2000-12-20Remove multi.c and single.c, which have been dead code forTom Lane
over two years.
2000-12-20Prevent freshly-started backend from ignoring SIGUSR1, per race conditionTom Lane
observed by Inoue. Also, don't call ProcRemove() from postmaster if we have detected a backend crash --- too risky if shared memory is corrupted. It's not needed anyway, considering we are going to reinitialize shared memory and semaphores as soon as the last child is dead.
2000-12-18>> Here is a patch for the beos port (All regression tests are OK).Bruce Momjian
>> xlog.c : special case for beos to avoid 'link' which does not work yet >> beos/sem.c : implementation of new sem_ctl call (GETPID) and a new >sem_op >> flag (IPCNOWAIT) >> dynloader/beos.c : add a verification of symbol validity (seem that the >> loader sometime return OK with an invalid symbol) >> postmaster.c : add beos forking support for the new checkpoint process >> postgres.c : remove beos special case for getrusage >> beos.h : Correction of a bas definition of AF_UNIX, misc defnitions >> >> >> thanks >> >> >> cyril Cyril VELTER
2000-12-18Ensure that 'errno' is saved and restored by all signal handlers thatTom Lane
might change it. Experimentation shows that the signal handler call mechanism does not save/restore errno for you, at least not on Linux or HPUX, so this is definitely a real risk.
2000-12-18Make sure make_rels_by_clause_joins doesn't return multiple referencesTom Lane
to same joinrel. Although make_rels_by_joins doesn't mind, GEQO has an Assert that doesn't like this.
2000-12-18Repair mishandling of PRIMARY KEY declaration that references anTom Lane
inherited column, per bug report from Elphick 12/15/00.
2000-12-18Clean up backend-exit-time cleanup behavior. Use on_shmem_exit callbacksTom Lane
to ensure that we have released buffer refcounts and so forth, rather than putting ad-hoc operations before (some of the calls to) proc_exit. Add commentary to discourage future hackers from repeating that mistake.
2000-12-17Tweak select_common_type() to deal with possibility of multiple preferredTom Lane
types in a category --- it was taking the last preferred type among the inputs, rather than the first one as intended.
2000-12-15Remove current->old mapping.Bruce Momjian
2000-12-15Make algorithm for resolving UNKNOWN function/operator inputs beTom Lane
insensitive to the order of arguments. Per pghackers discussion 12/10/00.
2000-12-15here is a patch fixing today's bug report:Bruce Momjian
> Date: Thu, 14 Dec 2000 12:44:47 +0100 (CET) > From: Kovacs Zoltan Sandor <tip@pc10.radnoti-szeged.sulinet.hu> > To: pgsql-bugs@postgresql.org > Subject: [BUGS] to_char() causes backend to close connection > > Hi, this query gives different strange results: > > select to_char(now()::abstime,'YYMMDDHH24MI'); > > I get e.g. a "backend closed the channel unexpectedly..." error with > successful or failed resetting attempt (indeterministic) Again thanks Kovacs, you found really designing bug, that appear if anyone write bad format template to "number" version of to_char() (as you with 'DD'). Karel
2000-12-15Remove obsolete comment.Tom Lane
2000-12-15Remove a few remaining vestiges of elog(WARN).Tom Lane
2000-12-14BugfixJan Wieck
Trying to connect to template0 left a global referenced buffer because the scan of pg_database wasn't ended properly before elog(FATAL). Jan
2000-12-14Planner speedup hacking. Avoid saving useless pathkeys, so that pathTom Lane
comparison does not consider paths different when they differ only in uninteresting aspects of sort order. (We had a special case of this consideration for indexscans already, but generalize it to apply to ordered join paths too.) Be stricter about what is a canonical pathkey to allow faster pathkey comparison. Cache canonical pathkeys and dispersion stats for left and right sides of a RestrictInfo's clause, to avoid repeated computation. Total speedup will depend on number of tables in a query, but I see about 4x speedup of planning phase for a sample seven-table query.
2000-12-14Make sure to not handle deactivated system indexesHiroshi Inoue
2000-12-14Change StoreCatalogInheritance() to work from a list of parent relationTom Lane
OIDs rather than names. Aside from being simpler and faster, this way doesn't blow up in the face of 'create temp table foo () inherits (foo)'. Which is a rather odd thing to do, but it seems some people want to.
2000-12-13Fix thinko for case of outer join where inner table is empty: shouldTom Lane
output first outer tuple before advancing...
2000-12-12Cache eval cost of qualification expressions in RestrictInfo nodes toTom Lane
avoid repeated evaluations in cost_qual_eval(). This turns out to save a useful fraction of planning time. No change to external representation of RestrictInfo --- although that node type doesn't appear in stored rules anyway.
2000-12-11Remove elog for online log files.Vadim B. Mikheev
2000-12-11elog(LOG)-->elog(DEBUG) for skipped logs.Vadim B. Mikheev
2000-12-11Tweak Darwin patch to get right include order.Tom Lane
2000-12-11Resolve complie error(was my fault).Hiroshi Inoue
2000-12-11*redo: Heap move* neglects to set t_cmin for MOVED_IN tuples.Hiroshi Inoue