欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

如何讀取oracle,如何讀取圖片上的文字

如何在java中讀取oracle blob

整個(gè)流程分為四步,連接oracle數(shù)據(jù)庫 - 讀取blob圖片字段 - 對(duì)圖片進(jìn)行縮放 -把圖片展示在jsp頁面上。

為元寶等地區(qū)用戶提供了全套網(wǎng)頁設(shè)計(jì)制作服務(wù),及元寶網(wǎng)站建設(shè)行業(yè)解決方案。主營業(yè)務(wù)為成都網(wǎng)站制作、成都網(wǎng)站建設(shè)、元寶網(wǎng)站設(shè)計(jì),以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專業(yè)、用心的態(tài)度為用戶提供真誠的服務(wù)。我們深信只要達(dá)到每一位用戶的要求,就會(huì)得到認(rèn)可,從而選擇與我們長期合作。這樣,我們也可以走得更遠(yuǎn)!

下面進(jìn)行詳細(xì)描述:

1. java連接Oracle

注:數(shù)據(jù)庫是Oracle10g版本為10.2.0, 在數(shù)據(jù)庫中,圖片字段類型為BLOB。

java中通常使用的是通過jdbc驅(qū)動(dòng)來連接數(shù)據(jù)庫,oracle也不例外,因此必須下載一個(gè)Oracle驅(qū)動(dòng)的jdbc需要去網(wǎng)上進(jìn)行下載,名稱為 ojdbc14.jar。

下載地址為:

下載了驅(qū)動(dòng)之后,可以使用驅(qū)動(dòng)里提供的接口進(jìn)行連接,具體代碼如下:

import java.sql.*;

import java.io.*;

import javax.imageio.ImageIO;

import java.awt.image.BufferedImage;

import java.awt.image.AffineTransformOp;

import java.awt.geom.AffineTransform;

public class OracleQueryBean {

private final String oracleDriverName = "oracle.jdbc.driver.OracleDriver";

private Connection myConnection = null;

/*圖片表名*/

private String strTabName;

/*圖片ID字段名*/

private String strIDName;

/*圖片字段名*/

private String strImgName;

/**

* 加載java連接Oracle的jdbc驅(qū)動(dòng)

*/

public OracleQueryBean(){

try{

Class.forName(oracleDriverName);

}catch(ClassNotFoundException ex){

System.out.println("加載jdbc驅(qū)動(dòng)失敗,原因:" + ex.getMessage());

}

}

/**

* 獲取Oracle連接對(duì)象

* @return Connection

*/

public Connection getConnection(){

try{

//用戶名+密碼; 以下使用的Test就是Oracle里的表空間

//從配置文件中讀取數(shù)據(jù)庫信息

GetPara oGetPara = new GetPara();

String strIP = oGetPara.getPara("serverip");

String strPort = oGetPara.getPara("port");

String strDBName = oGetPara.getPara("dbname");

String strUser = oGetPara.getPara("user");

String strPassword = oGetPara.getPara("password");

this.strTabName = oGetPara.getPara("tablename");

this.strIDName = oGetPara.getPara("imgidname");

this.strImgName = oGetPara.getPara("imgname");

String oracleUrlToConnect ="jdbc:oracle:thin:@"+strIP+":"+strPort+":"+strDBName;

this.myConnection = DriverManager.getConnection(oracleUrlToConnect, strUser, strPassword);

}catch(Exception ex){

System.out.println("Can not get connection:" + ex.getMessage());

System.out.println("請(qǐng)檢測配置文件中的數(shù)據(jù)庫信息是否正確." );

}

return this.myConnection;

}

}

2. 讀取blob字段

在OracleQueryBean類中增加一個(gè)函數(shù),來進(jìn)行讀取,具體代碼如下:

/**

* 根據(jù)圖片在數(shù)據(jù)庫中的ID進(jìn)行讀取

* @param strID圖片字段ID

* @param w 需要縮到的寬度

* @param h 需要縮到高度

* @return

*/

public byte[] GetImgByteById(String strID, int w, int h){

//System.out.println("Get img data which id is " + nID);

if(myConnection == null)

this.getConnection();

byte[] data = null;

try {

Statement stmt = myConnection.createStatement();

ResultSet myResultSet = stmt.executeQuery("select " + this.strIDName + " from " + this.strTabName + " where " + this.strIDName + "=" + strID);

StringBuffer myStringBuffer = new StringBuffer();

if (myResultSet.next()) {

java.sql.Blob blob = myResultSet.getBlob(this.strImgName);

InputStream inStream = blob.getBinaryStream();

try {

long nLen = blob.length();

int nSize = (int) nLen;

//System.out.println("img data size is :" + nSize);

data = new byte[nSize];

inStream.read(data);

inStream.close();

} catch (IOException e) {

System.out.println("獲取圖片數(shù)據(jù)失敗,原因:" + e.getMessage());

}

data = ChangeImgSize(data, w, h);

}

System.out.println(myStringBuffer.toString());

myConnection.commit();

myConnection.close();

} catch (SQLException ex) {

System.out.println(ex.getMessage());

}

return data;

}

