<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問(wèn)答1問(wèn)答10問(wèn)答100問(wèn)答1000問(wèn)答2000關(guān)鍵字專題1關(guān)鍵字專題50關(guān)鍵字專題500關(guān)鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專題關(guān)鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問(wèn)答文章1 問(wèn)答文章501 問(wèn)答文章1001 問(wèn)答文章1501 問(wèn)答文章2001 問(wèn)答文章2501 問(wèn)答文章3001 問(wèn)答文章3501 問(wèn)答文章4001 問(wèn)答文章4501 問(wèn)答文章5001 問(wèn)答文章5501 問(wèn)答文章6001 問(wèn)答文章6501 問(wèn)答文章7001 問(wèn)答文章7501 問(wèn)答文章8001 問(wèn)答文章8501 問(wèn)答文章9001 問(wèn)答文章9501
        當(dāng)前位置: 首頁(yè) - 科技 - 知識(shí)百科 - 正文

        mysql存儲(chǔ)和讀取圖片_MySQL

        來(lái)源:懂視網(wǎng) 責(zé)編:小采 時(shí)間:2020-11-09 19:28:08
        文檔

        mysql存儲(chǔ)和讀取圖片_MySQL

        mysql存儲(chǔ)和讀取圖片_MySQL:首先,介紹一下mysql相關(guān)的數(shù)據(jù)類型:MySQL中有四種BLOB類型,TinyBlob(最大255Byte), Blob(最大65K), MediunBlob(16M), LongBlob(最大4G)。這里注意一下如果你數(shù)據(jù)庫(kù)出現(xiàn)相關(guān)的Data too long...字樣可能是你選擇的種類的大小不夠。 接下
        推薦度:
        導(dǎo)讀mysql存儲(chǔ)和讀取圖片_MySQL:首先,介紹一下mysql相關(guān)的數(shù)據(jù)類型:MySQL中有四種BLOB類型,TinyBlob(最大255Byte), Blob(最大65K), MediunBlob(16M), LongBlob(最大4G)。這里注意一下如果你數(shù)據(jù)庫(kù)出現(xiàn)相關(guān)的Data too long...字樣可能是你選擇的種類的大小不夠。 接下

        首先,介紹一下mysql相關(guān)的數(shù)據(jù)類型:MySQL中有四種BLOB類型,TinyBlob(最大255Byte), Blob(最大65K), MediunBlob(16M), LongBlob(最大4G)。這里注意一下如果你數(shù)據(jù)庫(kù)出現(xiàn)相關(guān)的Data too long...字樣可能是你選擇的種類的大小不夠。

        接下來(lái)簡(jiǎn)單說(shuō)一下我為什么沒(méi)有用存儲(chǔ)圖片路徑的方式,而采取了直接在MySQL中存儲(chǔ)圖片的方式。原因有兩點(diǎn):

        1、本身不需要大量圖片,一個(gè)數(shù)據(jù)庫(kù)只需要一張圖片

        2、軟件結(jié)構(gòu)是要通過(guò)WebService由一個(gè)主客戶端去訪問(wèn)下面附屬的幾個(gè)客戶端,如果附屬客戶端不存儲(chǔ)圖片直接供主客戶端訪問(wèn),那么主客戶端勢(shì)必就需要一個(gè)加載圖片的功能(類似于FTP的功能)。

        下面還是直接上代碼吧:

        public bool MapSearchWrite(string strImagePath)
        {
        //將圖片轉(zhuǎn)換成緩沖流
        FileStream fs = new FileStream(strImagePath, FileMode.Open, FileAccess.Read);

        //獲得圖片的字節(jié)數(shù)組
        byte[] byImage = new byte[fs.Length];
        fs.Read(byImage, 0, byImage.Length);
        fs.Close();


        //數(shù)據(jù)庫(kù)連接
        MySqlConnection conn = new MySqlConnection();
        conn.ConnectionString = "Server=localhost;Uid=root;Password=123456;Database=firefighting;charset=gb2312";
        try
        {
        conn.Open();
        }
        catch
        {
        conn.Close();
        conn.Dispose();
        throw new ArgumentException("地圖檢索數(shù)據(jù)庫(kù)連接失敗");
        }


        //判斷數(shù)據(jù)庫(kù)內(nèi)部有無(wú)記錄
        string strQueryCmd = "select PicNum from images";
        MySqlCommand cmdQuery = new MySqlCommand(strQueryCmd, conn);
        MySqlDataReader dataReader = cmdQuery.ExecuteReader();


        //執(zhí)行操作
        MySqlCommand cmd = new MySqlCommand();
        if (dataReader.Read())
        {
        cmd.CommandText = "update images set Image=@byImage";
        }
        else
        {
        cmd.CommandText = "insert into images(Image) values(@byImage)";
        }

        cmd.CommandType = CommandType.Text;
        cmd.Parameters.Add("@byImage", MySqlDbType.MediumBlob);
        cmd.Parameters[0].Value = byImage;
        cmd.Connection = conn;

        int affectedRows = 0;
        try
        {
        affectedRows = cmd.ExecuteNonQuery();
        }
        catch
        {
        affectedRows = -1;
        }


        //關(guān)閉連接等
        cmd.Dispose();
        conn.Close();
        conn.Dispose();


        if (affectedRows <= 0)
        {
        return false;
        }
        else
        {
        return true;
        }
        }

        這是把圖片插入到數(shù)據(jù)庫(kù)的操作代碼,路徑的話就是你所需要存儲(chǔ)的圖片所在的路徑(包括圖片的名字和后綴名哦),另外我這里采用的是ADO.NET的連接方式,語(yǔ)言是C#的,其他代碼也不用我解釋了......


        下面是讀取MySQL中的圖片的代碼

        public void MapSearchQuery(out byte[] imageByteResulet)
        {
        imageByteResulet = null;

        MySqlConnection conn = new MySqlConnection();
        conn.ConnectionString = "Server=localhost;Uid=root;Password=123456;Database=firefighting;charset=gb2312";
        try
        {
        conn.Open();
        }
        catch
        {
        conn.Close();
        conn.Dispose();
        throw new ArgumentException("地圖檢索數(shù)據(jù)庫(kù)連接失敗");
        }


        string strQueryCmd = "select Image from images limit 1";
        MySqlCommand cmd = new MySqlCommand(strQueryCmd, conn);
        MySqlDataReader dataReader = null;
        try
        {
        dataReader = cmd.ExecuteReader();
        }
        catch
        {
        dataReader.Dispose();
        cmd.Dispose();
        conn.Close();
        conn.Dispose();
        throw new ArgumentException("地圖檢索查詢地圖失敗");
        }


        if (dataReader.Read())
        {
        imageByteResulet = new byte[dataReader.GetBytes(0, 0, null, 0, int.MaxValue)];
        dataReader.GetBytes(0, 0, imageByteResulet, 0, imageByteResulet.Length);

        //將圖片字節(jié)數(shù)組加載入到緩沖流
        // MemoryStream imageStream = new MemoryStream(imageByte);

        //從緩沖流生成圖片
        //imageResulet = Image.FromStream(imageStream, true);
        }

        dataReader.Dispose();
        cmd.Dispose();
        conn.Close();
        conn.Dispose();
        }

        當(dāng)然這里我是照顧到Image對(duì)象不能通過(guò)WebService傳輸而把BLOB數(shù)據(jù)只轉(zhuǎn)換成byte[]在傳輸,如果不需要這個(gè)功能的換可以直接把相關(guān)代碼踢出來(lái)再將byte[]轉(zhuǎn)成圖片對(duì)象即可,一下提供兩種方法

        第一種:imageByte是調(diào)用上面函數(shù)得到的byte[]的數(shù)據(jù)

        //將圖片字節(jié)數(shù)組加載入到緩沖流
        MemoryStream imageStream = new MemoryStream(imageByte);


        //從緩沖流生成圖片
        imageResulet = Image.FromStream(imageStream, true);


        //pictureBox是一個(gè)顯示圖片或者視頻的C#控件

        pictureBox.Image = imageResulet;

        這樣就把圖片讀取出來(lái)并顯示出來(lái)了

        第二種:BitMap是System.Drawingm命名空間中的

        Bitmap bm = new Bitmap(new MemoryStream(imageByte));
        pictureBox1.Image = bm;


        那么,到此我就說(shuō)完了,當(dāng)然不是迫不得已不要把圖片存到數(shù)據(jù)庫(kù)中,可以做個(gè)url映射,返回文件流(這個(gè)目前沒(méi)試過(guò),有時(shí)間試過(guò)后再把經(jīng)驗(yàn)分享給大家)。

        聲明:本網(wǎng)頁(yè)內(nèi)容旨在傳播知識(shí),若有侵權(quán)等問(wèn)題請(qǐng)及時(shí)與本網(wǎng)聯(lián)系,我們將在第一時(shí)間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        mysql存儲(chǔ)和讀取圖片_MySQL

        mysql存儲(chǔ)和讀取圖片_MySQL:首先,介紹一下mysql相關(guān)的數(shù)據(jù)類型:MySQL中有四種BLOB類型,TinyBlob(最大255Byte), Blob(最大65K), MediunBlob(16M), LongBlob(最大4G)。這里注意一下如果你數(shù)據(jù)庫(kù)出現(xiàn)相關(guān)的Data too long...字樣可能是你選擇的種類的大小不夠。 接下
        推薦度:
        標(biāo)簽: 保存 圖片 保存圖片
        • 熱門焦點(diǎn)

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 日本亚洲欧洲免费天堂午夜看片女人员 | 亚洲色av性色在线观无码| 一级毛片免费播放试看60分钟| 毛片视频免费观看| 国产亚洲玖玖玖在线观看| 成年男女免费视频网站| 亚洲日韩中文字幕一区| 永久黄网站色视频免费观看 | 亚洲精品欧美综合四区| 无码人妻一区二区三区免费| 亚洲天堂一区在线| 毛片大全免费观看| 精品一区二区三区无码免费直播| 免费va在线观看| 国产久爱免费精品视频| 精品亚洲综合久久中文字幕| 99re热精品视频国产免费| 亚洲精品动漫在线| 免费看a级黄色片| 乱人伦中文视频在线观看免费| 在线观看亚洲av每日更新| 99久久国产免费-99久久国产免费 99久久国产免费中文无字幕 | 99亚洲男女激情在线观看| 麻豆国产入口在线观看免费| 337p日本欧洲亚洲大胆人人| 久久亚洲色一区二区三区| 久9热免费精品视频在线观看| 亚洲天堂电影在线观看| 国产精品成人四虎免费视频| 国产成人精品免费大全| 亚洲欧洲日产国产综合网| 毛片免费观看网站| 一级一片免费视频播放| 亚洲成a人片在线观看中文!!!| 国产男女猛烈无遮挡免费视频网站| 国产无遮挡色视频免费观看性色| 337p欧洲亚洲大胆艺术| 免费一级毛片在播放视频| 特级无码毛片免费视频尤物| 亚洲国产综合AV在线观看| 国产亚洲精品岁国产微拍精品|