簡單的增刪查改

来源:http://www.cnblogs.com/hgc-bky/archive/2016/06/17/5595449.html
-Advertisement-
Play Games

package com.pro.dao.impl; import java.sql.Date;import java.sql.PreparedStatement;import java.sql.ResultSet;import java.sql.SQLException;import java.sq ...


package com.pro.dao.impl;

import java.sql.Date;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.sql.Connection;
import java.sql.Types;
import java.util.Vector;

import oracle.jdbc.OracleCallableStatement;
import oracle.jdbc.OracleTypes;

import com.pro.dao.EmpDao;
import com.pro.dao.comm.DBConfigUtil;
import com.pro.dao.comm.DBConnection;
import com.pro.pojo.Emp;

public class EmpDaoImpl implements EmpDao {

@Override
public boolean insert(Emp emp) {
boolean isSuccess = false;
Connection connection = DBConnection.getConnection();

String sql = "insert into emp values(?,?,?,?,?,?,?,?)";
PreparedStatement statement = null;
try {
statement = connection.prepareStatement(sql);

// 向占位符填充實際數據
statement.setInt(1, emp.getEmpno());
statement.setString(2, emp.getEname());
statement.setString(3, emp.getJob());
if (emp.getMgr() == 0) {
statement.setObject(4, null);
} else {
statement.setInt(4, emp.getMgr());
}
statement.setDate(5, new Date(emp.getHiredate().getTime()));
statement.setDouble(6, emp.getSal());
statement.setDouble(7, emp.getComm());
statement.setInt(8, emp.getDeptno());

int result = statement.executeUpdate();

if (result > 0) {
isSuccess = true;
System.out.println("插入成功 ! " + result);
} else {
System.out.println("插入失敗!");
}
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} finally {
DBConnection.close(null, statement, connection);
}

return isSuccess;
}

@Override
public boolean update(String exp) {
// TODO Auto-generated method stub
return false;
}

@Override
public boolean delete(String exp) {
boolean isSuccess = false;
Connection connection = DBConnection.getConnection();

String sql = "delete from emp where " + exp;
Statement statement = null;
try {
statement = connection.createStatement();
int result = statement.executeUpdate(sql);

if (result > 0) {
isSuccess = true;
System.out.println("刪除成功 ! " + result);
} else {
System.out.println("刪除失敗!");
}
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} finally {
DBConnection.close(null, statement, connection);
}

return isSuccess;
}

@Override
public boolean delete() {
// boolean isSuccess = false;
// Connection connection = DBConnection.getConnection();
//
// String sql = "delete from emp";
// Statement statement = null;
// try {
// statement = connection.createStatement();
// int result = statement.executeUpdate(sql);
//
// if (result > 0) {
// isSuccess = true;
// System.out.println("刪除成功 ! " + result);
// } else {
// System.out.println("刪除失敗!");
// }
// } catch (SQLException e) {
// // TODO Auto-generated catch block
// e.printStackTrace();
// } finally {
// DBConnection.close(null, statement, connection);
// }

return DBConnection.executeUpdate("delete from emp", null) > 0 ? true
: false;
}

@Override
public Emp search(String exp) {
// TODO Auto-generated method stub
return null;
}

@Override
public Vector<Emp> searchMuil(String exp) {
// TODO Auto-generated method stub
return null;
}

@Override
public Vector<Emp> search() {

Vector<Emp> allEmp = new Vector<Emp>();
// Connection connection = DBConnection.getConnection();
//
// String sql =
// "select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp";
// Statement statement = null;
ResultSet resultSet = null;
try {
// statement = connection.createStatement();
// resultSet = statement.executeQuery(sql);

resultSet = DBConnection.executeQuery(
"select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp",
null);
while (resultSet.next()) {
Emp emp = new Emp();
emp.setEmpno(resultSet.getInt(1));
emp.setEname(resultSet.getString("ename"));
emp.setJob(resultSet.getString("job"));
emp.setMgr(resultSet.getInt("mgr"));
emp.setHiredate(resultSet.getDate("hiredate"));
emp.setSal(resultSet.getDouble("sal"));
emp.setComm(resultSet.getDouble("comm"));
emp.setDeptno(resultSet.getInt("deptno"));
allEmp.add(emp);
}
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
// finally {
// DBConnection.close(null, statement, connection);
// }

return allEmp;
}

@Override
public Vector<Emp> search(int pageNum) {
Vector<Emp> allEmp = new Vector<Emp>();
Connection connection = DBConnection.getConnection();

String sql = "{call data_control.pagedata('SCOTT.EMP',?,?,?)}";
OracleCallableStatement statement = null;
ResultSet resultSet = null;

try {
statement = (OracleCallableStatement) connection.prepareCall(sql);
statement.setInt(1, pageNum);
statement.setInt(2, Integer.parseInt(DBConfigUtil
.getProperty("page.default.count")));

statement.registerOutParameter(3, OracleTypes.CURSOR);
statement.execute();

resultSet = statement.getCursor(3);
while (resultSet.next()) {
Emp emp = new Emp();
emp.setEmpno(resultSet.getInt(1));
emp.setEname(resultSet.getString("ename"));
emp.setJob(resultSet.getString("job"));
emp.setMgr(resultSet.getInt("mgr"));
emp.setHiredate(resultSet.getDate("hiredate"));
emp.setSal(resultSet.getDouble("sal"));
emp.setComm(resultSet.getDouble("comm"));
emp.setDeptno(resultSet.getInt("deptno"));
allEmp.add(emp);
}

} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} finally {
DBConnection.close(resultSet, statement, connection);
}

return allEmp;
}

}


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 工具:svcutil.exe 參數:指定wsdl、輸出源碼文件、輸出配置文件 示例: D:\>svcutil.exe http://localhost:8087/DataService/?wsdl /out:Client.cs /config:app.configMicrosoft (R) Serv ...
  • 密封類 密封類使用sealed修飾符聲明。 密封類中不可能有抽象方法【因為:抽象方法必須在抽象類中,而抽象類不能是密封的或者是靜態的,也就是說abstract 和sealed不能同時修飾一個類】 ...
  • 抽象類使用abstract修飾符聲明; 不能創建抽象類的實例; 抽象類只能用作其他類的基類; 抽象類中可以包含抽象成員和普通的非抽象成員; 抽象類自己可以派生自另外一個抽象類; 任何派生自抽象類的【類】,必須使用override關鍵字,實現該類所有的成員,除非派生類自己也是抽象類。 示例: 1.基類 ...
  • 技術綜合 《小黃鴨調試法,每個程式員都要知道的》 《開發一個這樣的 APP 要多長時間?》 《一段代碼讓你覺得人類智慧可以璀璨無比》 《成人網站有多大?》 《輸入Google網址回車之後發生了什麼?》 《為什麼有些大公司技術弱爆了?》 《高效 MacBook 工作環境配置》 《如何編寫讓別人能讀懂的 ...
  • ASP.net 第一章:ASP.NET介紹 1.搭建ASP.NET開發環境; 2.理解ASP.NET運行機制; 3.掌握ASP.NET兩種編碼方式。 4.Http協議。 關鍵點: 1.BS的工作原理是什麼? 2.伺服器端開發技術有哪些? Asp 、aspx、jsp、php 3.ASP.NET發展史。 ...
  • 摘自:http://blog.csdn.net/dyllove98/article/details/9289553 資料庫生成位置可控制(其實主要就是DbContext的構造函數) 1.使用DbContext的構造函數:public DbContext(string nameOrConnection ...
  • 可以轉載,禁止修改。轉載請註明作者以及原文鏈接 註:本文是從貝葉斯分類器的角度來討論判別分析,有關貝葉斯分類器的概念可參考文末延伸閱讀第1-2篇文章。至於Fisher判別分析,未來會連同PCA一同討論。 判別分析也是一種分類器,與邏輯回歸相比,它具有以下優勢: 當類別的區分度高的時候,邏輯回歸的參數 ...
  • 俗話說技多不壓身,當年苦讀《深入理解JVM》還專門整理了筆記,現在就用上了~ 筆記 http://www.cnblogs.com/syjkfind/p/3901774.html 【癥狀】 用戶操作數據導出時總會發生卡頓,後臺占記憶體的定時任務發生時也會。JVM參數就不貼了,比較普通且相對合理。 【思路 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...