3. 縮放圖片

因?yàn)閳D片的大小可能不一致,但是在頁面中輸出的大小需要統(tǒng)一,所以需要

在OracleQueryBean類中增加一個(gè)函數(shù),來進(jìn)行縮放,具體代碼如下:

/**

* 縮小或放大圖片

* @param data 圖片的byte數(shù)據(jù)

* @param w 需要縮到的寬度

* @param h 需要縮到高度

* @return 縮放后的圖片的byte數(shù)據(jù)

*/

private byte[] ChangeImgSize(byte[] data, int nw, int nh){

byte[] newdata = null;

try{

BufferedImage bis = ImageIO.read(new ByteArrayInputStream(data));

int w = bis.getWidth();

int h = bis.getHeight();

double sx = (double) nw / w;

double sy = (double) nh / h;

AffineTransform transform = new AffineTransform();

transform.setToScale(sx, sy);

AffineTransformOp ato = new AffineTransformOp(transform, null);

//原始顏色

BufferedImage bid = new BufferedImage(nw, nh, BufferedImage.TYPE_3BYTE_BGR);

ato.filter(bis, bid);

//轉(zhuǎn)換成byte字節(jié)

ByteArrayOutputStream baos = new ByteArrayOutputStream();

ImageIO.write(bid, "jpeg", baos);

newdata = baos.toByteArray();

}catch(IOException e){

e.printStackTrace();

}

return newdata;

}

4. 展示在頁面

頁面使用OracleQueryBean來根據(jù)用戶提供的圖片id進(jìn)行查詢,在讀取并進(jìn)行縮放后,通過jsp頁面進(jìn)行展示,具體代碼如下:

%@ page language="java" contentType="text/html;;charset=gbk" %

jsp:useBean id="OrcleQuery" scope="page" class="HLFtiDemo.OracleQueryBean" /

%

response.setContentType("image/jpeg");

//圖片在數(shù)據(jù)庫中的 ID

String strID = request.getParameter("id");

//要縮略或放大圖片的寬度

String strWidth = request.getParameter("w");

//要縮略或放大圖片的高度

String strHeight = request.getParameter("h");

byte[] data = null;

if(strID != null){

int nWith = Integer.parseInt(strWidth);

int nHeight = Integer.parseInt(strHeight);

//獲取圖片的byte數(shù)據(jù)

data = OrcleQuery.GetImgByteById(strID, nWith, nHeight);

ServletOutputStream op = response.getOutputStream();

op.write(data, 0, data.length);

op.close();

op = null;

response.flushBuffer();

//清除輸出流,防止釋放時(shí)被捕獲異常

out.clear();

out = pageContext.pushBody();

}

%

5. OracleQueryBean查詢類的整體代碼

OracleQueryBean.java文件代碼如下所示:

import java.sql.*;

import java.io.*;

import javax.imageio.ImageIO;

import java.awt.image.BufferedImage;

import java.awt.image.AffineTransformOp;

import java.awt.geom.AffineTransform;

