oracle(4)-order byソートページ繰返し解決
2442 ワード
問題の説明:oracleデータベースorder byのソートが一意ではなく、最終的なデータのソートが安定しているかどうか、結果は、ページ分割時に繰り返し表示されます.症状は、2ページ目と3ページ目に重複するデータがあります.
問題のあるsql:
問題解決:order byの最後に、PK列またはROWIDを追加することをお勧めします.
修正後のsql:orderの後ろにu.user_を追加id(プライマリキー)ソート
まとめ:以降、ソート・カラムが重複する可能性がある場合は、プライマリ・キー・カラムを1つ追加してソートします.
問題のあるsql:
select
*
from
( select
u.user_id user_id,
u.user_name user_name,
u.mobile1 mobile,
substr(u.id_no,
-4) id_no,
i.industry_name industry_name,
to_char(su.organ_type) organ_type,
su.organ_name group_name,
su.train_date train_date,
0 assign_status,
' ' assign_status_name
from
szfdc.szfdc_users su
join
sec_users u
on u.user_id = su.id
join
sec_user_group_rel ug
on u.user_id = ug.user_id
left join
t_industry i
on i.organ_type = su.organ_type
where
(
su.organ_type in (
512, 1024,2048
)
or su.organ_type is null
)
and ug.group_id = 10000000313
order by
su.train_date desc nulls last)
where
rownum <= 20;
問題解決:order byの最後に、PK列またはROWIDを追加することをお勧めします.
修正後のsql:orderの後ろにu.user_を追加id(プライマリキー)ソート
select
*
from
( select
u.user_id user_id,
u.user_name user_name,
u.mobile1 mobile,
substr(u.id_no,
-4) id_no,
i.industry_name industry_name,
to_char(su.organ_type) organ_type,
su.organ_name group_name,
su.train_date train_date,
0 assign_status,
' ' assign_status_name
from
szfdc.szfdc_users su
join
sec_users u
on u.user_id = su.id
join
sec_user_group_rel ug
on u.user_id = ug.user_id
left join
t_industry i
on i.organ_type = su.organ_type
where
(
su.organ_type in (
512, 1024,2048
)
or su.organ_type is null
)
and ug.group_id = 10000000313
order by
su.train_date desc nulls last,u.user_id )
where
rownum <= 20;
まとめ:以降、ソート・カラムが重複する可能性がある場合は、プライマリ・キー・カラムを1つ追加してソートします.