zoukankan      html  css  js  c++  java
  • Java连载135-JDBC执行SQL操作

    一、数据库的基本操作

    1.SQL语句四大类:

    • (1)数据查询/操纵/定义/控制语言(DQL/DML/DDL/DCL)
    • (2)增删改查CRUD

    2.查询数据

    • 利用Statement实例通过执行静态SELECT语句完成,也可以利用PreparedStatement实例通过执行SELECT语句进行完成,还可以利用CallableStatement实例通过执行存储过程来完成。
    • (1)利用Statement实例通过执行静态SELECT语句查询的代码示例:
    String sql = "select * from tb_record where sec=?";
    Statement stmt = con.createStatement();
    PreparedStatement pstmt = con.preparedStatement(sql);
    CallableStatement cstmt = con.prepareCall("(CALL demoSp(?,?))");
    
    • (2)利用PreaparedStatement实例通过执行动态SELECT语句查询数据的代码如下:
    String sql = "select * from tb_record where sec=?";
    PreparedStatement prpdStmt = connection.prepareStatement(sql);
    prpdStmt.setString(1,"男");
    ResultSet rs = prpdStmt.executeQuery();
    
    • (3) 利用CallableStatement实例通过执行存储过程查询数据的代码示例如下:
    String call = "(call pro_record_select_by_sex(?))";
    CallableStatement cablStmt = connection.prepareCall(call);
    calStmt.setString(1,"男");
    ResultSet rs = cablStmt.executeQuery();
    
    • 无论使用哪种方式,都需要执行executeQuery()方法,这时才是真正开始执行Select语句。
    package com.bjpowernode.java_learning;
    
    import java.beans.Statement;
    import java.sql.Connection;
    import java.sql.DriverManager;
    import java.sql.ResultSet;
    import java.sql.SQLException;
    
    public class D135_1_SelectExercise {
    	private static final String URL = "jdbc:Access:///e:/xsgl.mdb";
    	
    	static {
    		try {
    			Class.forName("com.hxtt.sql.access.AccessDriver");
    			
    		}catch(ClassNotFoundException e) {
    			e.printStackTrace();//捕获未找到该类的异常信息
    		}
    	}
    	
    	public static void main(String[] args) {
    		try {
    			Connection conn = DriverManager.getConnection(URL);
    			Statement stmt = conn.createStatement();
    			String sql = "select * from studentInfo";                //定义静态的SELECT语句
    			ResultSet rs = stmt.executeQuery(sql);                   //执行静态的SELECT语句
    			while(rs.next()) {
    				//遍历结果集,通过next()方法可以判断是否还存在符合条件的记录
    				int id = rs.getInt(1);                               //通过列索引获得指定列的值
    				String name = re.getString(2);                      
    				String sec = rs.getString(3);
    				System.out.println(id + " " + name + " " + sex);
    			}
    			stmt.close();
    			conn.close();
    		}catch(SQLException e) {
    			e.printStackTrace();
    		}
    	}
    
    }
    
    • 上面使用了Statement实例执行了静态SELECT语句,下面我们使用PreparedStatment实例执行动态SELECT语句查询记录
    package com.bjpowernode.java_learning;
    
    import java.sql.DriverManager;
    import java.sql.PreparedStatement;
    import java.sql.ResultSet;
    import java.sql.ResultSetMetaData;
    import java.sql.SQLException;
    
    public class D135_2_PreparedStatementSQL {
    	private static final String URL = "jdbc:Access:///e:/xsgl.mdb";
    	static {
    		try {
    			Class.forName("com.hxtt.sql.access.AccessDriver");
    			
    		}catch(ClassNotFoundException e) {
    			e.printStackTrace(); //输出捕获到异常信息
    		}
    	}
    	
    	public static void main(String[] args) {
    		try {
    			Connection conn = DriverManager.getConnection(URL);          
    			Statement stmt = conn.createStatement(sql);
    			String sql = "select * from studentInfo";                  //定义静态Select语句
    			PreparedStatement prpdStmt = conn.preparedStatement(sql);  //预处理动态INSERT语句
    			ResultSet rs = prpdStmt.executeQuery();                    //执行动态INSERT语句
    			ResultSetMetaData metaData  = rs.getMetaData();            //获得ResultSetMetaData类的实例
    			System.out.println(metaData.getColumnName(1) + "         ");//通过索引获得指定列的名称
    			System.out.println(metaData.getColumnName(2) + "         ");
    			System.out.println(meatData.getColumnName(3) + "         ");
    			while(rs.next()) {
    				int id = rs.getInt(1);                                  //通过索引获得指定列的值
    				String name = rs.getString(2);
    				String sex = rs.getString(3);
    				System.out.println(id + " " + name + " " + sex);
    			}
    			rs.close();
    			prpdStmt.close();
    			conn.close();
    		}catch(SQLException e) {
    			e.printStackTrace();
    		}
    	}
    
    }
    
    

    二、源码:

  • 相关阅读:
    通过IP获取地理位置,做分类系统必备!
    【转】句柄详解
    【转】C#泛型约束
    [转]掌握 Ajax,第 3 部分: Ajax 中的高级请求和响应[IBM]
    WPF调用Winfrom控件
    【转】C#对象的深拷贝与浅拷贝
    判断一个OBject类型是值类型还是引用类型
    WCF关于svcutil生成关于TCP绑定出现 元数据包含无法解析的引用:“net.tcp://127.0.0.1:9999/xxxx/”的解决方案
    C#枚举基础解析
    [转]掌握Ajax 第 1 部分: Ajax 入门简介 [IBM]
  • 原文地址:https://www.cnblogs.com/ruigege0000/p/13526944.html
Copyright © 2011-2022 走看看