0

我正在尝试构建一个字符串以将其作为 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。但事情似乎并不奏效。

关于问题出在哪里的任何输入?

4

5 回答 5

1

你应该在你的对象中覆盖方法 toString

于 2016-08-11T10:06:38.177 回答
1

您可以使用特定于 SQL 的 java Array

try (PreparedStatement stmt = connection.prepareStatement("... IN (?) ...")) {
    Object[] elements = ...
    stmt.setArray(1, connection.createArray("TEXT", elements));
    stmt.executeUpdate();
}
于 2016-08-11T10:14:49.563 回答
1

您遇到的问题是您隐式toString()使用. 默认情况下,该方法返回. 您应该覆盖您将在列表中使用的每个类中的方法,以便它返回您想要的内容。ObjectArrayListObjecttoString()

于 2016-08-11T10:18:03.100 回答
0

您可以将其另存为String,就像这段代码一样

ArrayList<String> arrayList = new ArrayList<>();

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

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

或者你想要它对象用于特定目的?

于 2016-08-11T10:22:43.943 回答
0

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

// 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));

我希望能解决这个问题,如果没有请告诉我,你可以将它用于多维数组

于 2016-08-11T13:25:35.577 回答