Access交流网
  • 设为首页|收藏本站|繁体中文|手机版
  •     
  • Access培训-Access开发平台-Access行业开发

  • 首页
  • 资讯
  • 技巧
  • 源码
  • 行业
  • 资源
  • 活动
  • 关于

技巧

ACCESS数据库

启动/设置/选项/背景

修复/压缩

安全/加密/解密

快捷键

版本升级/其它等

数据表

命名方式/设计规范

表设计

查询

Sql语言基础

选择查询

更新查询

删除查询

追加查询

生成表查询

交叉表查询

SQL特定查询

查询参数

查询综合应用

界面/窗体/控件

标签

文本框

命令按钮

组合框/列表框

选项组/复选框/选项按钮

选项卡

子窗体

窗体本身/综合应用

其它

报表打印

报表设计

高级报表

模块/函数/VBA/API/系统

VBA基础

内置函数

调试/跟踪/Debug

模块/类模块

API/COM/系统相关

字符数字日期

网络通信游戏

加密解密安全

文件处理

经典算法

宏/菜单/工具栏/功能区

宏/脚本

菜单/工具栏

功能区/Ribbon

图表/图形/图像/多媒体

图表

图形/图像

音频

视频/动画

DAO/链接表/ADO/ADP

DAO/链接表/ODBC

ADO/RDO

ADP

ActiveX/第三方控件/插件

Treeview树控件

ListView列表控件

Toolbar工具栏控件

微软其它控件

Dbi-Tech

CodeJock

Grid++Report

FastReport

ComponentOne

加载项/插件/Addin

OFFICE集成/导入导出/交互

Excel导入导出/交互

Word导入导出/交互

PPT交互

Outlook控制/邮件

Text文本文件/INI/CSV

PDF/SWF/XML格式

CAD格式

Sharepoint/其它Office

SqlServer/其它数据库

表

视图

存储过程/触发器

函数

用户/权限/安全

调试/维护

SqlServer其它/综合

发布/打包/文档/帮助

开发版/运行时

打包/发布/部署

开发文档/帮助制作

Access完整行业系统

采购管理系统

销售管理系统

仓库管理系统

人力资源管理HRM

CRM管理系统

MRP/ERP管理系统

BRP/流程优化

其它管理系统

心得/经验/绝招
其它/杂项
Excel技巧

Excel应用与操作

Excel开发编程

Word技巧

Word应用与操作

Word开发编程

Outlook技巧

Outlook应用与操作

Outlook开发编程

热门文章

  • access的真假:四、"..
  • 从B窗循环追加记录到A窗的..
  • 一条“INSERT INT..
  • insert into 和..
  • insert into 一..
  • 追加查询INSERT IN..

最新文章

  • insert into 一..
  • SQL数据库中select..
  • access的真假:四、"..
  • 追加查询INSERT IN..
  • insert into 和..
  • 一条“INSERT INT..

联系方式

Access交流网(免费Access交流)

QQ:18449932 

网  址:www.access-cn.com

当前位置:首页 > 技巧 > 查询 > 追加查询
追加查询

access的真假:四、"SELECT * INTO 工作表 FROM 临时表" 比 "CREATE TABLE 工作表 (...)" 速度快?

下面这个贴子中讨论了很多ACCESS中的一些猜想假设。

Access或其它数据库操作效率问题.欢迎讨论

http://topic.csdn.net/u/20090514/10/a93475bd-e67e-45c8-aa1e-87168ba36d02.html#replyachor

引用 55 楼 wwwwb 的回复::
create table是用什么方法?我一般是将空的工作表另存为一个临时表, 
用SELECT * INTO 工作表 FROM 临时表 方法建立,这种方法比delete from table 
还要慢? 
这种方法的局限是如果有表间关系是不能删除的。
 
当看到这个猜想的时候,感觉比较怀疑。因为 select * into newtable from oldTable,ACCESS需要先从oldTable得到所有字段的定义,然后才能进行表的创建。如果猜想成立,就说明ACCESS还有一套什么机制可以直接在底层对表的结构进行访问。但select 可以是任意的查询,这样也不太可能啊。 于是,依然做个简单的试验来难证一下这个猜想。

新建空 t.mdb ,然后创建一个模块,代码如下。

view plaincopy to clipboardprint?
Option Compare Database   
Option Explicit   
  
Public Sub ti()   
    Dim ssql As String  
    Dim conn As ADODB.Connection   
    Set conn = CurrentProject.Connection   
       
    ssql = "create table table2(id integer,cname char(10))"  
    conn.Execute ssql   
       
