「関連」ネストされた問題のラベルでMyBatisの

ネストされた関連付けのラベルを使用してクエリでMyBatisの場合は、関連付けは、内側のクエリ結果がnullとなっていることがわかりました

トラブルシューティング:

  • SQLの実装を確認し、我々は除いて、データ復帰を見つけました
  • プロパティ値と対応するPOJOかどうかを確認し、値が一致し、負
  • 除外に対応し、列の値と対応するデータベースかどうかを確認してください

それは調査がcolumnPrefixで対応する関連ではないとされた後、所定の位置にデータマッピングをMyBatisの一切あってはならないので、

<resultMap id="BaseResultMap" type="a.b.c.d.e">
    <id column="id" property="id" />
    <result property="workTime" column="work_time" />
    <result property="model" column="model" />
    <result property="status" column="status" />
    <association property="interfaceUpstream" javaType="interfaceUpstream" columnPrefix="ui_">
      <id column="id" property="id" />
      <result property="interfaceName" column="interface_name" />
      <result property="interfaceType" column="interface_type" />
      <result property="frequency" column="frequency" />
      <result property="address" column="address" />
      <result property="templateOrSql" column="template_or_sql" />
      <result property="status" column="status" />
      <association property="systemInfo" javaType="SystemInfo" columnPrefix="sys_">
        <id column="id" property="id"/>
        <result property="systemName" column="system_name"/>
        <result property="systemNameEN" column="system_name_en"/>
        <result property="belong" column="belong"/>
        <result property="status" column="status"/>
      </association>
      <association property="serverInfo" javaType="ServerInfo" columnPrefix="ser_">
        <id column="id" property="id"/>
        <result property="ftpIp" column="ftp_ip"/>
        <result property="ftpPort" column="ftp_port"/>
        <result property="ftpAccount" column="ftp_account"/>
        <result property="ftpPassword" column="ftp_password"/>
      </association>
    </association>
  </resultMap>
<sql id="base_select">
    SELECT
	ii.Id,
	ii.model,
	ii.status,
	ii.work_time,
	ui.id AS ui_id,
	ui.interface_name AS ui_interface_name,
	ui.interface_type AS ui_interface_type,
	ui.frequency AS ui_frequency,
	ui.address AS ui_address,
	ui.template_or_sql AS ui_template_or_sql,
	ui.status AS ui_status,
	sys.id AS sys_id,
	sys.system_name AS sys_system_name,
	sys.system_name_en AS sys_system_name_en,
	sys.belong AS sys_belong,
	sys.status AS sys_status,
	ser.id AS ser_id,
	ser.ftp_ip AS ser_ftp_ip,
	ser.ftp_port AS ser_ftp_port,
	ser.ftp_account AS ser_ftp_account,
	ser.ftp_password AS ser_ftp_password
  </sql>

コードの観点から問題なく
ネストされたときの関連付けが行われるため、columnPrefix内層の値は、合体のMyBatisの関連付け、意志
そのようなビットアウターcolumnPrefixのui_の値として、SYS_内層SQLはSYS_IDなどsys.idにすることはできません、追加する必要がui_ ui_sys_id AS sys.idに、とてもマッチデータにMyBatisの接頭対応協会にマップされます

次のように通常のコードは次のとおりです。

SELECT
	ii.Id,
	ii.model,
	ii.status,
	ii.work_time,
	ui.id AS ui_id,
	ui.interface_name AS ui_interface_name,
	ui.interface_type AS ui_interface_type,
	ui.frequency AS ui_frequency,
	ui.address AS ui_address,
	ui.template_or_sql AS ui_template_or_sql,
	ui.status AS ui_status,
	sys.id AS ui_sys_id,
	sys.system_name AS ui_sys_system_name,
	sys.system_name_en AS ui_sys_system_name_en,
	sys.belong AS ui_sys_belong,
	sys.status AS ui_sys_status,
	ser.id AS ui_ser_id,
	ser.ftp_ip AS ui_ser_ftp_ip,
	ser.ftp_port AS ui_ser_ftp_port,
	ser.ftp_account AS ui_ser_ftp_account,
	ser.ftp_password AS ui_ser_ftp_password

問題は解決しました!

リリース7件のオリジナルの記事 ウォンの賞賛1 ビュー994

おすすめ

転載: blog.csdn.net/weixin_42776772/article/details/104724922