bende bir tane var String[]
String[] name = {"amit", "rahul", "surya"};
IN yan tümcesinde sql sorgusunda parametre olarak adı göndermek istiyorum, bu yüzden bir formata nasıl dönüştürebilirim
'amit','rahul','surya'
bende bir tane var String[]
String[] name = {"amit", "rahul", "surya"};
IN yan tümcesinde sql sorgusunda parametre olarak adı göndermek istiyorum, bu yüzden bir formata nasıl dönüştürebilirim
'amit','rahul','surya'
Yanıtlar:
if (name.length > 0) {
StringBuilder nameBuilder = new StringBuilder();
for (String n : name) {
nameBuilder.append("'").append(n.replace("'", "\\'")).append("',");
// can also do the following
// nameBuilder.append("'").append(n.replace("'", "''")).append("',");
}
nameBuilder.deleteCharAt(nameBuilder.length() - 1);
return nameBuilder.toString();
} else {
return "";
}
String.join(...)ya TextUtils.join(...)?
Ya kendiniz basit bir yöntem yazın ya da oradaki çeşitli yardımcı programlardan birini kullanın.
Ben şahsen apache StringUtils ( StringUtils.join ) kullanıyorum
düzenleme: Java 8'de artık buna ihtiyacınız yok:
String joined = String.join(",", name);
StringUtils.join(names,',');
String list = "'" + StringUtils.join(names,"','") + "'";bu size SQL isteğinin ihtiyaç duyduğu Tek tırnakları verecektir.
TextUtils.join(",", stringArrayOfEmails)
Android geliştiricileri muhtemelen TextUtils.join'i arıyor
Android dokümanları: http://developer.android.com/reference/android/text/TextUtils.html
Kod:
String[] name = {"amit", "rahul", "surya"};
TextUtils.join(",",name)
Güzel ve basit: ama java8 gerekli!
String result = String.join(",", names);
StringBuilder sb = new StringBuilder();
for (String n : name) {
if (sb.length() > 0) sb.append(',');
sb.append("'").append(n).append("'");
}
return sb.toString();
TextUtils.join(...)mi? Sanırım bir satır kodu, beş satırdan daha iyi ve daha basit.
org.apache.commons.lang.StringUtilsJava'da dize dizisinden virgülle ayrılmış bir sonuç oluşturmak için API'yi de kullanabilirsiniz .
StringUtils.join(strArr,",");
Guava kütüphanesini kullanarak da basitleştirebilirsiniz:
String[] name = {"amit", "rahul", "surya"};
String str = "'" + Joiner.on(",").skipNulls().join(name)
.replace(",", "','") + "'";
"amit,rahul,surya"?
Kullanım StringBuilderbunun içine dize [] ve ekleme her dize üzerinde ve tekrarlayın:
public static String convert(String[] name) {
StringBuilder sb = new StringBuilder();
for (String st : name) {
sb.append('\'').append(st).append('\'').append(',');
}
if (name.length != 0) sb.deleteCharAt(sb.length()-1);
return sb.toString();
}
String[] name = {"amit", "rahul", "surya"};
public static String arrayToString(String array[])
{
if (array.length == 0) return "";
StringBuilder sb = new StringBuilder();
for (int i = 0; i < array.length; ++i)
{
sb.append(",'").append(array[i]).append("'");
}
return sb.substring(1);
}
substring(1), ama ya eğer array.length == 0?
KULLANIM StringUtils.joinişlevi: Ör.
String myCsvString = StringUtils.join(myList, ",")
String[] paramIdIdList={"P001","P002","P003"};
StringBuilder builder = new StringBuilder();
for(String paramId : paramIdIdList) {
builder.append(paramId+",");
}
builder.deleteCharAt(builder.length() -1);
String paramIds = builder.toString();
System.Out.Println(paramIds );
Kodu olarak cazip ve "cool" görünebilir gibi, kullanmayın foldveyareduce bunlardan yaşayacaktır olarak, dizeleri büyük koleksiyonları üzerinde dize birleştirme sorunu
String[] strings = { "foo", "bar", "baz" };
Optional<String> result = Arrays.stream(strings)
.reduce((a, b) -> String.format("%s,%s", a, b));
System.out.println(result.get());
Bunun yerine, diğer yanıtlarda olduğu gibi, String.join()zaten bir koleksiyonunuz StringBuildervarsa veya yoksa a kullanın.
Ayrıca bu kadar basit bir işlem için StringBuilder'ı spawnlamamak isteyebilirsiniz. Ben adresinin dizinin adını değiştirdik unutmayınız isim için isimlerin içerik uygunluk uğruna:
String[] names = {"amit", "rahul", "surya"};
String namesString = "";
int delimeters = (names.size() - 1);
for (String name : names)
namesString += (delimeters-- > 0) ? "'" + name + "'," : "'" + name + "'";
For () döngüsünü dikey olarak aralıklandırmayı pek umursamıyorsanız, iki satır (bildirimler hariç; 'finalstring' başlangıçta boş bir dizeye eşit olarak bildirilmelidir):
for (int i = 0; i<string_array.length; i++) {finalstring += string_array[i]+",";}
finalstring = finalstring.substring(0,finalstring.length()-1);
İki satır, bitirdiniz. :)
burada bir diziyi bölmek ve özel sınırlayıcınızı koymak için bir Yardımcı Program yöntemi verilmiştir.
String.replace(String,String)
Arrays.toString(Object[])
işte burada :
public static String toString(String delimiter, Object[]array){
String s = "";
// split array
if (array != null && array.length > 0) {
s = Arrays.toString(array).replace("[", "").replace("]", "");
}
// place delimiter (notice the space in ", ")
if(delimiter != null){
s = s.replace(", ", delimiter);
}
return s;
}
ikinci bağımsız değişken türünü dizi türünüze uyacak şekilde değiştirin
Önceki Java 8 çözümü için uzantı
String result = String.join(",", name);
Dizi değerleri için öneke ve / veya son eke ihtiyacınız varsa
StringJoiner joiner = new StringJoiner(",");
for (CharSequence cs: name) {
joiner.add("'" + cs + "'");
}
return joiner.toString();
Veya basit yöntem kavramı
public static String genInValues(String delimiter, String prefix, String suffix, String[] name) {
StringJoiner joiner = new StringJoiner(delimiter);
for (CharSequence cs: name) {
joiner.add(prefix + cs + suffix);
}
return joiner.toString();
}
Örneğin
For Oracle i need "id in (1,2,3,4,5)"
then use genInValues(",", "", "", name);
But for Postgres i need "id in (values (1),(2),(3),(4),(5))"
then use genInValues(",", "(", ")", name);
Bu benim yardımcı olacağım !!!
private static String convertArrayToString(String [] strArray) {
StringBuilder builder = new StringBuilder();
for(int i = 0; i<= strArray.length-1; i++) {
if(i == strArray.length-1) {
builder.append("'"+strArray[i]+"'");
}else {
builder.append("'"+strArray[i]+"'"+",");
}
}
return builder.toString();
}
String[] name = {"O'Neill"};