ONLINE HELP
 WINDEVWEBDEV AND WINDEV MOBILE

This content has been translated automatically.  Click here  to view the French version.
Help / WLanguage / Managing databases / HFSQL / HFSQL functions
  • Enabling the management of integrity
  • Disabling the integrity rules
  • In HFSQL Client/Server mode
WINDEV
WindowsLinuxJavaReports and QueriesUser code (UMC)
WEBDEV
WindowsLinuxPHPWEBDEV - Browser code
WINDEV Mobile
AndroidAndroid Widget iPhone/iPadIOS WidgetApple WatchMac Catalyst
Others
Stored procedures
Enables or disables the management of an integrity constraint on a file link.
Note: By default, all integrity rules defined in the analysis description are active.
Example
// Disable the check for cardinalities on the link between an order and a customer
HSetIntegrity(CustomerOrder, hCardinality, False)
// Disable all integrity rules on all application data files
HSetIntegrity("*", "*", hCardinality + hOnUpdate + hOnDelete, False)
// equivalent to: HSetIntegrity(False)
// Disable integrity rules on the link between an order and a customer
// with use of a connection
CtSourceFile is Connection
CtLinkedFile is Connection

HSetIntegrity(CtSourceFile, CtLinkedFile, CustomerOrder, ... 
	hCardinality + hOnUpdate + hOnDelete, False)
Syntax

Enabling or disabling the management of an integrity constraint by specifying the file name Hide the details

<Result> = HSetIntegrity([<Link to use>] [, <Data file>] [, <Integrity constraint>] , <Management mode>)
<Result>: Boolean
Former management mode of integrity (before the call to HSetIntegrity):
  • True if the management of integrity was enabled,
  • False if the management of integrity was disabled.
If <Link to use> = "*" or if <Data file> = "*", <Result> is set to True if the integrity was enabled for at least one link or for at least one data file in the former management mode of the integrity.
<Link to use>: Optional character string
Name of relevant link (name made of the different data files involved in the link).
If this name is not specified or if it is equal to "*", the new integrity management is applied to all links defined in the analysis.
<Data file>: Optional character string
Name of the data file used.
If this parameter is not specified or of it is equal to "*", the new management is applied to all the data files involved in the link (including the aliases).
If <Link to use> corresponds to "*", this parameter must also correspond to "*". Indeed, you cannot enable or disable all the integrity constraints for all links found in a specific data file.
<Integrity constraint>: Optional Integer constant (or combination of constants)
Used to define the integrity constraints that must be managed. If this parameter is not specified, the new management mode is applied to all link constraints.
hCardinalityCheck the link cardinalities.
hOnDeleteIntegrity rule applied during a deletion.
hOnUpdateIntegrity rule applied during a modification.
<Management mode>: Boolean
  • True if the integrity constraint is enabled,
  • False if this management must be disabled. If only this parameter is specified, the management mode is applied to all data files.

Enabling or disabling the management of an integrity constraint by specifying the connection of data file Hide the details

<Result> = HSetIntegrity(<Source data file connection> [, <Linked data file connection>] , <Link description> [, <Integrity constraint>] , <Management mode>)
<Result>: Boolean
Former management mode of integrity (before the call to HSetIntegrity):
  • True if the management of integrity was enabled,
  • False if the management of integrity was disabled.
<Source data file connection>: Character string or Connection variable
Connection to which the link source data file belongs. This connection corresponds to:
<Linked data file connection>: Optional character string or Connection variable
Connection to which the linked data file of the link belongs. This connection corresponds to: If this parameter is not specified, both data files will belong to the same connection (<Source data file connection>).
<Link description>: Link Description variable
Name of the Link description variable that contains the characteristics of the link.
<Integrity constraint>: Optional Integer constant (or combination of constants)
Integrity constraints that must be managed. If this parameter is not specified, the new management mode is applied to all link constraints.
hCardinalityCheck the link cardinalities.
hOnDeleteIntegrity rule applied during a deletion.
hOnUpdateIntegrity rule applied during a modification.
<Management mode>: Boolean
  • True if the integrity constraint is enabled,
  • False if this management must be disabled. If only this parameter is specified, the management mode is applied to all data files.
Remarks

Enabling the management of integrity

If an operation performed on a data file triggers a violation of an integrity constraint on an active rule, the operation is not performed and provokes the error of the function. In this case, HErrorIntegrity returns True.
Note: Only functions HAdd, HModify, HDelete, HCross and HWrite can generate an integrity error.

Disabling the integrity rules

Disabling an integrity rule means the possibility not to comply with the constraints specified during the description of the data files in the data model editor. Deactivating an integrity rule is therefore not a trivial operation: it must be used wisely.
WINDEVWEBDEV - Server codeReports and QueriesAndroidAndroid Widget iPhone/iPadJavaHFSQL Client/Server

In HFSQL Client/Server mode

Using the HSetIntegrity(<Management>) syntax affects the behavior of all HFSQL servers (no matter whether the connection is opened before or after the call to HSetIntegrity).
Using HSetIntegrity by specifying the link name can be done if:
  • The link is described in the client analysis (or by HDescribeLink).
  • The two data files linked by this link are found on the same HFSQL server.
If HSetIntegrity is called before the data files are in Client/Server mode (if HChangeConnection is used for example), the server enables the integrity rule.
A right is associated with integrity management on the database: hDroitGèreIntégrité. An error occurs when the user tries not to comply with the integrity constraint (when using HAdd, HModify, ...).
Component: wd300hf.dll
Minimum version required
  • Version 9
This page is also available for…
Comments
Click [Add] to post a comment

Last update: 10/04/2024

Send a report | Local help