




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、.使用Labwindow CVI软件平台进行Mysql数据库开发简介针对初学者进行数据库开发,不是很了解相应过程,现将我刚刚成功的验证过程,与大家分享。文中主要描述不能使用映射方式修改数据库中数据的问题。1. CVI版本为9.0(348),NI SQL Toolkit 2.2请前往 下载试用版软件系统!2. MySQL版本为5.6.221、 安装MySQL过程可参考网上的说明,如网络上,MySQL下载与安装5.6.10.1安装图解请前往处下载开源数据库系统MySQL3. 使用王建新老师的例程进行学习4. 更改了修改数据按钮中的代码备注:1、 通过更换SQL Toolkit2.1改为2.2后,还
2、是不能修改MySQL已存在数据库中数据的问题。2、 不使用映射的方式进行更新数据库数据,这种方式能满足Access创建的数据库,但是不能修改MySQL创建的数据库,原因不知,希望有高手指点 3、 更改为使用SQL直接进行更改数据,实现更改表中一条数据的功能。谢谢LabWindows/CVI交流群 20328398里各位老师的奉献!修改后的代码:#include cvi_db.h#include #include #include #include #include #include databasesample.hstatic int hdbc;static int globalvalue;s
3、tatic int panelHandle;int main (int argc, char *argv)if (InitCVIRTE (0, argv, 0) = 0)return -1;/* out of memory */if (panelHandle = LoadPanel (0, databasesample.uir, PANEL) 0) /对于带参数的数据库查询,首先准备执行SQL查询声明hstat = DBPrepareSQL (hdbc, DELETE FROM table2 WHERE ID = ?);/创建一个整型量参数预备查询方式resultcode = DBCreate
4、ParamInt (hstat, , DB_PARAM_INPUT, value);/执行带参数的SQL查询resultcode = DBExecutePreparedSQL (hstat);DBClosePreparedSQL (hstat);/刷新数据readdata (panel, PANEL_CMD_READDATA, EVENT_COMMIT, NULL, 0, 0); break;return 0;/插入记录int CVICALLBACK insertdata (int panel, int control, int event,void *callbackData, int ev
5、entData1, int eventData2)int resultcode;int hstat;int numberofrecords;switch (event)case EVENT_COMMIT:/激活SQL查询hstat = DBActivateSQL (hdbc, SELECT * FROM table2);/获得记录总数numberofrecords = DBNumberOfRecords (hstat);DBDeactivateSQL (hstat);/带参数查询hstat = DBPrepareSQL (hdbc, INSERT INTO table2 VALUES (?,
6、, , 0);resultcode = DBCreateParamInt (hstat, ID, DB_PARAM_INPUT, numberofrecords + 1);resultcode = DBExecutePreparedSQL (hstat);DBClosePreparedSQL (hstat); /刷新数据readdata (panel, PANEL_CMD_READDATA, EVENT_COMMIT, NULL, 0, 0); break;return 0;/修改记录int CVICALLBACK modifydata (int panel, int control, int
7、 event,void *callbackData, int eventData1, int eventData2)char labeltext10;int comparisonresult;int hstat;int value;Point colrow;/设置i为静态局部变量,在本函数内部值不会丢失static int i = 1;long agestatus;int agevalue;long sexstatus;char sexvalue10;int resultcode;long idstatus;int idvalue;long namestatus;char namevalue1
8、0;char SqlCommand200;int hmap;switch (event)case EVENT_COMMIT:/设置表格为可修改状态SetCtrlAttribute (panelHandle, PANEL_TABLE, ATTR_CTRL_MODE, VAL_HOT);/以下程序表示:当点击“修改”按钮时,按钮标签将变为“保存”if (i)SetCtrlAttribute (panelHandle, PANEL_CMD_MODIFY, ATTR_LABEL_TEXT, 保存);i = 0;elseSetCtrlAttribute (panelHandle, PANEL_CMD_M
9、ODIFY, ATTR_LABEL_TEXT, 修改); SetCtrlAttribute (panelHandle, PANEL_TABLE, ATTR_CTRL_MODE, VAL_INDICATOR);i = 1;/得到按钮的标签文本GetCtrlAttribute (panelHandle, PANEL_CMD_MODIFY, ATTR_LABEL_TEXT, labeltext);/将得到的文本与“修改”二字相对照comparisonresult = strcmp (labeltext, 修改);/如果确定标签文本上的字符就是“修改”二字,则执行以下操作if (comparisonr
10、esult = 0)/当联接数据库成功时进行下面操作if (hdbc 0) memset(SqlCommand,0,200);/一次修改只能修改最后触发的行数据,否则将以下代码放到表格控件的事件函数中GetTableCellVal (panelHandle, PANEL_TABLE, MakePoint(2, globalvalue), namevalue);GetTableCellVal (panelHandle, PANEL_TABLE, MakePoint(3, globalvalue), sexvalue); GetTableCellVal (panelHandle, PANEL_TA
11、BLE, MakePoint(4, globalvalue), &agevalue);sprintf(SqlCommand,UPDATE table2 SET NAME=%s,SEX=%s,AGE=%d WHERE ID=%d;,namevalue,sexvalue,agevalue,globalvalue);/带参数更新hstat = DBPrepareSQL (hdbc, SqlCommand);resultcode = DBExecutePreparedSQL (hstat);DBClosePreparedSQL (hstat); break;return 0;/删除数据表int CVI
12、CALLBACK deletetable (int panel, int control, int event,void *callbackData, int eventData1, int eventData2)int hstat;switch (event)case EVENT_COMMIT:DisableBreakOnLibraryErrors ();/激活SQL查询hstat = DBActivateSQL (hdbc, SELECT * FROM table2);/如果表存在数据,执行如下操作if (hstat 0)/释放被激活句柄DBDeactivateSQL (hstat);/删
13、除数据表DBImmediateSQL (hdbc, DROP TABLE table2); DeleteTableRows (panelHandle, PANEL_TABLE, 1, -1);SetCtrlAttribute (panelHandle, PANEL_CMD_READDATA, ATTR_DIMMED, 1);break;return 0;/创建数据表int CVICALLBACK createtable (int panel, int control, int event,void *callbackData, int eventData1, int eventData2)lo
14、ng agestatus;int agevalue;long sexstatus;char sexvalue10;long namestatus;char namevalue10;int resultcode;long idstatus;int idvalue;int hmap;switch (event)case EVENT_COMMIT:/创建一个数据库映射hmap = DBBeginMap (hdbc);resultcode = DBMapColumnToInt (hmap, ID, &idvalue, &idstatus);resultcode = DBMapColumnToChar
15、(hmap, NAME, 10, namevalue, &namestatus, );resultcode = DBMapColumnToChar (hmap, SEX, 10, sexvalue, &sexstatus, );resultcode = DBMapColumnToInt (hmap, AGE, &agevalue, &agestatus);/由此映射创建一个数据表resultcode = DBCreateTableFromMap (hmap, table2);if (resultcode = 0)/向数据表中添加数据DBImmediateSQL (hdbc, INSERT IN
16、TO table2 VALUES (1, 杨过, 男, 23);DBImmediateSQL (hdbc, INSERT INTO table2 VALUES (2, 小龙女, 女, 29);DBImmediateSQL (hdbc, INSERT INTO table2 VALUES (3, 周伯通, 男, 78); DBDeactivateMap (hmap); SetCtrlAttribute (panelHandle, PANEL_CMD_READDATA, ATTR_DIMMED, 0); break;return 0;/读取数据,即刷新数据int CVICALLBACK readd
17、ata (int panel, int control, int event,void *callbackData, int eventData1, int eventData2)long agestatus;int agevalue;long sexstatus;char sexvalue10;long namestatus;char namevalue10;int resultcode;long idstatus;int idvalue;int hstat;int total = 0;int i = 1;switch (event)case EVENT_COMMIT:DisableBrea
18、kOnLibraryErrors ();/激活SQL查询hstat = DBActivateSQL (hdbc, SELECT * FROM table2);/以下操作为将每列字段绑定到相关变量中resultcode = DBBindColInt (hstat, 1, &idvalue, &idstatus);resultcode = DBBindColChar (hstat, 2, 10, namevalue, &namestatus, );resultcode = DBBindColChar (hstat, 3, 10, sexvalue, &sexstatus, );resultcode
19、 = DBBindColInt (hstat, 4, &agevalue, &agestatus);/获得记录的总数total = DBNumberOfRecords (hstat);/删除面板中的表格控件所有行DeleteTableRows (panelHandle, PANEL_TABLE, 1, -1);/插入与数据表中记录数相同的行数InsertTableRows (panelHandle, PANEL_TABLE, 1, total, VAL_USE_MASTER_CELL_TYPE);if (total 0)/利用数据指针逐行写入面板表格控件中while (DBFetchNext(
20、hstat) != DB_EOF)SetTableCellVal (panelHandle, PANEL_TABLE, MakePoint(1,i), idvalue);SetTableCellVal (panelHandle, PANEL_TABLE, MakePoint(2,i), namevalue);SetTableCellVal (panelHandle, PANEL_TABLE, MakePoint(3,i), sexvalue);SetTableCellVal (panelHandle, PANEL_TABLE, MakePoint(4,i), agevalue);i+;DBDe
21、activateSQL (hstat);break;return 0;int CVICALLBACK tableCB (int panel, int control, int event,void *callbackData, int eventData1, int eventData2)int value;Point colrow;switch (event)/当在面板中的表格控件中双击时,产生以下操作case EVENT_LEFT_DOUBLE_CLICK:/获得活动表格当前的行与列GetActiveTableCell (panelHandle, PANEL_TABLE, &colrow)
22、;/获得本行一列中数据的ID号GetTableCellVal (panelHandle, PANEL_TABLE, MakePoint(1, colrow.y), &value);/将ID号作为全局变量处理globalvalue = value;break;return 0;修改前的部分代码:int CVICALLBACK Modifydata (int panel, int control, int event,void *callbackData, int eventData1, int eventData2)char labeltext10;int comparisonresult;in
23、t resultcode;int hstat;int value;Point colrow;/设置i为静态局部变量,在本函数内部值不会丢失static int i = 1;long agestatus;int agevalue;long sexstatus;char sexvalue10;long namestatus;char namevalue10;long idstatus;int idvalue;int hmap;switch (event)case EVENT_COMMIT:/设置表格为可以修改状态SetCtrlAttribute (panelHandle,PANEL_TABLE,
24、ATTR_CTRL_MODE, VAL_HOT);/以下部分表示,当点击修改按钮时,按钮标签将变为“保存”if(i)SetCtrlAttribute (panelHandle,PANEL_COMMANDBUTTON_8, ATTR_LABEL_TEXT, 保存);i = 0;elseSetCtrlAttribute (panelHandle,PANEL_COMMANDBUTTON_8, ATTR_LABEL_TEXT, 修改);SetCtrlAttribute (panelHandle,PANEL_TABLE, ATTR_CTRL_MODE, VAL_INDICATOR);i = 1;/获得按钮标签文本数据GetCtrlAttribute (panelHandle,PANEL_COMMANDBUTTON_8, ATTR_LABEL_TEXT,labeltext);/将得到的文本与“修改”二字进行比照comparisonresult = strcmp(labeltext,修改);/如果确定标签文本上的字符为“修改”二字,则执行以下操作if(comparisonresult =
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 榨汁机维护预案
- 家电维修保养规定及操作细则总结
- 如何提高初高中学生的学习兴趣
- 纺织服饰制作指南
- 化学工业排放标准报告
- 2025浙江杭州市城乡建设委员会所属部分事业单位招聘编外聘用人员2人笔试备考试题及答案解析
- 心理咨询在职场中的应用策略与实践
- 楼盘销售推广策略实施方案
- 社会治理模式创新及其效果
- 2025土地估实务基础:土地估价的概念考试试题
- 贵州省桐梓县狮溪铝多金属(含锂)普查项目环境影响评价报告表
- 吉林省梅河口市2025年上半年公开招聘辅警试题含答案分析
- 日间手术课件
- 灭火和应急疏散预案演练制度(足浴会所)
- 清产核资业务培训课件
- 2025年高等教育心理学模拟题(含答案)
- 2025年部编版新教材语文七年级上册教学计划(含进度表)
- (2025秋)人教版二年级数学上册全册教案(新教材)
- 2025-2026学年闽教版三年级英语上册全册教案
- 2025中国移动贵州公司秋季校园招聘笔试参考题库附带答案详解(10套)
- 施工单位年度业绩汇报
评论
0/150
提交评论