ひゅうが ねじ 2020-01-03 11:24 采纳率: 0%
浏览 230

matlab链接sql写入数据出现问题,无法写入一整行数据。

向数据库中某一个表插入一整行数据,但是总出现问题,请指教
A=cell(1,72); %A代表列名
for i=1:72 %对列名赋值,为1,2,3,A是元胞数组,
a=i;
b=num2str(i);
% A{1,a}=eval(['[',b,']']);
A{1,a}=b;
end
disp(class(A{1,1}));%判断一下里面的数值类型,为char
S=num2cell(S); %S为即将输入到数据库中的数值
insert(ComponentsData,'second_text_list',A,S);%插入数据,A为列名,S为数据

显示错误
错误使用 database.odbc.connection/insert (line 261)
ODBC Driver Error: [Microsoft][ODBC SQL Server Driver][SQL Server]列名 '1' 无效。

出错 calculate (line 20)
insert(ComponentsData,'second_text_list',A,S);

  • 写回答

1条回答 默认 最新

  • 憧憬blog 2023-03-15 03:35
    关注

    根据你提供的信息,出现的错误可能是由于变量S的数据类型不符合数据库中对应列的数据类型。请使用以下代码检查变量S每一列的数据类型是否和数据库中对应列的数据类型一致:

    C = fetch(ComponentsData, "SELECT * FROM second_text_list")
    disp(cellfun(@class, C, "UniformOutput", false))

    其中,C是从数据库中读取出second_text_list表中的所有数据,cellfun()函数用于将C中每个单元格的数据类型取出来。检查完数据类型后,根据数据库中对应列的数据类型转换变量S中的数据类型,再进行插入操作即可。

    评论

报告相同问题?

悬赏问题

  • ¥15 HFSS 中的 H 场图与 MATLAB 中绘制的 B1 场 部分对应不上
  • ¥15 如何在scanpy上做差异基因和通路富集?
  • ¥20 关于#硬件工程#的问题,请各位专家解答!
  • ¥15 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
  • ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
  • ¥30 截图中的mathematics程序转换成matlab
  • ¥15 动力学代码报错,维度不匹配
  • ¥15 Power query添加列问题
  • ¥50 Kubernetes&Fission&Eleasticsearch
  • ¥15 報錯:Person is not mapped,如何解決?