Passando l'ambito modulo per una CFC remoto
-
23-09-2019 - |
Domanda
Qual è la sintassi per far passare l'ambito modulo in una CFC con connessione = "remoto"? Ho:
<cfcomponent>
<cfset Variables.Datasource = "xxx">
<cffunction name="Save" access="remote">
<cfset var local = {}>
<!--- todo: try/catch --->
<cfif arguments.PersonID>
<cfquery datasource="#Variables.Datasource#">
UPDATE Person
SET FirstName = <cfqueryparam cfsqltype="cf_sql_varchar" value="#arguments.FirstName#">
,LastName = <cfqueryparam cfsqltype="cf_sql_varchar" value="#arguments.LastName#">
WHERE PersonID = <cfqueryparam cfsqltype="cf_sql_integer" value="#arguments.PersonID#">
</cfquery>
<cfset local.result = arguments.PersonID>
<cfelse>
<cfquery name="local.qry" datasource="#Variables.Datasource#">
INSERT INTO Person(FirstName,LastName) VALUES(
<cfqueryparam cfsqltype="cf_sql_varchar" value="#arguments.FirstName#">
,<cfqueryparam cfsqltype="cf_sql_varchar" value="#arguments.LastName#">
);
SELECT PersonID FROM Person
WHERE PersonID=Scope_Identity()
</cfquery>
<cfset local.result = local.qry.PersonID>
</cfif>
<cfreturn local.result>
</cffunction>
</cfcomponent>
ho bisogno di passare in form.PersonID, form.firstname, form.lastname.
Soluzione
La vostra funzione remoto può accettare sia un argomento struct, o 3 argomenti stringa (PersonID, nome e cognome).
Vedere <CFARGUMENT>
nella documentazione
Altri suggerimenti
Una cosa non correlato. In CF9 avete già la locali struct attesa. Maggiori informazioni su questo qui http: // forta.com/blog/index.cfm/2009/6/21/The-New-ColdFusion-LOCAL-Scope
Autorizzato sotto: CC-BY-SA insieme a attribuzione
Non affiliato a StackOverflow