development

“0”과“1”을 거짓과 참으로 변환하는 방법

big-blog 2020. 10. 6. 08:26
반응형

“0”과“1”을 거짓과 참으로 변환하는 방법


Odbc를 통해 데이터베이스에 연결하는 방법이 있습니다. 내가 호출하는 저장 프로 시저에는 데이터베이스 측에서 'Char'인 반환 값이 있습니다. 지금은 반환 값을 문자열로 잡고 간단한 if 문에서 사용하고 있습니다. 데이터베이스에서 0과 1이라는 두 개의 값만 반환 될 때 이와 같은 문자열을 비교하는 아이디어가 정말 마음에 들지 않습니다.

OdbcCommand fetchCommand = new OdbcCommand(storedProc, conn);

fetchCommand.CommandType = CommandType.StoredProcedure;
fetchCommand.Parameters.AddWithValue("@column ", myCustomParameter);
fetchCommand.Parameters.Add("@myReturnValue", OdbcType.Char, 1)
            .Direction = ParameterDirection.Output;
fetchCommand.ExecuteNonQuery();

string returnValue = fetchCommand.Parameters["@myReturnValue"].Value.ToString();
if (returnValue == "1")
{
    return true;
} 

이 상황을 처리하는 올바른 방법은 무엇입니까? 나는 명백한 대답처럼 보이는 'Convert.ToBoolean ()'을 시도했지만 '문자열이 유효한 부울로 인식되지 않았습니다. '예외가 발생했습니다. 여기에 뭔가 빠졌거나 '1'과 '0'이 참과 거짓처럼 작동하도록 만드는 다른 방법이 있습니까?

감사!


어때 :

return (returnValue == "1");

또는 아래 제안 된대로 :

return (returnValue != "0");

올바른 것은 성공 결과로 무엇을 찾고 있는지에 달려 있습니다.


한 줄의 코드에서 :

bool bVal = Convert.ToBoolean(Convert.ToInt16(returnValue))

변환이 항상 성공하기를 원한다면 문자열을 변환하는 가장 좋은 방법 (Kevin처럼) "1"as true및 다른 모든 것을 고려 하는 것입니다 false. "1"또는 이외의 항목 "0"이 반환되는 경우 변환이 실패하도록 하려면 다음으로 충분합니다 (도우미 메서드에 넣을 수 있음).

if (returnValue == "1")
{
    return true;
}
else if (returnValue == "0")
{
    return false;
}
else
{
    throw new FormatException("The string is not a recognized as a valid boolean value.");
}

반환 유형을 숫자로 설정-문자가 필요하지 않으므로 사용하지 마십시오. Convert.ToBoolean (num)을 사용하여 숫자 값 (0/1)을 변환 할 수 있습니다.

그렇지 않으면 : Kevin의 대답을 사용하십시오.


해당 양식을 사용할 수 있습니다.

return returnValue.Equals("1") ? true : false;

또는 더 간단하게 (Jurijs Kastanovs에게 감사드립니다) :

return returnValue.Equals("1");

또는 부울 값이 반환되지 않은 경우 다음과 같이 할 수 있습니다.

bool boolValue = (returnValue == "1");

내 솔루션 (vb.net) :

Private Function ConvertToBoolean(p1 As Object) As Boolean
    If p1 Is Nothing Then Return False
    If IsDBNull(p1) Then Return False
    If p1.ToString = "1" Then Return True
    If p1.ToString.ToLower = "true" Then Return True
    Return False
End Function

(returnValue != "1" ? false : true);

변환하고 싶지 않다면 그냥 사용하세요;

 bool _status = status == "1" ? true : false;

Perhaps you will return the values as you want.

참고URL : https://stackoverflow.com/questions/2648074/how-to-convert-0-and-1-to-false-and-true

반응형