我正在尝试构建一个字符串以将其作为IN语句内的SQL查询传递。

ArrayList<Object[]> arrayList = new ArrayList<Object[]>();

    List<String> strings = new ArrayList<>(arrayList .size());
    for (Object object : arrayList ) {
        strings.add(Objects.toString(object, null));
    }

    System.out.println("askldnlkasdn"+strings);


这仍然会打印出内存位置,而不是实际的字符串

askldnlkasdn[[Ljava.lang.Object;@7bb11784, [Ljava.lang.Object;@33a10788, [Ljava.lang.Object;@7006c658, [Ljava.lang.Object;@34033bd0, [Ljava.lang.Object;@47fd17e3, [Ljava.lang.Object;@7cdbc5d3, [Ljava.lang.Object;@3aa9e816, [Ljava.lang.Object;@17d99928, [Ljava.lang.Object;@3834d63f, [Ljava.lang.Object;@1ae369b7]


我也尝试过
使用StringBuilder和StringUtils。但是事情似乎没有用。

关于问题出在哪里有什么投入吗?

最佳答案

这是新的代码,可能会有所帮助,

// Data of Array of Object for test the Code
    Object[] a = new Object[1];
    a[0] = "Hello";
    Object[] b = new Object[1];
    b[0] = "Friend";
    Object[] c = new Object[1];
    c[0] = "This is";
    Object[] d = new Object[1];
    d[0] = "Just Test";

    // The Array List of objects and the data entry
    ArrayList<Object[]> arrayList = new ArrayList<Object[]>();
    arrayList.add(a);
    arrayList.add(b);
    arrayList.add(c);
    arrayList.add(d);

    // New List of strings
    List<String> strings = new ArrayList<>(arrayList .size());


    // The Process of adding the data from array list of objects to the strings
    for(int i = 0; i < arrayList.size(); i++){
        strings.add((String) arrayList.get(i)[0]);
    }

    // Just for print the data to console
    for(int i = 0 ; i < strings.size(); i++){
        System.out.println(strings.get(i));
    }

    System.out.println("askldnlkasdn "+strings.get(0));


我希望解决该问题,如果不能解决,请通知我,您可以将其用于多个一维数组。

10-08 16:31