本来想一直这么写着,写完增删,写修改,写完遍历(查询,用多了C++,习惯说遍历)数据库。但是,我最近有点累,速度结束吧。不过,我依旧愿意做到最好。
还是先交待一下,需要有点C++的知识,不要太多,就是派生和一点点异常的知识,同时有点Mysql的Sql操作即可。
先回忆之前的3篇文章,建议看过了再来开始这里:
visual c++ 2008进行MySQL编程(ODBC) -- (一) 套装安装
visual c++ 2008进行MySQL编程(ODBC) --二 操作数据库
visual c++ 2008进行MySQL编程(ODBC) --三 查询数据库
visual c++ 2008进行MySQL编程(ODBC)-- (四) 终极实现 之 派生CRecordset 上
visual c++ 2008进行MySQL编程(ODBC)-- (四) 终极实现 之 派生CRecordset 中
visual c++ 2008进行MySQL编程(ODBC)-- (四) 终极实现 之 派生CRecordset 下
我的邮箱:[email protected] 有什么疑问如果不能在回复里面说清楚,就邮件@我吧。
前面的文章里面说到的,对Mysql数据库增删和修改都是通过自己生成一个字符串,也就是一个mysql的sql执行语句,然后执行这个Sql语句,如果在这么场合:
如果我有一个表,有20个变量,先不说这个表合理不合理,这种情况,不管是是什么操作,生成一条sql语句,那就相当的长的一条sql语句。
而且,后续的维护将是崩溃的开始,每次数据库增删变量,又要把生成sql语句的地方仔细拿出来,往死里搞一遍,怕出错,怕遗漏,怕死。。。。。。
所以,微软做了一个终极的实现,CRecordset应运而生,之需要派生这个类,添加和注册一些变量。自然就可以了。
1、开启工程,也就是我前面说的my_db这个vc工程。
2、选择类视图,在工程上右键,添加新类,如下图1:
3、如图2,点击MFC,选择ODBC Consumer,点击添加
4、点击data source,也就是选择数据源,如图3:
5、选择“机器数据源”,就可以看到,在第一个介绍数据库的文章里面提到的,设置一个叫chh1的数据源的,具体链接:http://blog.csdn.net/ztz0223/article/details/7614091,如图4:
6、弹出的界面就很熟悉了吧,如图5:
7、选择一个表,这里我选择costomer表,点击ok,如图6:
8、弹出如下类,有一个绑定所有量,这个不要勾选。那么这个是干嘛的呢?这个是让vc自动帮我们生成一些变量来自动绑定我们Mysq这个表的一些变量的。微软这个这个貌似仅仅支持他们Sql server数据库。如图7:
此处再说明一下,Bind all columns,这在VS 2008里面不能支持的,但是在VS 2012里面,已经支持了,想怎么用就怎么用了。
9、点击完成,如图,在类视图里面就多出了一个刚才建立的Ccustomer类了,也会生成相应的customer类的头文件和实现文件,如图8:
10、派生的过程就算是完成了,接着开始注册变量,完成代码的部分即可,下一讲继续代码实现。