zoukankan      html  css  js  c++  java
  • Callablestatement与JavaBean及其实例

    一、

    Callablestatement:调用 数据库中的存储过程、存储函数

    connection.prepareCall(参数:存储过程/存储函数名)
    参数格式:
    存储过程:(无返回值return,用Out参数代替返回值)
          {call 存储过程名(参数列表)}
    存储函数:(有返回值return)
           { ?=call 存储函数名(参数列表)}

    存储过程:
    create or replace procedure addTwoNum( num1 in number,num2 in number,result out number)  --1+2-->3
    as
    begin
           result :=num1+num2;
    end;
    /     --/结束

    强调:
    如果通过sqlplus访问数据库,只需要开启:OracleServiceSID
    通过其它程序访问数据(Sqldevelop、Navicat、JDBC),需要开启:OracleServiceSID、XxxListener

    JDBC调用存储过程的步骤
    a.产生调用存储过程的对象(CallableStatement )cstmt=connection.prepareCall("{call addTwoNum(?,?,?)}");
    b.利用setXXX()进行处理             cstmt.setInt(1, 10)
    c.通过registerOutParameter()处理输出参数类型            cstmt.registerOutParameter(3, Types.INTEGER);//必须放在execute()前面
    d.cstmt.execute();//execute()进行执行
    e.接受返回值int result=cstmt.getInt(3);

    package JDBCDemo;
    
    import java.sql.CallableStatement;
    import java.sql.Connection;
    import java.sql.DriverManager;
    import java.sql.SQLException;
    import java.sql.Statement;
    import java.sql.Types;
    
    
    
    public class JDBCcallablestatementDemo {
        private static final String URL="jdbc:mysql://localhost:3306/mysql?serverTimezone=UTC&characterEncoding=utf-8";
        private static final String USERNAME="root";
        private static final String PWD="vayne";
            public static void update()
            {
                CallableStatement cstmt=null;
                Connection connection=null;
                try {
                    
                //a.导入驱动,加载具体的驱动类
                Class.forName("com.mysql.cj.jdbc.Driver");
                //b.与数据库建立连接
                connection = DriverManager.getConnection(URL,USERNAME,PWD);
                //使用Ctrl+1,快速生成值来获取Connection
                //c.发送SQL,执行(增删改、查)
                 cstmt=connection.prepareCall("{call addTwoNum(?,?,?)}");
                 cstmt.setInt(1, 10);
                 cstmt.setInt(2, 20);
                 
                 
                 cstmt.registerOutParameter(3, Types.INTEGER);//必须放在execute()前面
                 cstmt.execute();//execute()前处理输入值及输出参数类型,execute()后处理输出值
                 //设置输出参数的类型
                 int result=cstmt.getInt(3);
                //处理结果
                System.out.println(result+"操作成功!!!");
                
                }catch(ClassNotFoundException e) {
                    e.printStackTrace();
                }catch(SQLException e) {
                    e.printStackTrace();
                }catch(Exception e){
                    e.printStackTrace();
                }finally {
                    try {
                        //先开的后关,后开的先关
                    if(cstmt!=null)cstmt.close();
                    if(connection !=null)connection.close();
                    }catch(SQLException e) {
                        e.printStackTrace();
                    }finally {
                        
                    }
                }
            }
            public static void main(String[] args) {
                update();
                
            }
    }

    二、JavaBean
    将java代码和jsp代码分开存放
    作用:
    1、减轻jsp页面的负担,便于开发人员进行分块管理代码
    2、提高代码复用率,封装成类,使用时直接调用即可。

    定义
    1、public修饰的类以及public修饰的无参构造
    2、所有的属性都是private,并且还提供set/get  (boolean类型提供set/is)

    使用层面,分为两类:
    1、封装业务逻辑的JavaBean (LoginDao.java封装了登录逻辑)            即逻辑
        可以将jsp中的JDBC代码,封装到Dao.java类中 (Dao.java)

    2、封装数据的JavaBean   (实体类,Student.java  Person.java  )    即数据
        对应于数据库中的一张表
        User user=new User(name,pwd);//即用User对象 封装了2个数据(用户名 和密码)

    封装数据的JavaBean 对应于数据库中的一张表   (User(name,pwd))
    封装业务逻辑的JavaBean 用于操作 一个封装数据的JavaBean  

    可以发现,JavaBean可以简化 代码(jsp->jsp+java)、提供代码复用(Dao.java)
     

    登录实例

    Navicat中建表如下

    login.jsp

    <%@ page language="java" contentType="text/html; charset=UTF-8"
        pageEncoding="UTF-8"%>
    <!DOCTYPE html>
    <html>
    <head>
    <meta charset="UTF-8">
    <title>Insert title here</title>
    </head>
    <body>
           <form action="check.jsp" method="post">
                         用户名<input type="text" name="uname"><br/>
                         密码<input type="password" name="upwd"><br/>
                <input type="submit" value="登录"><br/>
           </form>
    </body>
    </html>

    check.jsp

    <%@ page language="java" contentType="text/html; charset=UTF-8"
        pageEncoding="UTF-8"%>
      <%@ page import="Dao.*"%>  
    <!DOCTYPE html>
    <html>
    <head>
    <meta charset="UTF-8">
    <title>Insert title here</title>
    </head>
    <body>
          <%
              request.setCharacterEncoding("utf-8");
              String name=request.getParameter("uname");
              String pwd=request.getParameter("upwd");
              User user=new User(name,pwd);
              Dao dao =new Dao();
              int result=Dao.login(user);
              if(result>0){
                  out.print("登录成功");
              }else{
                  out.print("用户名或密码错误");
              }%>
    </body>
    </html>

    DBUtil.DBUtil.java

    package DBUtil;
    
    import java.sql.Connection;
    import java.sql.DriverManager;
    import java.sql.ResultSet;
    import java.sql.SQLException;
    import java.sql.Statement;
    
    import Dao.User;
    
    public class DBUtil {
    
        public static String db_url = "jdbc:mysql://localhost:3306/system?serverTimezone=UTC&characterEncoding=utf-8";
        public static String db_user = "root";
        public static String db_pass = "vayne";
        
        public static Connection getConn () {
            Connection conn = null;
            
            try {
                Class.forName("com.mysql.cj.jdbc.Driver");
                conn = DriverManager.getConnection(db_url, db_user, db_pass);
            } catch (Exception e) {
                e.printStackTrace();
            }
            return conn;
        }
        
        
        public static void close (Statement state, Connection conn) {
            if (state != null) {
                try {
                    state.close();
                } catch (SQLException e) {
                    e.printStackTrace();
                }
            }
            
            if (conn != null) {
                try {
                    conn.close();
                } catch (SQLException e) {
                    e.printStackTrace();
                }
            }
        }
        
        public static void close (ResultSet rs, Statement state, Connection conn) {
            if (rs != null) {
                try {
                    rs.close();
                } catch (SQLException e) {
                    e.printStackTrace();
                }
            }
            
            if (state != null) {
                try {
                    state.close();
                } catch (SQLException e) {
                    e.printStackTrace();
                }
            }
            
            if (conn != null) {
                try {
                    conn.close();
                } catch (SQLException e) {
                    e.printStackTrace();
                }
            }
            
        }
    }

    Dao.User.java

    package Dao;
    
    public class User {
        private int id;
        private static String name;
        private static String pwd;
        private static String hobby;
    
        public User() {
    
        }
        public User( String name, String pwd) {
            this.name = name;
            this.pwd = pwd;
        }
        
    
        public User(int id, String name, String pwd, String hobby) {
            this.id = id;
            this.name = name;
            this.pwd = pwd;
            this.hobby = hobby;
        }
        
    
        public int getId() {
            return id;
        }
    
        public void setId(int id) {
            this.id = id;
        }
    
        public static String getName() {
            return name;
        }
    
        public void setName(String name) {
            this.name = name;
        }
    
        public static String getPwd() {
            return pwd;
        }
    
        public void setPwd(String pwd) {
            this.pwd = pwd;
        }
    
        public static String getHobby() {
            return hobby;
        }
    
        public void setHobby(String hobby) {
            this.hobby = hobby;
        }
    
    }

    Dao.Dao.java

    package Dao;
    
    import java.sql.Connection;
    import java.sql.DriverManager;
    import java.sql.ResultSet;
    import java.sql.SQLException;
    import java.sql.Statement;
    import Dao.User;
    import DBUtil.DBUtil;
    public class Dao {
        public static int login(User user) {
                   int f=-1;
                    String sql = "select * from JDBCjsp where name = '" + User.getName() + "' and password = '"+User.getPwd()+"'";
                    //
                    Connection conn = DBUtil.getConn();
                    Statement state = null;
                    ResultSet rs = null;       
                    try {
                        state = conn.createStatement();
                        rs = state.executeQuery(sql);
                        if (rs.next()) {
                            f = rs.getInt(1);
                        }
                    } catch (SQLException e) {
                        e.printStackTrace();
                    } finally {
                        DBUtil.close(rs, state, conn);
                    }
                    return f;
                }
          
    }

    演示截图

    输入正确的密码

     输入错误的用户名

     

  • 相关阅读:
    创建一个新的进程os.fork
    进程的特征
    进程的状态
    多进程概念
    IO多路复用
    Objective-C 和 C++中指针的格式和.方法 和内存分配
    生活需要奋斗的目标
    iOS 关于UITableView的dequeueReusableCellWithIdentifier
    哈哈,发现了刚毕业时发布的求职帖子
    iOS 和Android中的基本日期处理
  • 原文地址:https://www.cnblogs.com/yeyueweiliang/p/12207147.html
Copyright © 2011-2022 走看看