Named query not found: (包扫描的问题)

本文介绍了一种常见问题——在尝试使用NamedQuery时遇到NamedQuery not found错误的原因及解决方法。作者通过排查发现,问题根源在于配置文件中指定的实体类扫描路径不正确,修复路径后问题得以解决。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

今天在服务器上发布了个新系统,登录的时候提示Named query not found:

java.lang.IllegalArgumentException: Named query not found: User.findByUsername

看了一下entity包中的User类,NamedQuery是定义好的,那为什么提示找不到Named query呢?

想起昨天调试的时候也遇到过这个问题,既然实体类本身没问题,那么问题肯定出在其他环节。

也就是说,光实体类中定义了Named Query还不够,还要有其他类通过什么方式把它加载进来,那么问题就出在加载这个环节。

在几个环节都查了一遍,找到了原因:

在app-context.xml中,“packagesToScan” 这个节点是用来扫描实体类,加载Named Query的,并且这里的包名写错了,还是用的旧包,而项目里实际已经换了新包:

<property name="packagesToScan" value="com.vict.manage.*.entity" />


参照新的包结构,修改这个节点

修改如下:

<property name="packagesToScan" value="com.vict.web1.entity" />

重启,问题解决!


Error starting ApplicationContext. To display the conditions report re-run your application with 'debug' enabled. 2025-04-01 14:54:06.566 ERROR 36552 --- [ main] o.s.boot.SpringApplication : Application run failed org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'datebasechangeListener' defined in file [C:\Users\19242\IdeaProjects\KafkaTest\target\classes\com\ccssoft\LIstener\DatebasechangeListener.class]: Unsatisfied dependency expressed through constructor parameter 0; nested exception is org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'kafkaProducerService' defined in file [C:\Users\19242\IdeaProjects\KafkaTest\target\classes\com\ccssoft\service\KafkaProducerService.class]: Unsatisfied dependency expressed through constructor parameter 2; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'alarmOutDevRepository' defined in com.ccssoft.Repository.AlarmOutDevRepository defined in @EnableJpaRepositories declared on JpaRepositoriesRegistrar.EnableJpaRepositoriesConfiguration: Invocation of init method failed; nested exception is org.springframework.data.repository.query.QueryCreationException: Could not create query for public abstract void com.ccssoft.Repository.AlarmOutDevRepository.updateIsSendStatus(java.lang.Long,int); Reason: Using named parameters for method public abstract void com.ccssoft.Repository.AlarmOutDevRepository.updateIsSendStatus(java.lang.Long,int) but parameter 'Optional[status]' not found in annotated query 'update Alarmoutdev SET issend = status where id =:id'!; nested exception is java.lang.IllegalStateException: Using named parameters for method public abstract void com.ccssoft.Repository.AlarmOutDevRepository.updateIsSendStatus(java.lang.Long,int) but parameter 'Optional[status]' not found in annotated query 'update Alarmoutdev SET issend = status where id =:id'! 什么问题
04-02
### 解决 CUDA 'named symbol not found' 错误的方法 当遇到 `named symbol not found` 的错误时,这通常意味着某些必要的库文件未能正确加载或路径设置不正确。具体到 PyTorch 和 CUDA 环境下,此类问题可能源于环境变量配置不当、驱动版本兼容性或其他系统级因素。 #### 检查并更新 NVIDIA 驱动程序 确保安装的是最新版的NVIDIA显卡驱动,并且与当前使用的CUDA Toolkit 版本相匹配[^2]。可以通过官方渠道下载适合操作系统的稳定版本来完成升级工作。 #### 设置正确的环境变量 对于 Linux 用户来说,在从 suspend 模式恢复后可能会丢失一些重要的环境变量设定,特别是 `LD_LIBRARY_PATH` 或者 `PATH` 中关于 CUDA 库的位置信息。建议将这些变量固定写入 `.bashrc` 文件中: ```bash export PATH=/usr/local/cuda/bin:$PATH export LD_LIBRARY_PATH=/usr/local/cuda/lib64:$LD_LIBRARY_PATH ``` 重启终端使更改生效,或者直接 source 当前 shell session: ```bash source ~/.bashrc ``` #### 重新启动 Python 进程 有时简单的解决方案就是终止现有的Python进程然后再新开一个实例尝试调用GPU资源。这是因为一旦PyTorch检测到了可用设备列表就不会再改变直到下次初始化为止[^1]。 #### 安装或重置 cuDNN 如果仍然存在未解决问题,则可能是由于cuDNN库损坏造成的。可以从[NVIDIA官网](https://developer.nvidia.com/rdp/cudnn-archive)获取对应于所使用CUDA版本的预编译二进制进行替换安装。 #### 使用虚拟环境隔离依赖关系 创建一个新的 conda 虚拟环境专门用于管理项目所需的特定版本软件栈,从而减少不同工具链之间潜在冲突的可能性: ```bash conda create --name myenv python=3.x conda activate myenv pip install torch torchvision torchaudio cudatoolkit=x.x ``` 通过上述措施往往能够有效缓解乃至彻底消除类似的链接失败情况发生。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小鹰信息技术服务部

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值