楼主: weitingkoala
9370 7

[转]Matlab和SQL Server数据库编程(通过ODBC) [推广有奖]

已卖:77份资源

学科带头人

13%

还不是VIP/贵宾

-

TA的文库  其他...

应用量化研究

威望
2
论坛币
7789 个
通用积分
51.6314
学术水平
321 点
热心指数
290 点
信用等级
298 点
经验
8986 点
帖子
424
精华
7
在线时间
1325 小时
注册时间
2010-5-7
最后登录
2025-2-26

楼主
weitingkoala 发表于 2014-2-14 09:38:50 |AI写论文

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

求职就业群
赵安豆老师微信:zhaoandou666

经管之家联合CDA

送您一个全额奖学金名额~ !

感谢您参与论坛问题回答

经管之家送您两个论坛币!

+2 论坛币
转自:http://www.matlabsky.com/forum.php?mod=viewthread&tid=10302,感谢作者的无私奉献

Matlab数据库编程指南-Godman

Matlab与数据库链接有三种方法,本文只讲述其中以ODBC的方式进行链接。

本文件包含四部分,其中第三部分为我自己写的一些数据库函数操作的函数,第四部分为网上的一些资料。

如有疑问可以邮件联系 tntuyh@163.com
Godman
2009.3.30 Good Luck

第一部分:读取数据其相关信息查看

1.
配置数据源

“控制面板”----“管理工具”——“数据源(ODBC)”——“添加”——“创建数据源名称和选择数据库文件”

图解:http://wenku.baidu.com/link?url= ... lF1IYDiCiOLWor-hY__

2.
建立链接对象——database

调用格式:

conna=database(‘datasourcename’,’username’,’password’);

conna=database('SampleDB','','');其中SampleDB为上文中创建的数据源名称,当默认情况下,数据库文件的usernamepassword为空。

3.
建立并打开游标——exec

调用格式:

curs=exec(conna,'sqlquery')

curs=exec(conna,'select *from database')

其中conna为上文中链接对象,select * from database表示从表database中选择所有的数据.

4.
把数据库中的数据读取到Matlab中——fetch

调用格式:

curs=fetch(curs,RowLimit);

Data=curs.Data%把读取到的数据用变量Data保存.

curs=fetch(curs)

把所有的数据一次全部读取到Matlab中,RowLimit为每次读取的数据参数的行数,默认为全部读取,但是全部读取会很费时间(和计算机性能很大关系)。

上述四点是matlab从数据库文件中读取数据到matlab中的基本步骤。

5.
数据返回类型

从数据库中读取数据到matlab有三种数据类型(默认为元胞类型cellarray),分别为元胞类型(cellarray),数字型(numeric),结构型(structure)。可以在链接数据库之前通过setdbprefs函数来进行设置。如果数据库文件中全部是数值型数据时最好采用numeric型的数据,这样可以使得读取速度大幅提高,特别是在大型数据读取时非常明显。我曾经从数据库中读取过100万个数据,用cellarray时用了16s,但是用numeric时却只用了8s,速度提高很大啊,对电脑配置不好的来说,很有帮助的。(还有我的电脑很烂,1.3GHz384M内存,可能让大家见笑了…….

调用格式:

setdbprefs(‘datareturnformat’,’numric’)

6.
养成良好习惯,随手关闭链接对象和游标——close

当不再使用数据库的链接对象时要及时关闭,这样才能及时的释放出内存,而且每次链接后所需要的内存量是非常大的,要是不及时关闭的话对后续计算的影响将非常非常的大。( 针对烂机子而言,要是你的电脑超强也无所谓的…..)

调用格式:

close(curs)

close(conna)

7.
查看数据相关信息

Rows-查看数据行数

调用格式:numrows=rows(curs)

Cols——查看数据列数

调用格式:numcols=cols(curs)

Attr——查看数据属性

调用格式:attribute=attr(curs)


第二部分:把数据写入到数据库中

8.
添加数据到表中——insert函数

调用格式:

insert(conna,’tab’,colnames,exdata)

conna——链接对象

tab——数据库文件的表名

colnames——数据库表的列名

exdata——matlab变量

如:insert(conna,'try',{'a1', 'a2'},[45 65])


commit(conna)%
确认数据更改

9.
更新数据库中的数据——update

调用格式:

update(conna,’tab’,colnames,exdata,’whereclause’)

conna——链接对象

tab——数据库文件的表名

colnames——数据库表的列名

exdata——matlab变量

whereclause——SQLwhere字句

如:update(conna,'try',{'a1', 'a2'},[45 65],’where XX=’XX’’)

commit(conna)%确认数据更改

10.
建立新表——exec,creat table

调用格式:

conna=database('SampleDB','','');

exec(conna,['create table Table(name string,age int)']);

close(conna);

Table——表名

nameage——字段名


以上部分是从董振海写的《精通MATLAB7编程与数据库应用》中根据我使用databasetoolbox的经验摘抄的,在此向作者致谢。







第三部分:自己写的相关函数

下面是我在matlab的数据库分析项目的过程中自己写的和用到的关于数据库操作的相关函数的介绍:

详见开头链接,人大经济论坛有字数限制。

再次感谢作者,让我等有资料参考





二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

关键词:Server MATLAB matla 数据库编程 Serve 数据库编程

已有 1 人评分经验 论坛币 学术水平 热心指数 信用等级 收起 理由
fantuanxiaot + 20 + 10 + 2 + 2 + 2 精彩帖子

总评分: 经验 + 20  论坛币 + 10  学术水平 + 2  热心指数 + 2  信用等级 + 2   查看全部评分

本帖被以下文库推荐

沙发
sheva0728 在职认证  发表于 2014-2-22 17:09:18 来自手机
weitingkoala 发表于 2014-2-14 09:38
转自:http://www.matlabsky.com/forum.php?mod=viewthread&tid=10302,感谢作者的无私奉献
Matlab数据库编 ...
感谢楼主!果断马克!

藤椅
dengjiaqi03 发表于 2014-3-12 12:33:27
刘明,楼主真好人

板凳
浪荡乞丐 在职认证  发表于 2014-5-22 18:45:56
赞一个

报纸
fantuanxiaot 发表于 2014-12-27 13:12:28
不错!!!!!

地板
fantuanxiaot 发表于 2014-12-27 13:13:49
好帖子不能沉!!

7
fantuanxiaot 发表于 2014-12-27 13:13:54
好帖子不能沉!!

8
lingvincent 发表于 2016-8-21 12:52:14
学习了!谢谢

您需要登录后才可以回帖 登录 | 我要注册

本版微信群
加好友,备注cda
拉您进交流群
GMT+8, 2025-12-31 03:51