DSS サービスを介して db 関数を呼び出そうとしています。そのdb関数は基本的に、dssから入力として取得したデータベースのユーザー値を更新するために書かれています。
私のdb関数では、入力としてnull値を取得すると、postgresデータベースのユーザーの詳細が更新されません。それ以外の場合は更新されます。COALESCE 関数を使用してこれを達成しました。この db 関数の機能を個別にテストしたところ、正常に動作しています。
しかし、dssを介してnull値を関数に渡すと、dssはnullを ''(シングルスペース)に変換して関数に渡します。null を受信しない関数は、データベース フィールドを 1 つのスペースで更新します。
この問題のため、COALESCE 関数内にさらにロジックを記述する必要がありました。
dss が null 値を ' ' に変換する理由を知りたいですか?
私のdb関数は次のとおりです
CREATE OR REPLACE FUNCTION modify_user(customer_id_in character varying, email_id_in character varying, mobile_in character varying, first_name_in character varying, last_name_in character varying)
RETURNS integer AS
$BODY$
BEGIN
IF EXISTS (SELECT 1 FROM ildb_schema.customer_detail WHERE identifier = customer_id_in) THEN
UPDATE ildb_schema.customer_detail
SET first_name=COALESCE(first_name_in,first_name),
last_name=COALESCE(last_name_in,last_name),
mobile_number=COALESCE(mobile_in,mobile_number),
email=COALESCE(email_id_in,email),
last_modify=now()
WHERE identifier = customer_id_in
AND (first_name_in IS NOT NULL AND first_name_in IS DISTINCT FROM first_name
OR last_name_in IS NOT NULL AND last_name_in IS DISTINCT FROM last_name
OR mobile_in IS NOT NULL AND mobile_in IS DISTINCT FROM mobile_number
OR email_id_in IS NOT NULL AND email_id_in IS DISTINCT FROM email);
RETURN 1;
END IF;
RETURN 0;
END;
$BODY$
LANGUAGE plpgsql VOLATILE
COST 100;
ALTER FUNCTION ildb_schema.modify_user(character varying, character varying, character varying, character varying, character varying)
OWNER TO postgres;
DSSは以下の通りです。
<data name="update_test">
<config id="ildb">
<property name="carbon_datasource_name">test_database</property>
</config>
<query id="update_function" useConfig="ildb">
<sql>select * from modify_user(:cid,:email,:mob,:fn,:ln)</sql>
<result element="customer" rowName="">
<element column="modify_user" name="modify_user" xsdType="string"/>
</result>
<param defaultValue="null" name="cid" sqlType="STRING"/>
<param defaultValue="null" name="email" sqlType="STRING"/>
<param defaultValue="null" name="mob" sqlType="STRING"/>
<param defaultValue="null" name="fn" sqlType="STRING"/>
<param defaultValue="null" name="ln" sqlType="STRING"/>
</query>
<operation name="update_function_op1">
<call-query href="update_function">
<with-param name="cid" query-param="cid"/>
<with-param name="email" query-param="email"/>
<with-param name="mob" query-param="mob"/>
<with-param name="fn" query-param="fn"/>
<with-param name="ln" query-param="ln"/>
</call-query>
</operation>
<resource method="PUT" path="/update/function">
<call-query href="update_function">
<with-param name="cid" query-param="cid"/>
<with-param name="email" query-param="email"/>
<with-param name="mob" query-param="mob"/>
<with-param name="fn" query-param="fn"/>
<with-param name="ln" query-param="ln"/>
</call-query>
</resource>
</data>