- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我们目前正在为类(class)开发一个用户管理系统,我们编写了一个后端 spring 应用程序,将密码、姓名、电子邮件和角色保存在 mysql 数据库中。
我们在更新用户表中的行时遇到问题。错误是
SQLException:截断不正确的 DOUBLE 值:'test@test.de'
test@test.de
是一个字符串,在数据库中保存为varchar (1024)。在 Spring 中,我们有一个实体类,其中电子邮件显然也作为字符串声明。查询是来自 CrudRepository
的标准 save()
方法。
//编辑
看来,这是mysql内部的问题。我通过 HeidiSQL 登录数据库并尝试手动更改任何值,但我遇到了同样的错误。
以下是 mysql 表:
用户实体类:
@Entity
@Table(name = "user")
public class UserEntity {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name = "ID")
private int id;
@Column(name = "Name")
private String name;
@Column(name = "Email")
private String email;
@Column(name = "Password")
private String password;
@Transient
@JsonInclude
private List<RoleEntity> roles;
...(Getter and Setter Methods) ...
更新方法位于 @Service
类中,并从 @RestController
HttpRequest 方法中调用。我不认为,rest Controller 或 CrudRepository 有问题,因为 RestController 只是调用这个函数而 CrudRepository 是空的。
服务更新方法:
/**
* Edits the user with the provided userid, but only those,
* which are not null.
*
* @param entity UserEntity containg to be edited informations, will override roles.
* @return Error if to be edited params are wrong or new userEntity.
*/
public ResponseEntity editUser(UserEntity entity) {
Optional<UserEntity> userEntityOptional = userRepository.findById(entity.getId());
if (userEntityOptional.isPresent() == false) {
return new ResponseEntity(new ErrorResponse("Invalid userid"), HttpStatus.BAD_REQUEST);
}
//check if all parameters are
UserEntity toBeEdited = userEntityOptional.get();
if(entity.getEmail() != null){
toBeEdited.setEmail(entity.getEmail());
//return new ResponseEntity(new ErrorResponse("No email modification allowed"), HttpStatus.BAD_REQUEST);
}
if (entity.getName() != null) {
if (entity.getName().length() < 2) {
return new ResponseEntity(new ErrorResponse("Name too short"), HttpStatus.BAD_REQUEST);
}
toBeEdited.setName(entity.getName());
}
if (entity.getPassword() != null) {
if (entity.getPassword().length() < 8) {
return new ResponseEntity(new ErrorResponse("Password too short"), HttpStatus.BAD_REQUEST);
}
toBeEdited.setPassword(BCrypt.hashpw(entity.getPassword(), BCrypt.gensalt()));
}
if (entity.getRoles() != null) {
// Create list for user to role mapping.
List<RoleUserEntity> roleUserEntities = new ArrayList<>();
for (RoleEntity role : entity.getRoles()) {
RoleEntity roleEntity = roleRepository.findByRoleAndDomain(role.getRole(), role.getDomain());
if (roleEntity == null) {
// return error
return new ResponseEntity(new ErrorResponse("Role \"" + role.getRole() + "\" does not exist in domain \"" + role.getDomain() + "\""), HttpStatus.BAD_REQUEST);
}
RoleUserEntity roleUserEntity = new RoleUserEntity();
roleUserEntity.setRoleId(roleEntity.getId())
.setUserId(toBeEdited.getId());
roleUserEntities.add(roleUserEntity);
}
// Override all Userroles
roleUserRepository.deleteAllByUserId(toBeEdited.getId());
roleUserRepository.saveAll(roleUserEntities);
}
userRepository.save(toBeEdited);
// Get user for returning.
Optional<UserEntity> userEntityResponse = userRepository.findById(entity.getId());
return new ResponseEntity(createUserResponseWithMessage(userEntityResponse.get(), "User Edited"), HttpStatus.OK);
}
最佳答案
It seems like, this is a problem within mysql. I logged in via HeidiSQL on the database and tried changing any values manually, but I got the same error.
是的,这是 mysql 中的一个问题。另一个团队在此数据库中使用了触发器,当使用 UPDATE
命令时,它会在另一个数据库中创建额外的行。
这些触发器看起来像这样:
BEGIN
UPDATE otherdatabase.user
SET email = NEW.Email AND password = NEW.Password AND username = NEW.Name
WHERE id = OLD.ID;
END
这里的问题是 SET
短语中的 AND
。在 SET
短语中,必须使用逗号代替 AND
。
另一个关于“不要让任何人弄乱你的数据库”的故事。
关于java - MySQL 截断不正确的 DOUBLE 值 : 'string' in Java Spring Repository,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56299155/
在过去的几个月里,我一直在使用 Bzr 对我的项目进行版本控制。我是唯一的开发人员,目前我只有一个本地项目目录中的所有内容,我提交并同步到 DriveHQ。 我现在想到了一些可能会打破这条主线的大规模
我在一个多模块项目中使用 Maven 3.2.3。我想生成一个 checkstyle 和 findbugs 报告,所以我配置了以下内容:
我注意到 Repository 通常通过以下任一方式实现: 方法一 void Add(object obj); void Remove(object obj); object GetBy(int id
关闭。这个问题不满足Stack Overflow guidelines .它目前不接受答案。 想改善这个问题吗?更新问题,使其成为 on-topic对于堆栈溢出。 5年前关闭。 Improve thi
这是我的设置的详细信息: Gitlab 版本:5.2操作系统:Centos 6.3我在创建新项目 (/projects/new) 时导入现有存储库。 创建了一个新的 EMPTY 项目,但是没有导入存储
我的文件夹结构如下: repo1 | |---file1 |---fold1 | |---file2 |---repo2 | | |---file3 假设我有两
假设我有一个 TeacherRepository,需要根据下面的代码使用 CourseRepository。 Teacher 和 Course 形成多对多的关系。教师和类(class)不形成聚合。您会
我要同样的 repositories我在 buildscript.repositories 中指定的阻止与依赖项相同的存储库 repositories堵塞。请看我的例子: 正常 buidldscrip
是否使用 @EnableJpaRepositories 或 jpa:repositories(在 xml 上)让开发人员不要使用 Spring 的 @Repository 标签?当我查看 Spring
我是 git 和 Github 的新手。我已经了解了很多术语(推送、 pull 、提交、分支等),但我将主要使用通俗的说法来解释我最初的期望。 我假设过程是: 1.) Create a git rep
安装 Nexus Repository Manager OSS 3 后,我没有看到用于通过网页上传工件的选项Artifact Upload。 在 Nexus Repository Manager OS
CMS 和 DMS 有什么区别?两者都存储日期,可以访问数据,它们有什么不同?可以使用 apache Jack Rabbit 代替 Alfresco 吗? 最佳答案 我会根据管理数据的可变性来区分这两
在我的earlier question我问的是如何为使用 EF 等 ORM 框架构建的大型应用程序实现存储库/工作单元模式。 我现在无法解决的一个后续问题是将包含业务逻辑的代码放在哪里,但仍然足够低级
我正在尝试为 nuget git 存储库(我刚刚从中克隆)创建 pull 请求。我已经进行了本地提交。 但是当我尝试创建 pull 请求时,出现以下错误: Could not find any rel
我已经看到了下面的问题。 git diff between cloned and original remote repository 我的问题是如何在 SourceTree 中看到这个差异结果(而不
我在通过 Subversion (SVN) 中的 checkin 自动在 Review Board 中创建新的评论条目时遇到了困难。我创建了一个提交后 Hook ,当手动运行时会出现以下异常: Fai
我在尝试集成 Spring Data 时遇到此错误。完整的堆栈跟踪是 nested exception is org.xml.sax.SAXParseException; systemId: http
通知:https://docs.aws.amazon.com/codecommit/latest/userguide/how-to-repository-email.html 触发器:https://
我正在学习 Laravel 中的存储库设计模式,我正在使用 https://github.com/andersao/l5-repository去做这件事。 但是在我将文件夹 prettus 复制/粘贴
我最近开始了一个使用现有数据库(Oracle)和 MVC 4 的项目。已经进行了很多编码..但是代码中没有“策略”..只有 DB -> ORM -> Controller。因此,我正在尝试为开发添加一
我是一名优秀的程序员,十分优秀!