vs2010上位机与mysql的连接 5C

我把上位机和mysql连起来后,每20ms采集一次数据,程序调试没有错误,但是运行时采集几个数就会提示失败,并且也不是20ms,感觉变成1s了。
void Ca2Dlg::OnStart()
{
// TODO: 在此添加控件通知处理程序代码
RunTimeNumb = 0;
m_RunTime.Format("0");

CTime dt; 
dt=CTime::GetCurrentTime();
UpdateData(0);
SetTimer(0,1000,NULL);
//SetTimer(1,1000,NULL);
SetTimer(2,20,NULL);

}
case 2:
AddDataToLists();
break;
void Ca2Dlg::AddDataToLists()
{
UpdateData(TRUE);

CString local_m_WheelSpeed = m_WheelSpeed.GetBuffer();  

// 创建 MYSQL 对象。  
MYSQL local_mysql;  
// 初始化 MYSQL 对象。  
mysql_init(&local_mysql);  
// 连接数据库  
if(!mysql_real_connect(&local_mysql,"localhost","root","root","test1",3306,NULL,0))  
{  
    AfxMessageBox(_T("connect to database failed!"));  
}  
else  
{  
    //AfxMessageBox(_T("connect to database success!"));  
    // 设置字符集, 使程序支持中文。  设置数据库字符格式,解决中文乱码问题
    mysql_query(&local_mysql, "set names 'gb2312'");  
}  

// 创建 SQL 语句字符串  
CString sql_insert;  
sql_insert.Format("insert into wheel(m_WheelSpeed) values ( \'%s\')",local_m_WheelSpeed);  
// 执行 sql 语句。  
// mysql_query() 的返回值份很多情形, 进行判断使要注意。  
if(mysql_query(&local_mysql,(char*)(LPCTSTR)sql_insert)==0)  
{     
    AfxMessageBox("insert succeed!");     
}else{  
     AfxMessageBox("insert failed!");  
}  
// 关闭 local_mysql 所关联的数据库连接, 一般情况下不用写。  
mysql_close(&local_mysql);  
UpdateData(FALSE); 

}

7个回答

你的代码什么乱七八糟的
case 2:
AddDataToLists();
break;

那么case 1:呢
switch呢。
是不是漏了什么。

数据接收完整么?用串口助手看了么?什么样的数据没有入库,找下规律。

woshi_momomo
woshi_momomo 认同一楼
一年多之前 回复
tyler0318
tyler0318 最好是用多线程来操作
一年多之前 回复
qq_41249513
长腿的叫兽 同意一楼
一年多之前 回复
weixin_41472380
weixin_41472380 同意一楼
一年多之前 回复
caozhy
贵阳老马马善福专业维修游泳池堵漏防水工程 回复qq_40568813: 你应该分为两部分调试,一个是只获取数据,不写数据库,看看行不行,一个是每次获取后,只用硬编码的数据入库,而不使用实际的数据,这样,问题可以缩小一半。
一年多之前 回复
qq_40568813
qq_40568813 我没有截取完整的代码
一年多之前 回复

将mysql-connector-odbc-5.3.4-win32和mysql-essential-5.1.30-win32 安装完毕,因百度经验里已经有详细的安装步骤截图,所以在此处不再演示。

关键点:1、mysql-connector-odbc-5.3.4-win32和mysql-essential-5.1.30-win32 这两个软件一定要同一个位数(这里我用32操作举例)。2、mysql-connector-odbc-5.3.4-win32和mysql-essential-5.1.30-win32 安装时如果要修改安装路径,最好只修改C或D盘符,且一定要都安装到一个盘符里。 打开ODBC数据源,我安装的上面两个软件是32位的,而我的电脑是win7 64位,要到C:\Windows\SysWOW64中去打开odbc32.exe,千万不要直接去控制面板--管理工具中打开数据源。如果你上面的两个软件安装的是64位的,那么要到C:\Windows\System32 中去打开odbc32.exe)数据源(ODBC),在用户DSN选项卡中点击“添加”Mysql的操作步骤,经验中也有,在此也不做详细描述。

20ms 的采用别的方案,windows 的时间响应 我记得是40ms。的的事件响应处理不了这么快,需要别的办法,

qq_40568813
qq_40568813 不是吧,我同学做的把存的数据存成txt文件,也是20ms没什么问题,我想学学mysql,就在他的基础上修改下把采集的数据存到mysql里,但是一直没弄利索,改个程序每次都要弄好久,唉~
一年多之前 回复

