[sql] SQLite는 비어있는 곳을 선택합니까?

SQLite에서 some_column이 비어있는 레코드를 어떻게 선택할 수 있습니까?
비어 있으면 NULL과 “”로 간주됩니다.



답변

다음과 같은 여러 가지 방법이 있습니다.

where some_column is null or some_column = ''

또는

where ifnull(some_column, '') = ''

또는

where coalesce(some_column, '') = ''

where ifnull(length(some_column), 0) = 0


답변

간단히 할 수있는 것 같습니다.

SELECT * FROM your_table WHERE some_column IS NULL OR some_column = '';

테스트 케이스 :

CREATE TABLE your_table (id int, some_column varchar(10));

INSERT INTO your_table VALUES (1, NULL);
INSERT INTO your_table VALUES (2, '');
INSERT INTO your_table VALUES (3, 'test');
INSERT INTO your_table VALUES (4, 'another test');
INSERT INTO your_table VALUES (5, NULL);

결과:

SELECT id FROM your_table WHERE some_column IS NULL OR some_column = '';

id
----------
1
2
5    


답변

어쩌면 당신은 의미

select x
from some_table
where some_column is null or some_column = ''

하지만 당신이 정말로 질문하지 않았기 때문에 나는 말할 수 없습니다.


답변

다음과 같이 할 수 있습니다.

int counter = 0;
String sql = "SELECT projectName,Owner " + "FROM Project WHERE Owner= ?";
PreparedStatement prep = conn.prepareStatement(sql);
prep.setString(1, "");
ResultSet rs = prep.executeQuery();
while (rs.next()) {
    counter++;
}
System.out.println(counter);

이렇게하면 열 값이 null이거나 비어있는 행 수가 표시됩니다.


답변