spMFUpdateTable¶
- Return
1 = Success
0 = Partial (some records failed to be inserted)
-1 = Error
- Parameters
- @MFTableName
Valid Class TableName as a string
Pass the class table name, e.g.: ‘MFCustomer’
- @Updatemethod
0 = update from SQL to M-Files
1 = update from M-Files to SQL
- @User_ID (optional)
Default = 0
User_Id from MX_User_Id column
This is NOT the M-Files user. It is used to set and apply a user_id for a third party system. An example is where updates from a third party system must be filtered by the third party user (e.g. placing an order)
- @MFLastModified (optional)
Default = 100 years less than the current date
Get objects from M-Files that has been modified in M-files later than this date.
- @ObjIDs (optional)
Default = null
ObjID’s of records (separated by comma) e.g. : ‘10005,13203’
Restricted to 4000 charactes including the commas
- @Update_IDOut (optional, output)
Output id of the record in MFUpdateHistory logging the update ; Also added to the record in the Update_ID column on the class table
- @ProcessBatch_ID (optional, output)
Referencing the ID of the ProcessBatch logging table
- @SyncErrorFlag (optional)
Default = 0
This parameter is automatically set by spMFUpdateSynchronizeError when synchronization routine is called.
- @RetainDeletions (optional)
Default = 0
Set to 1 to keep deleted items in M-Files in the SQL table shown as “deleted” or the label of property 27 with the date time of the deletion.
- @IsDocumentCollection (optional)
Default = 0 (use default object type for the class)
Set to 1 to process objects with object type 9 (document collection) for the class.
- @Debug (optional)
Default = 0
1 = Standard Debug Mode
101 = Advanced Debug Mode
Purpose¶
This procedure get and push data between M-Files and SQL based on a number of filters. It is very likely that this procedure will be built into your application or own procedures as part of the process of creating, updating, inserting records from your application.
When calling this procedure in a query or via another procedure it will perform the update in batch mode on all the rows with a valid process_id.
When the requirements for transactional mode has been met and a record is updated/inserted in the class table with process_id = 1, a trigger will automatically fire spMFUpdateTable to update SQL to M-Files.
A number of procedures is included in the Connector that use this procedure including: - spMFUpdateMFilesToSQL - spMFUpdateTablewithLastModifiedDate - spMFUpdateTableinBatches - spMFUpdateAllIncludedInAppTables - spMFUpdateItembyItem
By default the object type of the class will get the object type from the MFclass Table (using the default object type of the class). To process Document collection objects for the class, the @IsDocumentCollection must be set to 1.
By default the system will use the the vault access user (per MFVaultSettings) as the LastModifiedBy and CreatedBy user in the class table. However, if the setting DefaultUser in the MFsettings table is set to 0 then the LastModified and Created by user can be set to any valid user. if it is not set in an update, then it would use the value of the previous version of the object. This setting is not class specific. If the DefaultUser is changed it will apply to all classes from that point onwards.
Prerequisites¶
From M-Files to SQL¶
Process_id in class table must be 0. All other rows are ignored.
From SQL to M-Files - batch mode¶
Process_id in class table must be 1 for rows to be updated or added to M-Files. All other rows are ignored.
Warnings¶
When using a filter (e.g. for a single object) to update the table with Update method 1 and the filter object process_id is not 0 then the filter will automatically revert to updating all records. Take care to pass valid filters before passing them into the procedure call.
This procedure will not remove destroyed objects from the class table. Use spMFUpdateMFilestoMFSQL identify and remove destroyed object.
This procedure will not remove objects from the class table where the class of the object was changed in M-Files. Use spMFUpdateMFilestoMFSQL to identify and remove these objects from the class table.
When running this procedure without setting the objids parameter will not identify if a record was deleted in M-Files. To update deleted records, use spMFUpdateMFilestoMFSQL or set the objids for the records to be updated.
When updating a record from SQL To MF the MF_Last_modified_by user will be taken as the last user that modified the record. If it is a new record in SQL and last modified by is not set, it will default to the MFSQLConnector user defined in the MFSettings table. To set or change the last modified user when a change is made in SQL then the MF_Last_modified_by_ID must be specifically set to the user that should be shown as the last modified by iser.
Deleted objects will only be removed if they are included in the filter ‘Objids’. Use spMFUpdateMFilestoMFSQL to identify deleted objects in general identify and update the deleted objects in the table.
Deleted objects in M-Files will automatically be removed from the class table unless @RetainDeletions is set to 1.
When the Retaindeletions flag are used, and a deleted object’s deleted date is reset to null with the intent to undelete the object, it will not reset the deletions flag in M-Files for the object. Use the procedure spmfDeleteObject, or spMFDeleteObjectList to reset a deletions flag of an object.
The valid range of real datatype properties for uploading from SQL to M-Files is -1,79E27 and 1,79E27. The value will be exchanged between MF and SQL without any rounding.
Examples¶
DECLARE @return_value int
EXEC @return_value = [dbo].[spMFUpdateTable]
@MFTableName = N'MFCustomerContact',
@UpdateMethod = 1,
@UserId = NULL,
@MFModifiedDate = null,
@update_IDOut = null,
@ObjIDs = NULL,
@ProcessBatch_ID = null,
@SyncErrorFlag = 0,
@RetainDeletions = 0,
@Debug = 0
SELECT 'Return Value' = @return_value
GO
Execute the core procedure with all parameters
DECLARE @return_value int
DECLARE @update_ID INT, @processBatchID int
EXEC @return_value = [dbo].[spMFUpdateTable]
@MFTableName = N'YourTableName', -- nvarchar(128)
@UpdateMethod = 1, -- int
@Update_IDOut = @update_ID output, -- int
@ProcessBatch_ID = @processBatchID output
SELECT * FROM [dbo].[MFProcessBatchDetail] AS [mpbd] WHERE [mpbd].[ProcessBatch_ID] = @processBatchID
SELECT 'Return Value' = @return_value
Process document collection type objects for the class
EXEC dbo.spMFUpdateTable @MFTableName = 'MFOtherDocument',
@UpdateMethod = 1,
@IsDocumentCollection = 1,
@Debug = 101
Update from and to M-Files with all optional parameters set to default.
--From M-Files to SQL
EXEC [dbo].[spMFUpdateTable] @MFTableName = 'MFCustomer',
@UpdateMethod = 1
--or
EXEC spMFupdateTable 'MFCustomer',1
--From SQL to M-Files
EXEC [dbo].[spMFUpdateTable] @MFTableName = 'MFCustomer',
@UpdateMethod = 0
--or
EXEC spMFupdateTable 'MFCustomer',0
Update from and to M-Files with all optional parameters set to default.
Changelog¶
Date |
Author |
Description |
2024-11-18 |
LC |
Change handling of float datatype, add new function, update assemblies |
2024-05-02 |
LC |
Set property 0 (name of title) to ‘Auto’ if null |
2024-04-10 |
LC |
resolve issue with ansii null warning |
2023-12-08 |
LC |
fix logging text for updatemethod 0 where objids specified |
2023-08-21 |
LC |
Add option based on MFSettings to set last modified by user |
2023-07-30 |
LC |
Fix bug when using windows based account for last modified user |
2023-06-30 |
LC |
All to change or select the last modified user |
2023-06-06 |
LC |
fix bug when updating table for missing object in class table |
2023-04-20 |
LC |
replacing get user id to using user account instead of login account |
2023-03-08 |
LC |
rework filter processing to improve throughput and reduce locks |
2023-02-06 |
LC |
Change create and modified date when new to UTC instead of local time |
2022-11-18 |
LC |
Change formatting of float to take account of culture |
2022-09-02 |
LC |
Add retain deletions to spMFUpdateSynchronizeError |
2022-08-03 |
LC |
Update sync precedence to resolve issue with not updating |
2022-06-01 |
LC |
Resolve bug with data definition in large text properties |
2022-03-23 |
LC |
Add protection against locking when updating class table |
2022-03-07 |
LC |
Fix bug with not updating AuditTable |
2022-02-08 |
LC |
Further optimize, replace UNPIVOT with new case method |
2022-02-06 |
LC |
allow null to be passed in for properties |
2022-01-28 |
lc |
Remove table scan when updatemethod 0 |
2022-01-26 |
LC |
Resolve bug related to audit table deletions removal |
2021-12-20 |
LC |
Pair connection test with Wrapper |
2021-06-21 |
LC |
Modify proc to include document collections |
2021-04-14 |
LC |
fix timestamp datatype bug |
2021-03-15 |
LC |
fix changing of class in the same object type in MF |
2021-03-11 |
LC |
update maximum valid number range to between -1,79E27 and 1,79E27 |
2021-01-31 |
LC |
Fix bug on insert new into audithistory |
2020-11-28 |
LC |
Improve collection of property ids |
2020-11-28 |
LC |
Resolve issue when fail message |
2020-11-24 |
LC |
New functionality to deal with changing of classes |
2020-10-20 |
LC |
Fix locationlisation for class_id |
2020-09-21 |
LC |
Change column name Value to avoid conflict with property |
2020-08-25 |
LC |
Fix debugging and log messaging |
2020-08-27 |
LC |
Rework logic to deal with deleted objects |
2020-08-29 |
LC |
Update treatment of required workflow errors |
2020-08-22 |
LC |
Replace boolean column Deleted with property 27 |
2020-07-27 |
LC |
Add handling of delete and check out status |
2020-06-13 |
LC |
Remove xml_document when transaction failed |
2020-05-12 |
LC |
Set last modified user to MFSQL |
2020-04-20 |
LC |
exclude last modified and and MF user to be modified |
2020-03-09 |
LC |
Resolve issue with timestamp format for finish formatting |
2020-02-27 |
LC |
Resolve issue with open XML_Docs |
2020-01-06 |
LC |
Resolve issue: variable is null: @RetainDeletions |
2020-01-06 |
LC |
Resolving performance bug when filtering on objids |
2019-12-31 |
DEV2 |
New output parameter add in spMFCreateObjectInternal to return the checkout objects. |
2019-10-01 |
LC |
Allow for rounding where float has long decimals |
2019-09-02 |
LC |
Fix conflict where class table has property with ‘Name’ as the name V53 |
2019-08-24 |
LC |
Fix label of audithistory table inserts |
2019-07-26 |
LC |
Update removing of redundant items form AuditHistory |
2019-07-13 |
LC |
Add working that not all records have been updated |
2019-06-17 |
LC |
UPdate MFaudithistory with changes |
2019-05-19 |
LC |
Terminate early if connection cannot be established |
2019-01-13 |
LC |
Fix bug for uniqueidentifyer type columns (e.g. guid) |
2019-01-03 |
LC |
Fix bug for updating time property |
2018-12-18 |
LC |
Validate that all records have been updated, raise error if not |
2018-12-06 |
LC |
Fix bug t.objid not found |
2018-11-05 |
LC |
Include new parapameter to validate class and property structure |
2018-10-30 |
LC |
Removing cursor method for update method 0 and reducing update time by 100% |
2018-10-24 |
LC |
Resolve bug when objids filter is used with only one object |
2018-10-20 |
LC |
Set Deleted to != 1 instead of = 0 to ensure new records where deleted is not set is taken INSERT |
2018-08-23 |
LC |
Fix bug with presedence = 1 |
2018-08-01 |
LC |
Fix deletions of record bug |
2018-08-01 |
LC |
New parameter @RetainDeletions to allow for auto removal of deletions Default = NO |
2018-06-26 |
LC |
Improve reporting of return values |
2018-05-16 |
LC |
Fix conversion of float to nvarchar |
2018-04-04 |
DEV2 |
Added Licensing module validation code. |
2017-11-03 |
DEV2 |
Added code to check required property has value or not |
2017-10-01 |
LC |
Fix bug with length of fields |
2017-08-23 |
DEV2 |
Add exclude null properties from update |
2017-08-22 |
DEV2 |
Add sync error correction |
2017-07-06 |
LC |
Add update of filecount column in class table |
2017-07-03 |
LC |
Modify objids filter to include ids not in sql |
2017-06-22 |
LC |
Add ability to modify external_id |
2107-05-12 |
LC |
Set processbatchdetail column detail |
2016-10-10 |
LC |
Change of name of settings table |
2016-09-21 |
LC |
Removed @UserName,@Password,@NetworkAddress and @VaultName parameters and fectch it as comma separated list in @VaultSettings parameter dbo.fnMFVaultSettings() function |
2016-08-22 |
LC |
Change objids to NVARCHAR(4000) |
2016-08-22 |
LC |
Update settings index |
2016-08-20 |
LC |
Add Update_ID as output paramter |
2016-08-18 |
LC |
Add defaults to parameters |
2016-03-10 |
DEV2 |
New input variable added (@ObjIDs) |
2016-03-10 |
DEV2 |
Input variable @FromCreateDate changed to @MFModifiedDate |
2016-02-22 |
LC |
Improve debugging information; Remove is_template message when updatemethod = 1 |
2015-07-18 |
DEV2 |
New parameter add in spMFCreateObjectInternal |
2015-06-30 |
DEV2 |
New error Tracing and Return Value as LeRoux instruction |
2015-06-24 |
DEV2 |
Skip the object failed to update in M-Files |
2015-04-23 |
DEV2 |
Removing Last modified & Last modified by from Update data |
2015-04-16 |
DEV2 |
Adding update table details to MFUpdateHistory table |
2015-04-08 |
DEV2 |
Deleting property value from M-Files (Task 57) |