Charles,
You're correct. Most of the wierd stuff below is stuff Sybase invented to get around limitations, and failure to support the SQL standard, in their product. > RULES: > > In the sample below the RULE CloneEnd_type restricts input: the only > data which can be inserted or updated into CloneEnd.type have to be one > of 'BAC_end', 'YAC_end' etc.. > > I know postgresql supports RULES but have not used them prior. How would > one cone this for postgresql? In Postgres, or in SQL92 for that matter, this would not be a Rule. It would be a CONTSTRAINT. See the documentation on CREATE TABLE or ALTER TABLE to cover constraints. Please also be aware that the particular constraint you mention would be better implemented through a reference table ("clone_end_types") and a FORIEGN KEY CONSTRAINT. Finally, remember that if you use mixed-case table names, you will have to quote them all the time. > Stored Procedures: > > Are FUNCTIONS (postgresql)equivalent to stored procedures (Sybase)? Yes. Not exactly equivalent, but functionally equivalent, especially as of 7.3. > ALTER TABLE CloneEnd > ADD PRIMARY KEY (clone_end_id) This is also done with Constraints in Postgres and the SQL spec. > exec sp_primarykey CloneEnd, > clone_end_id > exec sp_bindrule CloneEnd_type_rule, 'CloneEnd.type' > exec sp_bindefault Set_To_Current_Date, 'CloneEnd.date_last_modified' > exec sp_bindefault Set_to_False, 'CloneEnd.is_obsolete' All of the above is done through the table definition in Postges. The last two functions simply set defaults for two columns. -- -Josh Berkus Aglio Database Solutions San Francisco ---------------------------(end of broadcast)--------------------------- TIP 4: Don't 'kill -9' the postmaster