public class OracleQueryBean {

private final String oracleDriverName = "oracle.jdbc.driver.OracleDriver";

private Connection myConnection = null;

/*圖片表名*/

private String strTabName;

/*圖片ID字段名*/

private String strIDName;

/*圖片字段名*/

private String strImgName;

/**

* 加載java連接Oracle的jdbc驅(qū)動(dòng)

*/

public OracleQueryBean(){

try{

Class.forName(oracleDriverName);

}catch(ClassNotFoundException ex){

System.out.println("加載jdbc驅(qū)動(dòng)失敗,原因:" + ex.getMessage());

}

}

/**

* 獲取Oracle連接對(duì)象

* @return Connection

*/

public Connection getConnection(){

try{

//用戶名+密碼; 以下使用的Test就是Oracle里的表空間

//從配置文件中讀取數(shù)據(jù)庫信息

GetPara oGetPara = new GetPara();

這文章確實(shí)寫的不錯(cuò),你可以看原文

如何讀取遠(yuǎn)程oracle視圖數(shù)據(jù)

1. 獲得遠(yuǎn)程數(shù)據(jù)庫的tns信息和要訪問的對(duì)象的擁有者及其密碼

2.創(chuàng)建dblink

create database link "DBLINK_NAME" connect to "USER_NAME" identified by "PASSWD" using ' (DESCRIPTION =

(ADDRESS = (PROTOCOL = TCP)(HOST = lnwxzyp)(PORT = 1521))

(CONNECT_DATA =

(SERVER = DEDICATED)

(SERVICE_NAME = demo)

)

)

';

3.查看

select * from view_name@dblink_name;

也可以建成同義詞

create synonym OBJ_NAME for view_name@dblink_name;

建成視圖

create view VIEW_NAME as select * from view_name@dblink_name;

如何讀取Oracle的BLOB字段里的文件

樓主你好!根據(jù)你的描述,讓我來給你回答!

create table temp_blob as select blob_colname from tbname ;

然后使用exp或者expdp 。

或者你也可以使用第三方編程語言或者軟件來導(dǎo)出。

希望能幫到你,如果滿意,請(qǐng)記得采納哦~~~

Oracle讀取數(shù)據(jù)

錯(cuò)誤沒貼出來。 我只能猜測:

string sql = "select * from t_users where USER=@USER and PASS=@PASS";

string[,] UserInfo = { { "@Uname", loginInfo.UName }, { "@UID", loginInfo.UPassword } };

改成

string sql = "select * from t_users where USER=:USER and PASS=:PASS";

string[,] UserInfo = { { "Uname", loginInfo.UName }, { "UID", loginInfo.UPassword } };

試試

如何用python讀取oracle數(shù)據(jù)庫

下載cx_Oracle,下載之后就可以使用了。

簡單的使用流程如下:

1.引用模塊cx_Oracle2.連接數(shù)據(jù)庫3.獲取cursor4.使用cursor進(jìn)行各種操作5.關(guān)閉cursor6.關(guān)閉連接

參考代碼:

import cx_Oracle ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?#引用模塊cx_Oracleconn=cx_Oracle.connect('load/123456@localhost/ora11g') ? ?#連接數(shù)據(jù)庫c=conn.cursor() ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? #獲取cursorx=c.execute('select sysdate from dual') ? ? ? ? ? ? ? ? ? #使用cursor進(jìn)行各種操作x.fetchone()c.close() ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? #關(guān)閉cursorconn.close() ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?#關(guān)閉連接

如何編程讀取oracle的dmp文件中的表數(shù)據(jù)

操作步驟:

1、開始-輸入cmd,進(jìn)入命令提示符。

2、進(jìn)到C盤根目錄

3、輸入命令

imp 用戶名/密碼@數(shù)據(jù)庫實(shí)例名 file=load.dmp log=load.log TABLES=(表名)

4、敲入回車,等待導(dǎo)入結(jié)束。

提示:步驟3的中文部分,請(qǐng)根據(jù)自己數(shù)據(jù)庫的情況進(jìn)行更改。

文章題目:如何讀取oracle,如何讀取圖片上的文字
網(wǎng)站URL:http://aaarwkj.com/article14/dsspide.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供定制開發(fā)、網(wǎng)站導(dǎo)航、品牌網(wǎng)站設(shè)計(jì)、網(wǎng)站策劃App開發(fā)、網(wǎng)站內(nèi)鏈

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

綿陽服務(wù)器托管
男人的天堂久久精品激情| 国产三级三级精品久久| 日韩中文字幕一二三| 免费特黄特黄的欧美大片| 亚洲国产精品高清久久| 亚洲国产99在线精品一区| 亚洲av毛片一区二区三区网| 欧美大片免费在线播放| 亚洲男人的av天堂生活| 亚洲综合精品久久久一区| 亚洲国产精品区一区二区| 国产999精品在线观看| 日韩精品国产一区二区在线观看 | 亚洲成人av在线直播| 久久国产综合精品电影| 国产精品伊人久久综合网| 丝袜美腿蜜汁一龙二凤| 视频一区二区三区拍拍| 国产一区二区精品久久岳√| 性感美女国产av一区二区三区| 色偷拍亚洲偷自拍二区| 久久精品性少妇一区二区三区| 麻豆精品国产粉嫩av| 91无人区一区二区三乱码| 一本在线不卡中文字幕| 欧美艳星一区二区三区四区| 极品美女被插到高潮喷水| 国产精品中文字幕第一区| 日韩精品一区三区二区| 久久精品一偷一偷国产| 91色九色吧在线观看| 亚洲成人日韩在线播放| 久久热这里只有视频精品| 黑人一区二区三区在线| 欧美另类亚洲综合久青草| 97视频在线观看免费| 和富婆啪啪一区二区免费看| 日韩欧美精品另类在线| 国产大片在线观看一区二区| 四虎久久久最新网址| 国产成+人+综合+亚洲专区|