java的Sql中?号赋值的经典错误

1 篇文章 0 订阅
下午,在写sql语句时,我用?号赋值,我用了两个?号,但奇怪的是,就是取不到数据,但又不报异常,我把sql打印出来,粘到sql sever 2008后台去执行又可以,当时很无奈啊:
   
   String Log_Num = “GZ0666”;
   String [] paras = {"'"+Log_Num+"'","'"+Log_Num+"'"};  
   String Check_Type = " dep.id_sl = ? and wor.id_log = ?";     
   String sql = Log_SQL.getInstancex().All_Date(Database_Table, Check_Type,Database_Table_2);

Log_SQL类:
public String All_Date(String Database_Table_1, String Check_Type,String Database_Table_2){
String sql = Common_All_Sql()+" personnel_mi as dep, log_workers as wor where "+Check_Type;
return sql;
}
 
  public String Common_All_Sql(){

 
String sql= "select dep.id_sl 用户账号, dep.groups_sl 组别,dep.name_sl 用户姓名,wor.password_sl 用户密码,dep.post_sl 职位,dep.guest 访客权限, "+ " dep.common_purview 普通权限,dep.advanced_purview 高级权限,dep.admin_purview 管理员权限 "+ ",dep.gender 性别,dep.entry_date 入职日期,dep.identityx 身份证号,dep.age 年龄 ,dep.xieli 学历,dep.nation 民族 "+ ",
dep. birth_date 联系电话,dep.addressx 住址,dep.marriage 婚姻状况,dep.remark_sl 备注 from ";
 
return sql;
}
 

折腾了一下午,其中用了在右连接也不行,后面在Eclipse断点调试 ,也不知道什么原因,在后来,鑫鑫告诉我,这句话有问题,
String [] paras = {"'"+Log_Num+"'","'"+Log_Num+"'"};,参数两边不要加'号,因为 在preparestatement设置参数的时候会自动加上,
我修改成
String [] paras = {Log_Num,Log_Num};果然可以,在这里万分感谢鑫鑫,当然,还有海峰,牵牛大哥,还有 osc-徐航,
   陈鑫,小得意,生活有你们,我的世界很精彩,谢谢你们 。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 这个错误信息是指在 Java 试图将一个 long 类型的值转换为 java.sql.Timestamp 类型时出现了问题,因为这两种类型之间的转换是不支持的。 通常,java.sql.Timestamp 类型表示时间戳,其值是一个包含日期和时间信息的长整型数值,表示自 1970 年 1 月 1 日以来经过的毫秒数。如果要将一个 long 类型的值转换为 java.sql.Timestamp 类型,可以使用 java.sql.Timestamp 的构造函数来创建一个新的 java.sql.Timestamp 对象,例如: ``` long milliseconds = System.currentTimeMillis(); java.sql.Timestamp timestamp = new java.sql.Timestamp(milliseconds); ``` 这将创建一个新的 java.sql.Timestamp 对象,其值为当前时间戳。但是如果直接将 long 类型的值赋值java.sql.Timestamp 类型的变量,就会出现上述错误信息。 ### 回答2: unsupported conversion from long to java.sql.Timestamp 在Java编程,时间戳是从2019年1月1日开始计算的毫秒数,可以使用long类型来表示。而java.sql.Timestamp是Java表示时间戳的一个类,通常用于表示数据库的日期和时间数据。 当我们在程序需要将long类型的毫秒数转换为java.sql.Timestamp类型时,我们通常会使用如下代码: long time = 1575460274707L; //时间戳的毫秒表示 java.sql.Timestamp timestamp = new java.sql.Timestamp(time); //将long类型转换为Timestamp类型 但是,有时我们会遇到unsupported conversion from long to java.sql.Timestamp的异常,这是因为long类型和java.sql.Timestamp类型之间并没有直接的转换方式。 那么,如何解决这个异常呢? 一种常见的解决方案是使用java.util.Date类来转换时间戳。我们可以先将long类型的毫秒数转换为Date类型,然后再使用java.sql.Timestamp类将其转换为数据库的时间格式。例如: long time = 1575460274707L; //时间戳的毫秒表示 java.util.Date date = new java.util.Date(time); //将long类型转换为Date类型 java.sql.Timestamp timestamp = new java.sql.Timestamp(date.getTime()); //将Date类型转换为Timestamp类型 另外,如果我们使用的是JDBC 4.2及以上的版本,也可以使用新的方法toInstant()将java.sql.Timestamp类型转换为Java 8的时间类型Instant,然后再通过toEpochMilli()方法获取毫秒数。例如: java.sql.Timestamp timestamp = new java.sql.Timestamp(time); //获取一个java.sql.Timestamp对象 Instant instant = timestamp.toInstant(); //将Timestamp对象转换为Instant类型 long timeInMillis = instant.toEpochMilli(); //通过Instant对象获取毫秒数 总之,当我们在Java编程遇到unsupported conversion from long to java.sql.Timestamp的异常时,应该选择合适的方式将long类型的毫秒数转换为java.sql.Timestamp类型,以满足我们对时间戳的处理需求。 ### 回答3: 长整型数和时间戳是两种不同的数据类型,它们之间不能进行直接转换。在Java语言,时间戳是使用java.sql.Timestamp类来表示的,而长整型数通常使用Java的long类型表示。由于它们的数据类型不同,直接进行转换会导致Java编译器抛出“unsupported conversion from long to java.sql.timestamp”的错误。 解决这个问题的方法主要有两种:一种是使用java.util.Date类来代替long类型进行时间戳的转换,另一种是使用Java提供的日期格式化类进行时间戳和字符串之间的转换。下面分别介绍这两种方法的具体实现步骤。 1. 使用java.util.Date类转换 使用java.util.Date类进行时间戳转换的主要思路是利用Date类提供的构造函数将long类型的时间戳转换为Date对象,然后再将Date对象转换为java.sql.Timestamp类型。具体实现代码如下: ``` long time = System.currentTimeMillis(); // 获取当前时间戳 Date date = new Date(time); // 将长整型时间戳转换为日期对象 Timestamp timestamp = new Timestamp(date.getTime()); // 将日期对象转换为时间戳对象 ``` 2. 使用日期格式化类转换 Java提供了很多日期格式化类来处理时间和日期的转换。其,最常用的类是SimpleDateFormat类。这个类可以将时间戳转换为需要的日期格式的字符串,也可以将日期格式的字符串转换为时间戳。具体实现代码如下: ``` long time = System.currentTimeMillis(); // 获取当前时间戳 SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); // 定义日期格式 String strTime = sdf.format(new Date(time)); // 将时间戳转换为字符串 Timestamp timestamp = Timestamp.valueOf(strTime); // 将字符串转换为时间戳对象 ``` 总之,无论使用哪种方法,都要注意数据类型的匹配,以便正确地进行时间戳的转换。如果数据类型不匹配,就会出现编译错误,导致不能正确地进行转换。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值