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.

È stato utile?

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
scroll top