Mysql对文件操作的封装

原创 2005年05月30日 02:02:00
Mysql对文件操作的封装
在查看Mysql对文件的操作中发现,它在不同的操作系统上对文件的操作,除了使用标准C运行库函数,包括open、close、seek等,在Win32下的文件和目录操作函数使用了CreatFile、CloseHandl、SetFilePointer等,不明白为什么对文件的操作要封装出两套函数。
查看了相关资料,其实使用API和标准库函数都可以生成文本文件和二进制文件,在这点上没有区别。同read()对应的是ReadFile,同write()对应的是WriteFile,同seek()对应的是SetFilePointer,同close对应的是CloseHandle。这两套函数都可以使用。但是Win 32系统把文件的概念进行了扩展。无论是文件、通信设备、命名管道、邮件槽、磁盘、还是控制台,都是用API函数CreateFile来打开或创建的。该函数的声明为:
HANDLE CreateFile(
LPCTSTR lpFileName, // 文件名
DWORD dwDesiredAccess, // 访问模式
DWORD dwShareMode, // 共享模式
LPSECURITY_ATTRIBUTES lpSecurityAttributes, // 通常为NULL
DWORD dwCreationDistribution, // 创建方式
DWORD dwFlagsAndAttributes, // 文件属性和标志
HANDLE hTemplateFile // 临时文件的句柄,通常为NULL
);
如果调用成功,那么该函数返回文件的句柄,如果调用失败,则函数返回INVALID_HANDLE_VALUE。
在用ReadFile和WriteFile读写时,既可以同步执行,也可以异步执行。ReadFile和WriteFile函数是否为执行异步操作是由CreateFile函数决定的。如果在调用CreateFile创建句柄时指定了FILE_FLAG_OVERLAPPED标志,那么调用ReadFile和WriteFile对该句柄进行的读写操作就是异步的,如果未指定异步标志,则读写操作是同步的。在同步执行时,函数直到操作完成后才返回。这意味着在同步执行时线程会被阻塞,从而导致效率下降。在异步执行时,即使操作还未完成,调用的函数也会立即返回。费时的I/O操作在后台进行,这样线程就可以干别的事情。这样可以大大的提高效率。这一点是值得我们学习和借鉴的,对于我们在文件的操作方面也可以对win32系统进行封装来提高文件操作的效率。

mysql 命令行对文件进行读写操作

首先在mysql中,使用如下指令: secure_file_priv后面跟着的路径就是我们进行文件操作的路径: 文件读入: 将要读的文件放在上述路径中, 使用如下指令: my...

MySQL数据库的迁移——使用*.sql文件操作方式

1. 概述 MySQL数据库的导入,有两种方法: 1) 先导出数据库SQL脚本,再导入; 2) 直接拷贝数据库目录和文件。 在不同操作系统或MySQL版本情况下,直接拷贝文件的方法可能会有不兼容的情...

MySQL的biglog文件操作

一、查看 1、SQL (1)  查看所有binlog文件 mysql> show binary logs; (2)  查看binlog内容 mysql> show binary events in '...

如何导入导出MySQL数据库----*.sql文件操作

转自于http://www.einit.com/user1/259/archives/2007/6705.html   1. 概述 MySQL数据库的导入,有两种方法: 1) 先导出数据库SQ...

如何导入导出MySQL数据库*.sql文件操作

http://zhidao.baidu.com/question/93580886.html 1. 概述 MySQL数据库的导入,有两种方法: 1) 先导出数据库...
  • wdt3385
  • wdt3385
  • 2012年09月05日 15:43
  • 456

mysql数据库文件操作

//============================================================================ // Name : CExe...

映射文件操作封装类

  • 2017年10月09日 14:27
  • 9KB
  • 下载

Java文件操作封装类

  • 2017年07月31日 06:47
  • 251KB
  • 下载

Java文件操作类封装

package com.wiker;   import java.io.BufferedInputStream; import java.io.BufferedOutputStrea...

一个封装好的文件操作的例子

  • 2013年11月26日 02:00
  • 20KB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Mysql对文件操作的封装
举报原因:
原因补充:

(最多只允许输入30个字)