End Sub  
Public Sub tx()   
    Dim ssql As String  
    Dim conn As ADODB.Connection   
    Set conn = CurrentProject.Connection   
       
    Dim i As Integer  
    On Error Resume Next  
    For i = 1 To 9000   
        ssql = "drop table t" & (10000 + i)   
        CurrentProject.Connection.Execute ssql   
    Next i   
    On Error GoTo 0   
End Sub  
  
Public Sub t1()   
    Dim ssql As String  
    Dim i As Integer  
       
    For i = 1 To 9000   
        ssql = "create table t" & (10000 + i) & " (id integer,cname char(10))"  
        CurrentProject.Connection.Execute ssql   
    Next i   
End Sub  
  
Public Sub t2()   
    Dim ssql As String  
    Dim i As Integer  
       
    For i = 1 To 9000   
        ssql = "select * into t" & (10000 + i) & " from table2"  
        CurrentProject.Connection.Execute ssql   
    Next i   
End Sub  
  
Public Sub t()   
       
    Call tx   
    Debug.Print "t1 start.", Now   
    Call t1   
    Debug.Print "t1 end  .", Now   
       
       
    Call tx   
    Debug.Print "t2 start.", Now   
    Call t2   
    Debug.Print "t2 end  .", Now   
End Sub  
Option Compare Database
Option Explicit

Public Sub ti()
    Dim ssql As String
    Dim conn As ADODB.Connection
    Set conn = CurrentProject.Connection
    
    ssql = "create table table2(id integer,cname char(10))"
    conn.Execute ssql
    
End Sub
Public Sub tx()
    Dim ssql As String
    Dim conn As ADODB.Connection
    Set conn = CurrentProject.Connection
    
    Dim i As Integer
    On Error Resume Next
    For i = 1 To 9000
        ssql = "drop table t" & (10000 + i)
        CurrentProject.Connection.Execute ssql
    Next i
    On Error GoTo 0
End Sub

Public Sub t1()
    Dim ssql As String
    Dim i As Integer
    
    For i = 1 To 9000
        ssql = "create table t" & (10000 + i) & " (id integer,cname char(10))"
        CurrentProject.Connection.Execute ssql
    Next i
End Sub

Public Sub t2()
    Dim ssql As String
    Dim i As Integer
    
    For i = 1 To 9000
        ssql = "select * into t" & (10000 + i) & " from table2"
        CurrentProject.Connection.Execute ssql
    Next i
End Sub

Public Sub t()
    
    Call tx
    Debug.Print "t1 start.", Now
    Call t1
    Debug.Print "t1 end  .", Now
    
    
    Call tx
    Debug.Print "t2 start.", Now
    Call t2
    Debug.Print "t2 end  .", Now
End Sub


 

步骤一:运行 ti()创建一个原表 table2 以供后面的 select * into newtable from oldTable 使用。 
步骤二:运行 t() 结果如下。 
t1 start.     5/23/2009 3:06:54 PM 
t1 end  .     5/23/2009 3:07:03 PM 
t2 start.     5/23/2009 3:07:17 PM 
t2 end  .     5/23/2009 3:07:29 PM

t1() 9s , t2() 12s

试验结论: 猜想不成立。

发布人:ACMAIN_CHM版主   
分享到:
点击次数:  更新时间:2015-01-20 10:49:19  【打印此页】  【关闭】
上一条:SQL数据库中select into from和insert into select的区别  下一条:追加查询INSERT INTO SELECT和SELECT INTO 两种插入数据的区别



相关文章

  • • insert into 一次同时插入多条记录
  • • SQL数据库中select into from和insert into select的区别
  • • 追加查询INSERT INTO SELECT和SELECT INTO 两种插入数据的区别
  • • insert into 和select * into的性能比较
  • • 一条“INSERT INTO”语句插入多条记录
  • • 从B窗循环追加记录到A窗的样例代码

热门文章

  • [2015-01-20] insert into 和select * into的性能比较access数据库
  • [2009-05-19] 从B窗循环追加记录到A窗的样例代码access数据库
  • [2015-01-20] 一条“INSERT INTO”语句插入多条记录access数据库
  • [2015-01-20] SQL数据库中select into from和insert into select的区别access数据库
  • [2015-01-20] 追加查询INSERT INTO SELECT和SELECT INTO 两种插入数据的区别access数据库
  • [2015-01-20] access的真假:四、"SELECT * INTO 工作表 FROM 临时表" 比 "CREATE TABLE 工作表 (...)" 速度快?access数据库

热门产品

公司动态|在线留言|在线反馈|友情链接|会员中心|站内搜索|网站地图

Access交流网 版权所有 1999-2018 粤ICP备10043721号

QQ:18449932

Access应用 Access培训 Access开发 Access平台

access|数据库|access下载|access教程|access视频|access软件

Powered by MetInfo 5.3.12 ©2008-2023  www.metinfo.cn