uniDBGrid导入数据库(转红鱼儿)

有朋友问如何将excel导入数据库,这是我做的uniGUI项目中代码,实现uniDBGrid导入数据库的函数,因为用了kbmMW,所以你看到是将uniDBGrid导入kbmMWClientQuery,然后提交的ClientQuery到数据库。共享了!

function ImportFromFile(aDataSet: TkbmMWClientQuery; aGrid:
TUniDBGrid; aFileName: string): Boolean;
var

r, c, i: integer;
  // v: TCellValue;
  xls: TExcelfile;
begin
  aDataSet.DisableControls;
  xls := TXlsFile.Create(False);
  try
   
xls.Open(aFileName);
   
xls.ActiveSheet := 1;

for r := 2
to xls.RowCount do
    begin
     
if not IsBlankRow(xls, r) then // 不是空行则填加
     
begin
       
aDataSet.Append;
       
for i := 0 to aGrid.Columns.Count - 1 do
       
begin
         
c := GetColByName(xls, aGrid.Columns[i].Title.Caption);
         
if c <> -1 then
         
begin
           
case aDataSet.FieldByName(aGrid.Columns[i].FieldName).DataType
of
             
ftDateTime, ftDate:
               
aDataSet.FieldByName(aGrid.Columns[i].FieldName).AsDateTime :=
xls.GetCellValue(r, c).ToDateTime(False);
           
else
             
aDataSet.FieldByName(aGrid.Columns[i].FieldName).AsString :=
xls.GetCellValue(r, c)
               
.ToString.Replace(‘ ‘, ‘‘).Replace(‘‘‘‘, ‘‘);
           
end;
         
end;
       
end;

aDataSet.Post;
     
end;
    end;
    result :=
aDataSet.Resolve;

finally
   
aDataSet.EnableControls;
   
xls.Free;
  end;
end;

时间: 2024-08-11 07:41:23

uniDBGrid导入数据库(转红鱼儿)的相关文章

atitit.sql server2008导出导入数据库大的表格文件... oracle mysql

atitit.sql server2008导出导入数据库大的表格文件... 1. 超过80M的文件是不能在查询分析器中执行的 1 2. Oracle ,mysql大的文件导入 1 2.1. 使用sql文件 1 2.2. 使用dmp二进制文件(oracle only) 1 2.3. Other 导出txt,excel在导入( 不推荐),常常不能导入 1 3. 本机导入 1 4. 远程导入 2 5. syaolon msg 2 6. 参考 3 1. 超过80M的文件是不能在查询分析器中执行的 imE

[转载红鱼儿]delphi 实现微信开发(2)接入微信公众号平台

先要学习一下接入的资料,在这里,因为原理都在,所以一定要认真阅读,然后,利用Delphi实现一个对应函数: function CheckSignature(const signature, timestamp, nonce, token: string): boolean; var strs: TStringList;   tmpStr: string; begin strs := TStringList.Create;   try     strs.Add(token);     strs.A

通过EA导入数据库存在表结构并生成文档

通过EA导入数据库存在表结构并生成文档 慕课网,程序员升职加薪神器,点击免费学习 目录[-] 导入数据源,表结构 生成表结构的文档 Enterprise Architect 是超级强大项目管理功能,个人尤其喜欢它的反响生成功能. 导入数据源,表结构 以下是将原有的数据结构导入到EA 首先创建好项目后,添加Data Model package 右键项目 —- add — add a new model 创建好model之后 在Data Model 下的 Schemal 右键 code engine

Java实现Excel导入数据库,数据库中的数据导入到Excel

实现的功能: Java实现Excel导入数据库,如果存在就更新 数据库中的数据导入到Excel 1.添加jxl.jar mysql-connector-java.1.7-bin.jar包到项目的lib目录下­ 2.Excel文件目录:D://book.xls 3.数据库名:javenforexcel 4.表名:stu 5.编写类:连接mysql的字符串方法.插入的方法.实体类­­ 表结构如下 : 连接数据库的工具类 package com.javen.db; import java.sql.Co

几个数据库的小案例(一):将文本文件中的信息导入数据库的表中

从文本文件添加到数据库用户表的记录(有两个文件:frmMain.cs  SqlHelper.cs  ) //FrmMain.cs//作者:Meusing System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Linq; using System.Text; using System.Windows.Fo

导入数据库出现html lang=&#39;zh&#39; dir=&#39;ltr&#39; class=&#39;ie ie7错误代码解决方法

今天遇到一个客户导入数据库错误的问题,导入后出现错误代码如下: <!DOCTYPE HTML><html lang='zh' dir='ltr' class='ie ie7'><meta charset="utf-8" /><meta name="robots" content="noindex,nofollow" /><meta http-equiv="X-UA-Compatibl

jeesite导入数据库错误:java.sql.SQLException: Incorrect string value: &#39;\xE4\xB8\xAD\xE5\x9B\xBD&#39; for column &#39;name&#39; at row 1问题解决

如果使用mvn antrun:run -Pinit-db进行数据库导入导致出现如下错误: 解决方法: 这个是由于新建数据库没有选择默认字符集导致的,只要选择utf-8即可. jeesite导入数据库错误:java.sql.SQLException: Incorrect string value: '\xE4\xB8\xAD\xE5\x9B\xBD' for column 'name' at row 1问题解决

python之TXT数据导入数据库

为了导入数据,可以先对数据做些处理,让其更容易导入数据库 #!/usr/bin/python #coding=utf-8 import _mysql,sys,time #读入数据函数 def add_data(id,name,created_time):     try:         conn=_mysql.connect('127.0.0.1','root','')         conn.query("set names utf8")         conn.query(&

PHP读取CSV大文件导入数据库的示例

对于数百万条数据量的CSV文件,文件大小可能达到数百M,如果简单读取的话很可能出现超时或者卡死的现象. 为了成功将CSV文件里的数据导入数据库,分批处理是非常必要的. 下面这个函数是读取CSV文件中指定的某几行数据: /** * csv_get_lines 读取CSV文件中的某几行数据 * @param $csvfile csv文件路径 * @param $lines 读取行数 * @param $offset 起始行数 * @return array * */ function csv_get