Penukaran ResultSet yang Cekap kepada JSON
Kod yang disediakan dengan cekap menukar ResultSet kepada rentetan JSON menggunakan JSONArray dan JSONObject. Walau bagaimanapun, terdapat potensi peningkatan untuk kelajuan dan pengoptimuman memori.
Satu pendekatan untuk meningkatkan kelajuan adalah dengan memudahkan kod. Coretan kod berikut menawarkan penyelesaian yang diperkemas:
JSONArray json = new JSONArray(); ResultSetMetaData rsmd = rs.getMetaData(); while(rs.next()) { int numColumns = rsmd.getColumnCount(); JSONObject obj = new JSONObject(); for (int i=1; i<=numColumns; i++) { String column_name = rsmd.getColumnName(i); obj.put(column_name, rs.getObject(column_name)); } json.put(obj); } return json;
Dengan mendapatkan terus objek daripada ResultSet menggunakan rs.getObject(column_name), kami menghapuskan keperluan untuk menyemak jenis lajur dan melaksanakan operasi khusus berdasarkannya .
Mengenai penggunaan memori, penyederhanaan juga menyumbang. Kod asal memperuntukkan contoh baharu JSONArray dan JSONObject untuk setiap baris dalam ResultSet, yang membawa kepada penggunaan memori yang tidak diperlukan. Kod yang dioptimumkan menggunakan semula kejadian ini, mengurangkan jejak memori.
Untuk mengoptimumkan lagi penggunaan memori, pertimbangkan untuk menggunakan StringBuilder untuk membina rentetan JSON secara berperingkat dan bukannya mencipta JSONObjects baharu untuk setiap baris. Pendekatan ini meminimumkan peruntukan memori sementara dan boleh meningkatkan prestasi dengan ketara untuk set hasil yang besar.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Menukar ResultSet kepada JSON dengan Cekap di Java?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!