java實現調用Mysql預存程序分析代碼

來源:互聯網
上載者:User

標籤:

 資料庫的測試代碼如下 :

1、建立表test,sql代碼如下:

create table test(field1 int not null)TYPE=MyISAM ;insert into test(field1) values(1);


2、刪除已存在的預存程序,代碼如下:

delimiter // -- 定義結束符號drop procedure p_test;


3、mysql預存程序定義,代碼如下:

create procedure p_test()begindeclare temp int;set temp = 0; update test set field1 = values(temp);end


4、 Java調用帶有輸入參數的預存程序,代碼如下:

public static void callIn(int in){ //擷取串連 Connection conn = ConnectDb.getConnection(); CallableStatement cs = null; try {  //可以直接傳入參數  //cs = conn.prepareCall("{call sp1(1)}");  //也可以用問號代替  cs = conn.prepareCall("{call sp1(?)}");  //設定第一個輸入參數的值為110  cs.setInt(1, in);  cs.execute(); } catch (Exception e) {  e.printStackTrace(); } finally {  try {  if(cs != null){   cs.close();  }  if(conn != null){   conn.close();  }  } catch (Exception ex) {  ex.printStackTrace();  } } }


5、Java調用帶有輸出參數的預存程序,代碼如下:

 public static void callOut() { Connection conn = ConnectDb.getConnection(); CallableStatement cs = null; try {  cs = conn.prepareCall("{call sp2(?)}");  //第一個參數的類型為Int  cs.registerOutParameter(1, Types.INTEGER);  cs.execute();  //得到第一個值  int i = cs.getInt(1);  System.out.println(i); } catch (Exception e) {  e.printStackTrace(); } finally {  try {  if(cs != null){   cs.close();  }  if(conn != null){   conn.close();  }  } catch (Exception ex) {  ex.printStackTrace();  } } }


6、Java調用輸出結果集的預存程序,代碼如下:

public static void callResult(){ Connection conn = ConnectDb.getConnection(); CallableStatement cs = null; ResultSet rs = null; try {  cs = conn.prepareCall("{call sp6()}");  rs = cs.executeQuery();  //迴圈輸出結果  while(rs.next()){  System.out.println(rs.getString(1));  } } catch (Exception e) {  e.printStackTrace(); } finally {  try {  if(rs != null){   rs.close();  }  if(cs != null){   cs.close();  }  if(conn != null){   conn.close();  }  } catch (Exception ex) {  ex.printStackTrace();  } } }}


7、Java擷取資料庫連接的工具類,代碼如下: 

import java.sql.Connection;import java.sql.DriverManager;import java.sql.PreparedStatement;import java.sql.ResultSet;import java.sql.SQLException;import java.sql.Statement; public class ConnectDb { public static Connection getConnection(){ Connection conn = null; PreparedStatement preparedstatement = null; try {  Class.forName("org.gjt.mm.mysql.Driver").newInstance();   String dbname = "test";  String url="jdbc:mysql://localhost/dbname?user=root&password=root&useUnicode=true&characterEncoding=utf-8";  conn= DriverManager.getConnection(url); } catch (Exception e) {  e.printStackTrace(); }  return conn; } }

java實現調用Mysql預存程序分析代碼

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.