oracle同样的sql结果不稳定,Java程序和在Oracle数据库中调用相同的SQL查询语句,结果却不相同解决方法...

本文探讨了一段Java程序通过预编译的SQL查询从Oracle数据库获取学生信息的问题,发现查询结果与直接在数据库中执行SQL语句得到的结果不一致。问题可能涉及日期格式处理、时区差异或数据库配置。分析并解决此类问题对于确保数据一致性至关重要。
摘要由CSDN通过智能技术生成

Java程序和在Oracle数据库中调用相同的SQL查询语句,结果却不相同

同样数据查询语句,利用Java程序调用的结果为什么和在Oracle数据库查询的结果不相同?以下是我的Java代码调用的数据库后返回的结果和SQL语句及在该SQL语句下的查询结果,两个结果为什么不相同呢?求解!

package org.programming.student;

import java.sql.*;

import java.text.ParseException;

import java.text.SimpleDateFormat;

import java.util.*;

public class StudentsManagerImpl implements StudentsManager

{

public ArrayList getStudentList(java.util.Date beginDate, java.util.Date endDate)

{

String sql =

"select stu_id, class_name, c.class_id, stu_name, sex, birthday, contactTel, address"+

" from students stu join class c on stu.class_id = c.class_id where stu.birthday between ? and ?";

Connection conn = null;

PreparedStatement psmt = null;

ResultSet res = null;

ArrayList stu_list = new ArrayList();

try

{

conn = DBUtil.getConnection();

psmt = conn.prepareStatement(sql);

psmt.setDate(1, new java.sql.Date(beginDate.getTime()));

psmt.setDate(2, new java.sql.Date(endDate.getTime()));

res = psmt.executeQuery();

while(res.next())

{

Student student = new Student();

student.setStudentId(res.getString("stu_id"));

student.setName(res.getString("stu_name"));

student.setSex(res.getString("sex"));

student.setBirthday(res.getDate("birthday"));

student.setContactTel(res.getString("contacttel"));

student.setAddress(res.getString("address"));

Clas clas = new Clas();

clas.setClassName(res.getString("class_name"));

clas.setClassId(res.getString("class_id"));

student.setClas(clas);

stu_list.add(student);

}

}

catch(SQLException e)

{

e.printStackTrace();

}

return stu_list;

}

public static void main(String[] args) throws ParseException

{

StudentsManagerImpl stu_manager = new StudentsManagerImpl();

ArrayList list =

stu_manager.getStudentList(new SimpleDateFormat("yyyy-mm-dd").parse("1988-01-01"), new SimpleDateFormat("yyyy-mm-dd").parse("1992-11-2"));

System.out.println("符合条件的学生人数为:"+list.size());

}

}

控制台显示的结果:

1509066.png

在oracle数据库中查询的SQL语句:

alter session nls_date_format = 'yyyy-mm-dd';

select stu_id, class_name, c.class_id, stu_name, sex, birthday, contactTel, address

from students stu join class c on stu.class_id = c.class_id

where stu.birthday between '1988-01-01' and '1992-11-2';

查询的结果:

STU_ID       CLASS_NAME CLASS_ID STU_NAME             SEX BIRTHDAY    CONTACTTEL  ADDRESS

------------ ---------- -------- -------------------- --- ----------- ----------- ------------------------------

200901332356 四年忠班   1        罗箫                 男  1991/12/23  13800372278 天津市静海县

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值