استعلامات SQL الفعالة IN () باستخدام JDBCTemplate لـ Spring
لديك استعلام IN () يجعلك تقوم حاليًا ببناء جملة تحتوي على أسطر متعددة الكود:
StringBuilder jobTypeInClauseBuilder = new StringBuilder(); for(int i = 0; i < jobTypes.length; i ) { Type jobType = jobTypes[i]; if(i != 0) { jobTypeInClauseBuilder.append(','); } jobTypeInClauseBuilder.append(jobType.convert()); }
أنت تبحث عن طريقة أكثر أناقة تشبه استبدال معلمات البيانات المعدة.
استخدام مصدر معلمة
لتحقيق الأناقة المطلوبة ، يمكنك استخدام مصدر المعلمة:
Setids = ...; MapSqlParameterSource parameters = new MapSqlParameterSource(); parameters.addValue("ids", ids); List foo = getJdbcTemplate().query("SELECT * FROM foo WHERE a IN (:ids)", parameters, getRowMapper());
NamedParameterJdbcTemplate
لاحظ أن هذا يعمل فقط إذا قامت getJdbcTemplate() بإرجاع مثيل من النوع NamedParameterJdbcTemplate.
تنصل: جميع الموارد المقدمة هي جزئيًا من الإنترنت. إذا كان هناك أي انتهاك لحقوق الطبع والنشر الخاصة بك أو الحقوق والمصالح الأخرى، فيرجى توضيح الأسباب التفصيلية وتقديم دليل على حقوق الطبع والنشر أو الحقوق والمصالح ثم إرسالها إلى البريد الإلكتروني: [email protected]. سوف نتعامل مع الأمر لك في أقرب وقت ممكن.
Copyright© 2022 湘ICP备2022001581号-3