summaryrefslogtreecommitdiff
path: root/offapi/com/sun/star/sdbc/KeyRule.idl
diff options
context:
space:
mode:
Diffstat (limited to 'offapi/com/sun/star/sdbc/KeyRule.idl')
-rw-r--r--offapi/com/sun/star/sdbc/KeyRule.idl192
1 files changed, 192 insertions, 0 deletions
diff --git a/offapi/com/sun/star/sdbc/KeyRule.idl b/offapi/com/sun/star/sdbc/KeyRule.idl
new file mode 100644
index 000000000000..08806abccf94
--- /dev/null
+++ b/offapi/com/sun/star/sdbc/KeyRule.idl
@@ -0,0 +1,192 @@
+/*************************************************************************
+ *
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * Copyright 2000, 2010 Oracle and/or its affiliates.
+ *
+ * OpenOffice.org - a multi-platform office productivity suite
+ *
+ * This file is part of OpenOffice.org.
+ *
+ * OpenOffice.org is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Lesser General Public License version 3
+ * only, as published by the Free Software Foundation.
+ *
+ * OpenOffice.org is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU Lesser General Public License version 3 for more details
+ * (a copy is included in the LICENSE file that accompanied this code).
+ *
+ * You should have received a copy of the GNU Lesser General Public License
+ * version 3 along with OpenOffice.org. If not, see
+ * <http://www.openoffice.org/license.html>
+ * for a copy of the LGPLv3 License.
+ *
+ ************************************************************************/
+#ifndef __com_sun_star_sdbc_KeyRule_idl__
+#define __com_sun_star_sdbc_KeyRule_idl__
+
+ module com { module sun { module star { module sdbc {
+
+
+/** determines the rules for foreign key constraints.
+ */
+published constants KeyRule
+{
+
+ /** a possible value for the column's
+ <code>UPDATE_RULE</code>
+ and
+ <code>DELETE_RULE</code>
+ in the
+ <type scope="com::sun::star::sdbc">XResultSet</type>
+ objects returned by the methods
+ <member scope="com::sun::star::sdbc">XDatabaseMetaData::getImportedKeys()</member>
+ ,
+ <member scope="com::sun::star::sdbc">XDatabaseMetaData::getExportedKeys()</member>
+ ,
+ and
+ <member scope="com::sun::star::sdbc">XDatabaseMetaData::getCrossReference()</member>
+ .
+ <P>
+ For the column
+ <code>UPDATE_RULE</code>
+ ,
+ it indicates that
+ when the primary key is updated, the foreign key (imported key)
+ is changed to agree with it.
+ </P>
+ <P>
+ For the column
+ <code>DELETE_RULE</code>
+ ,
+ it indicates that
+ when the primary key is deleted, rows that imported that key
+ are deleted.
+ </P>
+ */
+ const long CASCADE = 0;
+ //-------------------------------------------------------------------------
+
+ /** a possible value for the column's
+ <code>UPDATE_RULE</code>
+ and
+ <code>DELETE_RULE</code>
+ in the
+ <type scope="com::sun::star::sdbc">XResultSet</type>
+ objects returned by the methods
+ <member scope="com::sun::star::sdbc">XDatabaseMetaData::getImportedKeys()</member>
+ ,
+ <member scope="com::sun::star::sdbc">XDatabaseMetaData::getExportedKeys()</member>
+ ,
+ and
+ <member scope="com::sun::star::sdbc">XDatabaseMetaData::getCrossReference()</member>
+ .
+ <P>
+ For the column
+ <code>UPDATE_RULE</code>
+ , it indicates that
+ a primary key may not be updated if it has been imported by
+ another table as a foreign key.
+ </P>
+ <P>
+ For the column
+ <code>DELETE_RULE</code>
+ , it indicates that
+ a primary key may not be deleted if it has been imported by
+ another table as a foreign key.
+ </P>
+ */
+ const long RESTRICT = 1;
+ //-------------------------------------------------------------------------
+
+ /** a possible value for the column's
+ <code>UPDATE_RULE</code>
+ and
+ <code>DELETE_RULE</code>
+ in the
+ <type scope="com::sun::star::sdbc">XResultSet</type>
+ objects returned by the methods
+ <member scope="com::sun::star::sdbc">XDatabaseMetaData::getImportedKeys()</member>
+ ,
+ <member scope="com::sun::star::sdbc">XDatabaseMetaData::getExportedKeys()</member>
+ ,
+ and
+ <member scope="com::sun::star::sdbc">XDatabaseMetaData::getCrossReference()</member>
+ .
+ <P>
+ For the columns
+ <code>UPDATE_RULE</code>
+ and
+ <code>DELETE_RULE</code>
+ ,
+ it indicates that
+ when the primary key is updated or deleted, the foreign key (imported key)
+ is changed to <code>NULL</code>.
+ </P>
+ */
+ const long SET_NULL = 2;
+ //-------------------------------------------------------------------------
+
+ /** a possible value for the column's
+ <code>UPDATE_RULE</code>
+ and
+ <code>DELETE_RULE</code>
+ in the
+ <type scope="com::sun::star::sdbc">XResultSet</type>
+ objects returned by the methods
+ <member scope="com::sun::star::sdbc">XDatabaseMetaData::getImportedKeys()</member>
+ ,
+ <member scope="com::sun::star::sdbc">XDatabaseMetaData::getExportedKeys()</member>
+ ,
+ and
+ <member scope="com::sun::star::sdbc">XDatabaseMetaData::getCrossReference()</member>
+ .
+ <P>
+ For the columns
+ <code>UPDATE_RULE</code>
+ and
+ <code>DELETE_RULE</code>
+ ,
+ it indicates that if the primary key has been imported, it cannot be updated or deleted.
+ </P>
+ */
+ const long NO_ACTION = 3;
+ //-------------------------------------------------------------------------
+
+ /** a possible value for the column's
+ <code>UPDATE_RULE</code>
+ and
+ <code>DELETE_RULE</code>
+ in the
+ <type scope="com::sun::star::sdbc">XResultSet</type>
+ objects returned by the methods
+ <member scope="com::sun::star::sdbc">XDatabaseMetaData::getImportedKeys()</member>
+ ,
+ <member scope="com::sun::star::sdbc">XDatabaseMetaData::getExportedKeys()</member>
+ ,
+ and
+ <member scope="com::sun::star::sdbc">XDatabaseMetaData::getCrossReference()</member>
+ .
+ <P>
+ For the columns
+ <code>UPDATE_RULE</code>
+ and
+ <code>DELETE_RULE</code>
+ ,
+ it indicates that
+ if the primary key is updated or deleted, the foreign key (imported key)
+ is set to the default value.
+ </P>
+ */
+ const long SET_DEFAULT = 4;
+};
+
+//=============================================================================
+
+}; }; }; };
+
+/*===========================================================================
+===========================================================================*/
+#endif