Всегда становится ложным, читая поля из MySQLJAVA

Программисты JAVA общаются здесь
Ответить Пред. темаСлед. тема
Anonymous
 Всегда становится ложным, читая поля из MySQL

Сообщение Anonymous »

У меня есть этот код: < /p>

Код: Выделить всё

@Service
@RequiredArgsConstructor
public class DeviceService {

private static final LoggerWrapper logger = LoggerWrapper.getLogger(DeviceService.class);
private final UserHistoryMobileDeviceRepository userHistoryMobileDeviceRepository;

public List getDeviceData(long userId) {

logger.info(String.format("fetching device data for userId: %d", userId));
return userHistoryMobileDeviceRepository.findByUserId(userId).stream()
.map(currentRecord -> {

logger.info(String.format("Device from DB - deviceId: %s, isPrimary: %s",
currentRecord.getDeviceUid(),
currentRecord.getDeviceIsPrimary()));

return DeviceData.builder()
.deviceId(currentRecord.getDeviceUid())
.isPrimary(Objects.equals(currentRecord.getDeviceIsPrimary(), IS_PRIMARY_Y))
.build();
})
.toList();
}
}
< /code>
Класс объектов: < /p>
import jakarta.persistence.Column;
import jakarta.persistence.Entity;
import jakarta.persistence.GeneratedValue;
import jakarta.persistence.GenerationType;
import jakarta.persistence.Id;
import jakarta.persistence.Table;
import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Builder.Default;
import lombok.Getter;
import lombok.NoArgsConstructor;
import lombok.Setter;

@Builder
@Entity
@Table(name = "tbl_user_history_mobile_devices")
@Getter
@Setter
@AllArgsConstructor
@NoArgsConstructor
public class UserHistoryMobileDevice {

@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;

@Column(name = "fk_user_id")
private long userId;

@Column(name = "device_uid")
private String deviceUid;

@Column(name = "is_primary")
@Default
private String deviceIsPrimary = "N";

}

< /code>
Проблема в этом журнале:
Device from DB - deviceId: %s, isPrimary: %s< /code>
всегда печатает:
"message"=>"Device from DB - deviceId: 02dxxxxx59axx, isPrimary: N"}

Даже когда база данных имеет значение y
Кроме того, это более удивительно, заключается в том, что она работает над непрофюшерской средой, сталкиваясь только с этой проблемой только на env.
. Версия на PROD и не-продочной < /li>
[*] Private String DeviceIsprimary была логическим, таким образом, изменил ее на строку. И в коде, измененный в сборке с .isprimary (currentRecord.getDeviceisPrimary () на: .isprimary (objects.equals (currentRecord.getDeviceisPrimary (), is_primary_y)
[*] Проверенный продукт и непредна Не продлить:

Код: Выделить всё

is_primary
enum ('y', 'n') contraTe utf8mb3_unicode_ci не null default 'n', `

и iSprimary на Prod:

Код: Выделить всё

# Field Type    Null    Key Default Extra

is_primary  enum('Y','N')   NO  MUL N
Любой лидер>

Подробнее здесь: https://stackoverflow.com/questions/796 ... from-mysql
Реклама
Ответить Пред. темаСлед. тема

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение

Вернуться в «JAVA»