java连接sqlserver,并通过生日(日期)搜索数据库中的数据

本文介绍了一种使用Java进行SQL日期类型数据查询的方法,并提供了具体的代码实现,包括如何设置日期参数及获取结果。

搜索int,string类型的数据都很简单,但是写到日期类型的时候就不知道怎么弄了,在csdn中提问后,才知道怎么弄,所以在这笔记下,下次用。

Code:
  1. package sqltest;   
  2.   
  3. import java.sql.Connection;   
  4.   
  5. import java.sql.DriverManager;   
  6. import java.sql.PreparedStatement;   
  7. import java.sql.ResultSet;   
  8. import java.sql.Date;   
  9. import java.text.SimpleDateFormat;   
  10.   
  11. import sqltest1.InputData;   
  12.   
  13. public class SqlTest {   
  14.         public static String driverName="com.microsoft.sqlserver.jdbc.SQLServerDriver";   
  15.         public static String dbURL="jdbc:sqlserver://localhost:1433;DatabaseName=test";   
  16.         public static String userName="sa";   
  17.         public static String userPwd="123";   
  18.     public static void main(String[] args) throws Exception {   
  19.         Connection conn=null;   
  20.         PreparedStatement pstmt=null;   
  21.         ResultSet result=null;    
  22.         Class.forName(driverName);   
  23.         conn=DriverManager.getConnection(dbURL,userName,userPwd);   
  24.         String sql="select pid,name,age,birthday,salary from person where birthday = ?";//name like ? or    
  25.         pstmt=conn.prepareStatement(sql);   
  26.         SimpleDateFormat f=new SimpleDateFormat("yyyy-MM-dd");   
  27.         java.util.Date d=null;   
  28.         d=f.parse("1990-05-04");   
  29.         pstmt.setDate(1,new java.sql.Date(d.getTime()));   
  30. //      String key1="xiaolong";   
  31. //      Date key2 = new Date(2011,04,01);   
  32. //      pstmt.setString(1,"%"+key1+"%");   
  33. //      pstmt.setDate(1,Date.valueOf("2011-04-01"));   
  34.         result=pstmt.executeQuery();   
  35.         while(result.next()){   
  36.             int pid=result.getInt(1);   
  37.             String name=result.getString(2);   
  38.             int age=result.getInt(3);   
  39.             float salary=result.getFloat(5);   
  40.             Date birthday=result.getDate(4);   
  41.             System.out.println(pid+" "+name+" "+age+" "+salary+" "+birthday);   
  42.         }   
  43.         result.close();   
  44.         pstmt.close();   
  45.         conn.close();   
  46.     }   
  47. }  

通过日期查找目前知道两种方法:

1:pstmt.setDate(1,Date.valueOf("2011-04-01"));

2:通过simpledateformat。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值