zoukankan      html  css  js  c++  java
  • DB2中sql语句占位符问题

    初到公司实习,让做一个网站,使用struts2+spring框架,数据库使用的是DB2,以前没接触过DB2,对它不了解。在写sql语句的时候遇到一些问题,首先就是在mysql下的limit到了DB2中需要改成fetch first 数字 rows only的形式。还有是在使用Spring的JdbcTemplate进行查询时sql语句占位符的问题,在where语句中使用"?"占位符是没有问题的,但是在这之外使用"?"占位符就会出现问题。

    sql如下:

    select USER_NAME,PIC_URL,COUNTY_NAME,STAR_RANK,NEW_BUSI_RANK,REDEEM_RANK,POPULAR_RANK
    from TF_SERVSTAR_RANK_DETAIL as a,
    TF_SERVSTAR_RACE_USER as b
    where b.USER_TYPE = ? and a.BOSS_ID = B.BOSS_ID 
    order by ? desc 
    fetch first ? rows only

    这样执行时会报错,提示占位符“?”是非法字符。在网上查了资料,说在where语句之外的地方需要使用类似cast(? as varchar(8))的形式来显式的转换为指定类型,但是我给"limit"的整数使用 cast(? as integer)的形式时还是会报错。由于我对DB2不熟,也没找到解决的办法,最后只能使用拼接字符串的形式将整数传过去。

    去到公司才知道自己在学校学的知识基本没用额,虽然自己也自学了ssh2等开源框架,但是由于平时练习的不够,很多知识都记不太清除了,导致我的开发速度很慢.....还有就是数据方面的知识,由于经验少,写的sql效率都不高,平时自己也只是用用mysql,去到公司发现都是使用的oracle和db2。希望在公司实习的这几个月能够提升自己的能力,就要毕业了,我选择了实习而不是培训,就是想到企业中去接触一下真实的项目开发流程,积累一些开发经验,所以越是困难的问题,我就应该越是认真的攻克它!

  • 相关阅读:
    微信小程序上传文件(报错处理方式)
    自绘 TreeDataView 控件
    C# 读取outlook 本地签名
    【英雄帖】FreeRedis 邀请您一起优化项目。
    (30)ASP.NET Core3.1 集成Apollo快速安装与使用
    C#引用fo-dicom读取dicom文件异常
    .NET 开源导入导出库 Magicodes.IE 2.5发布
    WinUI 3 Preview 3 发布了,再一次试试它的性能
    Aspose.Word for DotNet 定位到每页,画笔 移动到某页。
    .NET Core下好用的FTP框架 FluentFTP
  • 原文地址:https://www.cnblogs.com/jdluojing/p/3212413.html
Copyright © 2011-2022 走看看