
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();
特别是两行。。作用是什么啊=。= 展开
{
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();
特别是两行。。作用是什么啊=。= 展开
3个回答
展开全部
看这样子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中的代码。你的代码中的就是捕捉到异常直接打印异常。纯手打,累死了。
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中的代码。你的代码中的就是捕捉到异常直接打印异常。纯手打,累死了。
展开全部
stmt.setString(1,"男");
?是一个占位符,1代表第一个出现的?,其值为男
where ssex =? ");
stmt.setString(1,"男"); 代表查询条件为’男‘的
修改的话 把男改成女 就代表只查女的那类
?是一个占位符,1代表第一个出现的?,其值为男
where ssex =? ");
stmt.setString(1,"男"); 代表查询条件为’男‘的
修改的话 把男改成女 就代表只查女的那类
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
stmt.setString(1,"男");这句是将第一个占位符,也就是查询语句中的“?”,设置为“男”
ResultSet rs = stmt.executeQuery();这句定义一个结果集,这个结果集合就是执行了sql以后得到的内容
ResultSet rs = stmt.executeQuery();这句定义一个结果集,这个结果集合就是执行了sql以后得到的内容
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询