新建一个工程名叫mysql,编程环境选择c#,然后选择windows窗体应用程序,新建一个窗体用于显示查询到sql数据库的数据集
vs2010连接mysql数据库
从工具箱向form1窗体上拖一个按钮和datagridview控件,按钮是触发连接数据库获取数据集,按钮的名称为显示,datagridview控件是用于显示数据集内容
vs2010连接mysql数据库
单击解决方案资源管理器中的引用文件夹然后右键选择添加引用,选择浏览后打开mysql.data.dll,这是c#连接mysql数据库的动态库,里面封装了很多常用的操作数据库的方法
vs2010连接mysql数据库
在解决方案资源管理器中的form1.cs的代码中加入using MySql.Data.MySqlClient;这就是代码中的实际引用mysql.data.dll中的内容,有了这个c#就能很方便地操作sql数据库
vs2010连接mysql数据库
在按钮的单击事件中添加如下代码
string str = "Server=127.0.0.1;User ID=root;Password=123456;Database=test;CharSet=gbk;";
MySqlConnection con = new MySqlConnection(str);//实例化链接
con.Open();//开启连接
string strcmd = "select * from user";
MySqlCommand cmd = new MySqlCommand(strcmd, con);
MySqlDataAdapter ada = new MySqlDataAdapter(cmd);
DataSet ds = new DataSet();
ada.Fill(ds);//查询结果填充数据集
dataGridView1.DataSource = ds.Tables[0];
con.Close();//关闭连接
vs2010连接mysql数据库
使用navicat软件在数据库test中新建表user,然后新建两个字段username和password(图中的栏位),navicat软件是mysql的图形化界面工具,负责新建表以及备份等数据库操作,直观地通过界面来操作
vs2010连接mysql数据库
数据库建好后就可以执行工程了,单击显示按钮执行结果如下,出现username和password说明数据库连接成功,由于没有添加数据所以下面为空
vs2010连接mysql数据库
经验内容仅供参考,

qq_40568813
qq_40568813 我是要做一个上位机采下位机的数据,你这个好像不太合适,不过还是很感谢
一年多之前 回复

有可能是时间上的问题,20ms的时间是否是已经确定了,无法修改!!而且window反应的时间也不是这么短,建议修改一下时间

最好是用多线程来操作.20MS时间够短了。

