今天寫一個mysql存儲過程,根據自己的需求要遍歷一個數據表,因為對存儲過程用的不多,語法不甚熟悉,加之存儲過程沒有調試環境,花了不少時間才慢慢弄好,故留個痕跡。
1 BEGIN
2 DECLARE Done INT DEFAULT 0;
3
4 DECLARE CurrentLingQi INT;
5
6 DECLARE ShizuName VARCHAR(30);
7 /* 聲明游標 */
8 DECLARE rs CURSOR FOR SELECT NodeName, LingQi FROM socialrelation;
9 /* 異常處理 */
10 DECLARE CONTINUE HANDLER FOR SQLSTATE '02000' SET Done = 1;
11
12 /* 打開游標 */
13 OPEN rs;
14
15 /* 逐個取出當前記錄LingQi字段的值,需要進行最大值的判斷 */
16 FETCH NEXT FROM rs INTO ShizuName, CurrentLingQi;
17 /* 遍歷數據表 */
18 REPEAT
19 IF NOT Done THEN
20 SET CurrentLingQi = CurrentLingQi + 60;
21 /* 如果更新后靈氣值大于允許的最大值,則就設置為最大值 */
22 IF CurrentLingQi >= 1800 THEN
23 UPDATE socialrelation SET LingQi = 1800 WHERE NodeName = ShizuName;
24 ELSE
25 /* 否則,正常更新 */
26 UPDATE socialrelation SET LingQi = LingQi + 60 WHERE NodeName = ShizuName;
27 END IF;
28 END IF;
29
30 FETCH NEXT FROM rs INTO ShizuName, CurrentLingQi;
31
32 UNTIL Done END REPEAT;
33
34 /* 關閉游標 */
35 CLOSE rs;
36 END
CxImage是什么
CxImage是C++實現的功能強大的、能處理多種文件格式的圖像管理類。它能夠簡單快速的實現圖像的導入、保存、顯示和變換。
為什么使用CxImage
u 它是平臺無關的
u 它是自由軟件、免費的、開源的
u 支持多種平面格式:BMP、GIF、ICO、TGA、JPEG、PCX、PNG、TIFF、MNG、RAS等,還有更多!
u 功能強大:幾何變換、圖像處理、圖像格式轉換等。
u 使用簡單:下面的入門教程會給你展示這一點。
CxImage的功能
Constructors 構造函數
Initialization 初始化
File 文件操作,主要是編解碼
Generic 圖像基本變化
DSP 圖像處理操作
Painting 繪圖操作
Multiple Images 多幀圖像操作
Transparency 透明層操作
Palette 調色板操作
Pixels 像素操作
Region Selection 區域選擇操作
Alpha Channel Alpha通道操作
Layers 圖像層操作
Attributes 圖像屬性操作
Miscellaneous 雜項
呵呵,夠強大吧!一個類庫再好,不能為我們所用,則一切都是空談,怎么用,請看詳細步驟:
CxImage使用入門
1. 去
這里:http://www.codeproject.com/KB/graphics/cximage.aspx,下載CxImage的源代碼。在
codeproject沒有賬戶的兄弟姐妹需要先注冊一個哦,非常簡單,幾秒鐘就可以了!該頁面上有兩個可以下載的東東,一個是CxImage的源代碼,
另一個是用CxImage類庫開發的一個完整的Demo,你可以看一下這個Demo,就知道它的功能有多強大了!
2. 編譯CxImage。解壓源碼包,在解壓后的目錄下有一個CxImageLib.dsw工作空間文件,使用VC++ 6.0 打開該工作空間文件。做以下事情:
① Project->Settings->C/C++,
在Category下拉列表中選擇Code Generation,將Use rum-time libary中選擇MultiThread DLL.在
Category下拉列表中選擇 Precompiled Headers中,選擇第一
項: Not using Precompiled headers.
② Build->Batch Build->勾選你要編譯的版本庫。默認情況下是每個庫都有四個版本,分別是Debug、Release、Unicode Debug、Unicode Release.選擇你想要編譯的版本即可。
③ 等待幾分鐘,即可編譯好。
④ 新建立一個文件夾,如mycximage。在該文件夾下新建一個header文件夾和一個lib文件夾。將CxImage下的所有頭文件都拷貝到header文件夾下,將剛才所有生成的lib文件拷貝到lib文件夾下。至此,你已經擁有了CxImage類庫。
⑤ 打開VC++6.0,新建立一個基于對話框的MFC應用程序,叫Test。我們來完成一個將BMP位圖轉換成JPEG格式的小程序。在對話框上畫一個按鈕,雙擊按鈕,響應事件函數。
⑥ 將剛才我們建立好的mycximage文件夾拷貝到你的工程目錄下。在TestDlg.cpp文件頂部,加入以下代碼:
#include ”mycximage/header/ximage.h”
#pragma comment(lib, ”mycximage/lib/png.lib”)
#pragma comment(lib, ”mycximage/lib/libdcr.lib”)
#pragma comment(lib, ”mycximage/lib/jpeg.lib”)
#pragma comment(lib, ”mycximage/lib/zlib.lib”)
#pragma comment(lib, ”mycximage/lib/tiff.lib”)
#pragma comment(lib, ”mycximage/lib/jasper.lib”)
#pragma comment(lib, ”mycximage/lib/cximage.lib”)
#pragma comment(lib, ”mycximage/lib/mng.lib”)
在你的事件響應函數中添加一下代碼:
CxImage image;
CString strFileName; // 圖像文件名
CFileDialog dlg( TRUE, ”BMP”, NULL, OFN_OVERWRITEPROMPT | OFN_HIDEREADONLY, ”所有圖像文件(*.*)|*.*|BMP圖像文件(*.BMP)|*.BMP|JPG格式圖像(*.JPG)|*.JPG||”);
dlg.DoModal();
// 獲取文件名
strFileName = dlg.GetFileName();
// 判斷文件名是否為空
if (strFileName.GetLength() == 0)
{
return;
}
// 加載BMP位圖
image.Load( strFileName.GetBuffer( strFileName.GetLength()), CXIMAGE_FORMAT_BMP );
// 判斷圖像是否有效
if (image.IsValid())
{
// 判斷圖像顏色數
if (!image.IsGrayScale())
image.IncreaseBpp( 24 );
// 設置Jpeg圖像的質量
image.SetJpegQuality( 80 );
// 將位圖轉換成JPEG格式圖像
image.Save(”export.jpg”,CXIMAGE_FORMAT_JPG);
}
呵呵,看看效果吧!你已經完成了將指定位圖轉換成JPEG格式的功能!就是這么簡單!
后記
如果各位XDJM按照我的步驟一步一步來,應該是肯定可以成功的!
本文中所述的是在VC++ 6.0中完成。而對于編譯好的庫,在VS2005中也是可以直接用的。如果上述同樣的代碼在VS2005中編譯不能通過,你需要在工程屬性中將字符集設置為Not Set,編譯即可通過!
09年的最后一天!
晚上,互易中國的客服向我提醒說我的域名到期,該續費了,我說不續了。打算以后就在CPP博客安家了。
回首09年,感慨很多。在09年的尾巴尖上,把博客建立起來。
迎接2010。