sql java语句

publicclasstestDBprepare{publicstaticvoidmain(String[]args){System.out.print("thisisa... public class testDBprepare
{
public static void main (String[] args)
{
System.out.print(" this is a test ");
try
{
Class.forName("org.postgresql.Driver").newInstance();
String url = "jdbc:postgresql://localhost:5432/postgres";
Connection con = DriverManager.getConnection(url,"postgres","123");
PreparedStatement stmt = con.prepareStatement("select * from student where ssex =? ");
stmt.setString(1,"男");
ResultSet rs = stmt.executeQuery();
while (rs.next())
{
System.out.print(rs.getInt(1));
System.out.println(rs.getString(2));
}
rs.close();
stmt.close();
con.close();
}
catch (Exception ee)
{
System.out.print(ee.getMessage());
}
}
}

这里边的语句都是什么意思啊?

如果查询、修改的话改哪里啊。
stmt.setString(1,"男");
ResultSet rs = stmt.executeQuery();
特别是两行。。作用是什么啊=。=
展开
 我来答
辟谷老僧
2013-06-28
知道答主
回答量:15
采纳率:0%
帮助的人:16.7万
展开全部
看这样子LZ似乎是完全不懂java啊,那我就说的详细点。

Class.forName("org.postgresql.Driver").newInstance(); 装载数据库驱动
String url = "jdbc:postgresql://localhost:5432/postgres";
Connection con = DriverManager.getConnection(url,"postgres","123");
配置数据库,并获得链接。上面三句数据库,用户名密码都不变的话是可以通用的。
PreparedStatement stmt = con.prepareStatement("select * from student where ssex =? ");
stmt.setString(1,"男");
这一句是使用动态查询 select * from student where ssex =? 这就是你将要向数据库发送的查询语句,其中?是通配符。stmt.setString(1,"男");这一句就是设定统配符,将第一个?替换成“男”,
这个时候你将要发送的语句就是select * from student where ssex ='男'。
ResultSet rs = stmt.executeQuery();
stmt.executeQuery();就是向数据库发送查询语句并将结果传到 类型为ResultSet 的对象中。
while (rs.next())
{
System.out.print(rs.getInt(1));
System.out.println(rs.getString(2));
}
这一段就是循环了,从得到的第一个结果开始循环,将每一个循环到的结果打印出来。
rs.close();
stmt.close();
这个就是关闭数据库的连接释放资源啦。

至于下面这个你一定注意到了。
try{
(其中是你的代码)
}catch (Exception ee)
{
System.out.print(ee.getMessage());
}
这个分成两部分,一个是try的{}中的代码,一个是catch{}中的代码。作用就是使虚拟机监控try中语句的运行,当发生异常时会根据捕捉到的异常执行catch中的代码。你的代码中的就是捕捉到异常直接打印异常。纯手打,累死了。
伊人不在212
2013-06-28
知道答主
回答量:8
采纳率:0%
帮助的人:2.6万
展开全部
stmt.setString(1,"男");
?是一个占位符,1代表第一个出现的?,其值为男
where ssex =? ");
stmt.setString(1,"男"); 代表查询条件为’男‘的
修改的话 把男改成女 就代表只查女的那类
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友d384eac
2013-06-28
知道答主
回答量:23
采纳率:0%
帮助的人:26.2万
展开全部
stmt.setString(1,"男");这句是将第一个占位符,也就是查询语句中的“?”,设置为“男”
ResultSet rs = stmt.executeQuery();这句定义一个结果集,这个结果集合就是执行了sql以后得到的内容
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式