开两个线程,每个线程里跑一个while,周期分别定1s和20ms,用windows精准定时那个思路。settime的定时器不准的

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
请问下位机通过串口线连接的上位机,是怎么和上位机进行日期的同步的
-
想要设计激光雷达测量风速的上位机监控模型,用那种语言比较好
-
c#上位机与单片机通信,上位机接收不到单片机返回的数据
-
使用stm32f1通过串口接收上位机信息产生中断来控制电机,但是中断打不开,想请大佬看看是为什么?
-
上位机串口与stm32连接,如何编写上位机代码
-
通过什么语言写与单片机TTL通讯的上位机软件比较好?
-
stm32与上位机通过网口通信,网口读不出数据?
-
上位机与下位机通讯常用的框架或协议(下位机C语言)
-
求GPRS与PC端通信的上位机源码
-
上位机跨程序不打开端口如何检测上位机是否给下位机回发了数据包?
-
关于数据是否重发,上位机一段的串口可以同时回传数据的么?
-
上位机与usb mass storage设备通信
-
关于C8051F340 USB 通讯上位机的问题?
-
上传数据到上位机以后,下位机是不是不再保持发送的数据?
-
单片机采集到的模拟量和开关量是如何打包通过串口发送到上位机的内存中的?
-
实现上位机和下位机通信
-
怎么从进程外拦截上位机向下位机的通讯数据?
-
帮忙甄别可以实时处理数据的上位机软件
-
上位机向单片机发送字符串
-
学会了这些技术,你离BAT大厂不远了
每一个程序员都有一个梦想,梦想着能够进入阿里、腾讯、字节跳动、百度等一线互联网公司,由于身边的环境等原因,不知道 BAT 等一线互联网公司使用哪些技术?或者该如何去学习这些技术?或者我该去哪些获取这些技术资料?没关系,平头哥一站式服务,上面统统不是问题。平头哥整理了 BAT 等一线大厂的必备技能,并且帮你准备了对应的资料。对于整理出来的技术,如果你掌握的不牢固,那就赶快巩固,如果你还没有涉及,现在...
程序员真是太太太太太有趣了!!!
网络上虽然已经有了很多关于程序员的话题,但大部分人对这个群体还是很陌生。我们在谈论程序员的时候,究竟该聊些什么呢?各位程序员大佬们,请让我听到你们的声音!不管你是前端开发...
史上最详细的IDEA优雅整合Maven+SSM框架(详细思路+附带源码)
网上很多整合SSM博客文章并不能让初探ssm的同学思路完全的清晰,可以试着关掉整合教程,摇两下头骨,哈一大口气,就在万事具备的时候,开整,这个时候你可能思路全无 ~中招了咩~ ,还有一些同学依旧在使用eclipse或者Myeclipse开发,我想对这些朋友说IDEA 的编译速度很快,人生苦短,来不及解释了,直接上手idea吧。这篇文章每一步搭建过程都测试过了,应该不会有什么差错。本文章还有个比较优秀的特点,就是idea的使用,基本上关于idea的操作都算是比较详细的,所以不用太担心不会撸idea!最后,本文
我花了一夜用数据结构给女朋友写个H5走迷宫游戏
起因 又到深夜了,我按照以往在csdn和公众号写着数据结构!这占用了我大量的时间!我的超越妹妹严重缺乏陪伴而 怨气满满! 而女朋友时常埋怨,认为数据结构这么抽象难懂的东西没啥作用,常会问道:天天写这玩意,有啥作用。而我答道:能干事情多了,比如写个迷宫小游戏啥的! 当我码完字准备睡觉时:写不好别睡觉! 分析 如果用数据结构与算法造出东西来呢? ...
接班马云的为何是张勇?
上海人、职业经理人、CFO 背景,集齐马云三大不喜欢的张勇怎么就成了阿里接班人? 作者|王琳 本文经授权转载自燃财经(ID:rancaijing) 9月10日,张勇转正了,他由阿里巴巴董事局候任主席正式成为阿里巴巴董事局主席,这也意味着阿里巴巴将正式开启“逍遥子时代”。 从2015年接任CEO开始,张勇已经将阿里巴巴股价拉升了超过200%。但和马云强大的个人光环比,张勇显得尤其...
让程序员崩溃的瞬间(非程序员勿入)
今天给大家带来点快乐,程序员才能看懂。 来源:https://zhuanlan.zhihu.com/p/47066521 1. 公司实习生找 Bug 2.在调试时,将断点设置在错误的位置 3.当我有一个很棒的调试想法时 4.偶然间看到自己多年前写的代码 5.当我第一次启动我的单元测试时 ...
接私活必备的 10 个开源项目!
点击蓝色“GitHubDaily”关注我加个“星标”,每天下午 18:35,带你逛 GitHub!作者 | SevDot来源 | http://1t.click/VE8W...
Spring高级技术梳理
Spring高级技术梳理 序言正文SpringDate部分Spring全家桶之SpringData——预科阶段Spring全家桶之SpringData——Spring 整合Hibernate与Hibernate JpaSpring全家桶之SpringData——Spring Data JPASpring全家桶之SpringData——SpringData RedisSpringBoot部分Sp...
如何在Windows中开启"上帝模式"
原文链接 : https://mp.weixin.qq.com/s?__biz=MzIwMjE1MjMyMw==&mid=2650202982&idx=1&sn=2c6c609ce06db1cee81abf2ba797be1b&chksm=8ee1438ab996ca9c2d0cd0f76426e92faa835beef20ae21b537c0867ec2773be...
飞天智能:阿里云的 AI 落地野心
当下,AI 业界不会否认的一个事实是,AI实力的比拼不再是单点的算法技术能力,而是从底层算法到应用平台的全面AI能力。单纯的算法,只是实验室里的乐趣,唯有结合商业的数据处...
为什么平头哥做芯片如此迅猛?
作者 | 胡巍巍 发自杭州云栖大会 责编 | 唐小引 出品 | CSDN(ID:CSDNnews) 2018年10月31日,阿里旗下的平头哥半导体有限公司成立。 如今,平头哥成立不到一年,就已成绩斐然。 2019年9月25日,阿里巴巴旗下半导体公司平头哥,发布含光800芯片。 2019年7月25日,平头哥发布成立后第一个基于RISC-V的处理器IP Core玄铁910。...
分享靠写代码赚钱的一些门路
作者 mezod,译者 josephchang10如今,通过自己的代码去赚钱变得越来越简单,不过对很多人来说依然还是很难,因为他们不知道有哪些门路。今天给大家分享一个精彩...
技术人员要拿百万年薪,必须要经历这9个段位
很多人都问,技术人员如何成长,每个阶段又是怎样的,如何才能走出当前的迷茫,实现自我的突破。所以我结合我自己10多年的从业经验,总结了技术人员成长的9个段位,希望对大家的职...
多线程编程是后台开发人员的基本功
这里先给大家分享一个小故事:在我刚开始参加工作的那年,公司安排我开发一款即时通讯软件(IM,类似于 QQ 聊天软件),在这之前我心里也知道如果多线程操作一个整型值是要加锁...
分布式、多线程、高并发都不懂,拿什么去跳槽
当提起这三个词的时候,是不是很多人都认为分布式=高并发=多线程?当面试官问到高并发系统可以采用哪些手段来解决,或者被问到分布式系统如何解决一致性的问题,是不是一脸懵逼?确...
动画:用动画给面试官解释 TCP 三次握手过程
作者 | 小鹿 来源 | 公众号:小鹿动画学编程 写在前边 TCP 三次握手过程对于面试是必考的一个,所以不但要掌握 TCP 整个握手的过程,其中有些小细节也更受到面试官的青睐。 对于这部分掌握以及 TCP 的四次挥手,小鹿将会以动画的形式呈现给每个人,这样将复杂的知识简单化,理解起来也容易了很多,尤其对于一个初学者来说。 学习导图 一、TCP 是什么? TCP(Transmissio...
为什么程序员在学习编程的时候什么都记不住?
在程序员的职业生涯中,记住所有你接触过的代码是一件不可能的事情!那么我们该如何解决这一问题?作者 |Dylan Mestyanek译者 | 弯月,责编 | 屠敏出品 |...
500行代码,教你用python写个微信飞机大战
这几天在重温微信小游戏的飞机大战,玩着玩着就在思考人生了,这飞机大战怎么就可以做的那么好,操作简单,简单上手。 帮助蹲厕族、YP族、饭圈女孩在无聊之余可以有一样东西让他们振作起来!让他们的左手 / 右手有节奏有韵律的朝着同一个方向来回移动起来! 这是史诗级的发明,是浓墨重彩的一笔,是…… 在一阵抽搐后,我结束了游戏,瞬时觉得一切都索然无味,正在我进入贤者模式时,突然想到,如果我可以让更多人已不同的方式体会到这种美轮美奂的感觉岂不美哉? 所以我打开电脑,创建了一个 `plan_game.py`……
2019诺贝尔经济学奖得主:贫穷的本质是什么?
2019年诺贝尔经济学奖,颁给了来自麻省理工学院的 阿巴希·巴纳吉(Abhijit Vinayak Banerjee)、艾丝特·杜芙若(Esther Duflo)夫妇和哈...
linux:最常见的linux命令(centOS 7.6)
最常见,最频繁使用的20个基础命令如下: 皮一下,这都是干货偶,大佬轻喷 一、linux关机命令: 1.shutdown命令安全地将系统关机(推荐)参数说明: [-r] 重启计算器。 [-h] 关机后关闭电源〔halt〕。 [-c] cancel current process取消目前正在执行的关机程序。 [-time] 设定关机〔shutdown〕前的时间。 shutdown -h now ...
只因写了一段爬虫,公司200多人被抓!
“一个程序员写了个爬虫程序,整个公司200多人被端了。” “不可能吧!” 刚从朋友听到这个消息的时候,我有点不太相信,做为一名程序员来讲,谁还没有写过几段爬虫呢?只因写爬虫程序就被端有点夸张了吧。 朋友说,消息很确认并且已经进入审判阶段了。 01.对消息进一步确认 朋友认识几个律师朋友,和他们有一些业务来往,得知他们想尝试把业务扩展到程序员这个群体。那段时间我刚好离职也有时间,在朋友...
相关热词 c# mvc 上传 文件 c#扫描软件 c# 文字打印左右反转 c#byte转换成数字 c# 音量调节组件 c# wpf 界面 c# 读取证书文件的内容 c# 单例模式 工厂模式 c# dgv 树结构 c#继承 反序列化