创建表对表的修改数据库
【MySQL】DDL数据定义语言的基本用法create、drop和alter(增删改)

【MySQL】DDL数据定义语⾔的基本⽤法create、drop和alter(增删改)DDL 的基础语法⽂章⽬录简单复习⼀波 SQL必知必会DDL 的英⽂全称是 Data Definition Language(数据定义语⾔),它定义了数据库的结构和数据表的结构。
在 DDL 中,我们常⽤的功能是增删改,分别对应的命令是 CREATE、DROP 和 ALTER。
对数据库进⾏定义建数据库的基本SQL语法格式为:CREATE DATABASE database_name;//创建⼀个名为 database_name 的数据库“database_name”为要创建的数据库的名称,该名称不能与已经存在的数据库重名。
mysql> CREATE DATABASE database_name;Query OK, 1 row affected (0.00 sec)mysql> CREATE DATABASE database_name;ERROR 1007 (HY000): Can't create database 'database_name'; database exists删除数据库是将已经存在的数据库从磁盘空间上清除,清除之后,数据库中的所有数据也将⼀同被删除。
删除数据库的基本SQL语法格式为:DROP DATABASE database_name;//删除⼀个名为 database_name 的数据库“database_name”为要删除的数据库的名称。
若指定的数据库不存在,则删除出错。
mysql> DROP DATABASE database_name;Query OK, 0 rows affected (0.00 sec)mysql> DROP DATABASE database_name;ERROR 1008 (HY000): Can't drop database 'database_name'; database doesn't exist在这⾥插⼊图⽚描述mysql> CREATE DATABASE database_name;Query OK, 1 row affected (0.00 sec)mysql> CREATE DATABASE database_name;ERROR 1007 (HY000): Can't create database 'database_name'; database existsmysql> SHOW CREATE DATABASE database_name;+---------------+------------------------------------------------------------------------+| Database | Create Database |+---------------+------------------------------------------------------------------------+| database_name | CREATE DATABASE `database_name` /*!40100 DEFAULT CHARACTER SET utf8 */ |+---------------+------------------------------------------------------------------------+1 row in set (0.00 sec)mysql> DROP DATABASE database_name;Query OK, 0 rows affected (0.00 sec)mysql> SHOW CREATE DATABASE database_name;ERROR 1049 (42000): Unknown database 'database_name'CREATE DATABASE mysqlcrashcourse;// 创建⼀个名为 mysqlcrashcourse 的数据库DROP DATABASE mysqlcrashcourse;// 删除⼀个名为 mysqlcrashcourse 的数据库对数据表进⾏定义创建表结构的语法是这样的:CREATE TABLE table_name;创建⼀个名为 table_name的表⼀般要写⾄少写⼀⾏ A table must have at least 1 column,后⾯介绍如何创建表结构创建⼀个名为 table_name的表mysql> CREATE DATABASE database_name;Query OK, 1 row affected (0.00 sec)mysql> USE database_name;Database changedmysql> CREATE TABLE table_name;ERROR 1113 (42000): A table must have at least 1 columnmysql> CREATE TABLE table_name( name VARCHAR(50) NOT NULL);Query OK, 0 rows affected (0.01 sec)mysql> show tables;+-------------------------+| Tables_in_database_name |+-------------------------+| table_name |+-------------------------+1 row in set (0.00 sec)mysql> CREATE TABLE table_name( name VARCHAR(50) NOT NULL);ERROR 1050 (42S01): Table 'table_name' already existsmysql>删除表的基本SQL语法格式为:DROP TABLE table_name;DROP TABLE [IF EXISTS] table_name;DROP TABLE table_name;删除⼀个名为 table_name的表DROP TABLE IF EXISTS table_name;执⾏了这条语句如果存在table_name表就删除,不存在不会报错也是执⾏。
第4章 VisualFoxPro数据库操作

阶段1 实体完整性
在Visual
FoxPro 6.0中,实体完整性是保证表中 记录“唯一”的特性,即在一个表中不允许有重 复的记录出现。保证实体完整性的方法是利用主 关键字或候选关键字来保证表中的记录“唯一” 。
在
Visual FoxPro6.0中,将主关键字称为主索 引,将候选关键字称为候选索引,主索引和候 选索引具有相同的作用。若一个字段的值或几 个字段的值能够唯一标识表中的一条记录,则 称为候选关键字。
[EXCLUSIVE|SHARED]
阶段3 修改数据库
数据库的修改操作,是通过【数据库设计器】
来完成的,打开一个数据库会自动打开【数据库 设计器】工具条,通过【数据库设计器】工具条 可以对数据库进行数据对象的建立、修改和删除 等操作。也可以在【数据库设计器】中,单击鼠 标右键进行相关的操作。
用命令打开【数据库设计器】的格式为: MODIFY DATABASE [<数据库文件名 >|?][NOWAIT] [NOEDIT]
阶段1 多工作区的概念
多工作区是为了控制有关系的表之间记录指针
的相互关联,在使用临时联系时,需要临时同时 打开多个表,这种情况下的操作就是多工作区操 作。
选择工作区的命令是:
SELECT <工作区号>|<工作区别名> 其各参数的含义如下: (1)<工作区号>:工作区号的取值范围是 1~32767之间 的正整数。 (2)<工作区别名>:可以是系统定义的别名,即 1~10 号工作区的别名分别为字母A~J;可以将表名作为工作 区的别名;也可以用命令重新定义别名,使用ALIAS命 令实现。
VisualFoxPro数据库操作
第4章 Visual FoxPro数据库操作
opengauss数据库表的基本操作

标题:opengauss数据库表的基本操作一、概述opengauss是一种开源的分布式关系型数据库管理系统,具有高性能、高可用性、高可扩展性等特点。
在opengauss数据库中,表是存储数据的基本单位,对表的操作是数据库管理和开发中的基本操作之一。
二、创建表1. 创建表的语法在opengauss数据库中,可以使用CREATE TABLE语句来创建新的表,其语法格式如下:```sqlCREATE TABLE table_name (column1 datatype,column2 datatype,column3 datatype,....);```2. 示例要创建一个名为employee的表,包含id、name和age三列,可以使用以下语句:```sqlCREATE TABLE employee (id INT,name VARCHAR(50),age INT);```三、插入数据1. 插入数据的语法使用INSERT INTO语句可以向表中插入新的数据,其语法格式如下:```sqlINSERT INTO table_name (column1, column2, column3, ...) VALUES (value1, value2, value3, ...);```2. 示例假设要向employee表中插入一条id为1、name为"张三"、age为25的数据,可以使用以下语句:```sqlINSERT INTO employee (id, name, age)VALUES (1, '张三', 25);```四、查询数据1. 查询数据的语法通过SELECT语句可以从表中查询数据,其语法格式如下:```sqlSELECT column1, column2, ...FROM table_nameWHERE condition;```2. 示例要查询employee表中所有的数据,可以使用以下语句:```sqlSELECT * FROM employee;```五、更新数据1. 更新数据的语法使用UPDATE语句可以更新表中已有的数据,其语法格式如下:```sqlUPDATE table_nameSET column1 = value1, column2 = value2, ...WHERE condition;2. 示例假设要将employee表中id为1的记录的name更新为"李四",可以使用以下语句:```sqlUPDATE employeeSET name = '李四'WHERE id = 1;```六、删除数据1. 删除数据的语法使用DELETE FROM语句可以从表中删除数据,其语法格式如下:```sqlDELETE FROM table_nameWHERE condition;```2. 示例要删除employee表中id为1的记录,可以使用以下语句:```sqlDELETE FROM employeeWHERE id = 1;```七、修改表结构1. 添加新列可以使用ALTER TABLE语句向表中添加新的列,其语法格式如下:```sqlALTER TABLE table_nameADD column_name datatype;```2. 修改列类型使用ALTER TABLE语句还可以修改表中已有列的数据类型,其语法格式如下:```sqlALTER TABLE table_nameALTER COLUMN column_name SET DATA TYPE new_datatype; ```3. 删除列要删除表中的列,可以使用ALTER TABLE语句,其语法格式如下:```sqlALTER TABLE table_nameDROP COLUMN column_name;```八、索引的操作1. 创建索引在opengauss数据库中,可以使用CREATE INDEX语句创建新的索引,其语法格式如下:```sqlCREATE INDEX index_nameON table_name (column1, column2, ...);```2. 删除索引要删除表中的索引,可以使用DROP INDEX语句,其语法格式如下:```sqlDROP INDEX index_name;```九、表的备份与恢复在opengauss数据库中,可以使用pg_dump和pg_restore命令进行表的备份和恢复操作,具体的操作步骤和语法格式可以参考opengauss官方文档。
实验3 数据库 数据操作

选择导入目的对话框
选择源表、目的表
实验3
数据操作
2.在企业管理器中录入数据至数据表T中 在企业管理器中录入数据至数据表T 把左下表中的内容录入数据至表T。
待录入到表 T的数据 待插入表C的数据 语句插入数据至数据表C 3.使用INSERT INTO语句插入数据至数据表C中 使用INSERT INTO语句插入数据至数据表 把右上表中的数据插入课程表C。 在查询分析器中输入下面SQL语句,把表中第一行数据插入表C: 在查询分析器中输入下面SQL语句,把表中第一行数据插入表C: SQL语句 USE jxsk VALUES( C1 C1’, 程序设计 程序设计’, 60 60’) INSERT INTO C VALUES(‘C1 ,‘程序设计 ,‘60 )
格式的S_EXCEL.xls Excel 格式的S_EXCEL.xls 数据文件内容
实验3
【实验步骤】 实验步骤】
数据操作
1.利用导入导出向导把Excel文件S_EXCEL.xls中的数据导入数据表S中 ቤተ መጻሕፍቲ ባይዱ用导入导出向导把Excel文件S_EXCEL.xls中的数据导入数据表S Excel文件S_EXCEL.xls中的数据导入数据表
实验3
数据操作
"TNO" "T1" "T1" "T2" "T3" "T3" "T4" "T4" "T5" "T5"
"CNO" "C1" "C4" "C5" "C1" "C1" "C2" "C3" "C5" "C7"
实验三、四创建表及输入数据及完整性约束

实验三、四 创建表及输入数据及完整性约束本实验需要4学时。
一、实验目的要求学生熟练掌握和使用Transact-SQL、SQL Server企业管理器创建表、索引和修改表结构,并学会使用SQL Server 查询分析器接收Transact-SQL语句和进行结果分析。
学生熟练掌握使用 SQL、Transact-SQL和SQL Server企业管理器向数据库输入数据、修改数据和删除数据的操作。
二、实验内容1 创建表、确定表的主码和约束条件。
为主码建索引。
2 查看和修改表结构。
3 输入数据、修改数据和删除数据三、实验步骤(1)通过企业管理器,在建好的图书借阅数据库中建立图书、读者和借阅3个表,其结构为;图书(书号,类别,出版社,作者,书名,定价,作者).读者(编号,姓名,单位,性别,电话).借阅(书号,读者编号,借阅日期)要求为属性选择合适的数据类型,定义每个表的主码.是否允许空值和默认值等列级数据约束。
(2)在企业管理器中建立图书、读者和借阅3个表的表级约束.每个表的主码约束.借阅表与图书表间、借阅表与读者表之间的外码约束,要求按语义先确定外码约束表达式.再通过操作予以实现.实现借阅表的书号和读者编号的惟一性约束:实现读者性别只能是“男”或“女”的Check(检查)约束。
(3)通过企业管理器,在图书借阅数据库的图书、读者和借阅3个表中各输入10条记录。
要求记录不仅满足数据约束要求.还要有表间关联的记录。
(4)通过企业管理器实现对图书借阅数据库的图书、读者和借阅3个表中数据的插入。
删除和修改操作。
(5)通过企业管理器实现对学生选课库的数据增加、数据删除和数据修改操作、要求学生、课程和选课表中各有10条以上的记录。
四、实验方法1 新建表在 SQL Serve 2000的数据库中,文件夹是按数据库对象的类型建立的.文件夹名是该数据库对象名。
当在企业管理器中选择服务器和数据库文件夹,并打开已定义好的图书.读者数据库后,会发现它自动设置了关系图、表、视图、存储过程、用户、角色、规则、默认等文件夹。
数据库原理与应用(Access) 第四章 表的创建与表的

本章学习目标
在Access 2003中,表是有结构的数据的集合, 是数据库应用系统的数据“仓库”。开发数据库应用 系统时,开发者首要的工作是分析应用系统的数据要 求,然后根据分析的结果建立适合于系统要求的表结 构和表间关系。例如,我们要设计一个“学生信息管 理系统”就必须先设计表结构、建立表和对表进行必 要的操作与维护。
图4-1 新建表对话框
图4-2 表设计视图窗口
(3)在表设计器窗口单击第一行的“字段名称” 列,输入“学生”表的“学号”字段,单击“数据类 型”列右侧的向下箭头,从下拉列表中选择所需要的 数据类型,如“文本”;在窗口下半部的字段属性区 域设置“字段大小”属性,如8,并将必填字段设置 为“是”。如图4-3所示。 (4) 按上述方法依次定义每个字段的名字、类型、 长度及小数位数等参数。如图4-4所示。 (5)定义好表的全部字段后,单击“保存”按钮, 进入“另存为”对话框,在文件名输入框输入表名 称(“学生”),单击“确定”按钮。进入如图45所示的对话框。
图4-24 查找和替换对话框
(4)若要逐个替换,可单击“查找下一个”按钮, 当找到满足条件的记录时,单击“替换”按钮,可 替换当前记录,若不替换当前记录,则单击“查找 下一个”按钮。如要一次替换所有满足条件的记录, 可单击“全部替换”按钮。 (5)替换完成后,单击“取消”按钮,退出替换 操作。
4.4修改表结构
(9)超级链接 超级链接类型用于保存超链接的字段。超链接 可以是某个UNC路径(通往局域网中一个文件的地 址)或是URL(通往Internet节点)。当单一个超 链接时,Web浏览器或Access 2003将根据超链接 地址到达指定的目标。 (10)查询向导 查询向导类型(Loolup Wizard)字段通过列 表框或组合框提供了一个字段内容的列表,用户可 以在列表框或组合框中选择所列内容作为输入字段 的内容。其长度由系统默认设置。
实验二--数据表创建和操作

实验二表的创建及简单操作实验目的:本实验主要是对SQL基本操作语句进行学习,完成数据表的建立(Create Table)、修改(Alter Table)、删除(Drop Table)和数据记录的插入(Insert)、修改(Update)和删除(Delete)。
1.掌握构造SQL语句完成数据库中各张基本表的创建、修改、和删除方法。
2.在建立基本表的基础上,掌握为表建立索引及删除索引的方法。
3.掌握利用SQL语句对基本表中元组进行插入、修改和删除的方法。
4.对数据库中各表中的记录完成简单查询,掌握单表查询和多表查询的SQL语句构造方法。
实验内容及步骤:(二)综合实验2新建一个学生选修课程的数据库School,其中存放以下三个表:学生Student(学号,姓名,性别,年龄,系别),即Sno char (3), Sname char(4), Ssex char(2), Sage int, Sdept char(6);课程Course(课程号,课程名,任课教师),即Cno char(3), Cname char(8), teacher char(4);选修SC(学号,课程号,分数),即Sno char (3), Cno char (3), Grade int,试用SQL语言完成下列功能:1.打开SQL Server2000点击电脑“开始”—“程序”—“Microsoft SQL Server”—启动“服务管理器”点击电脑“开始”—“程序”—“Microsoft SQL Server”—启动“企业管理器”点击电脑“开始”—“程序”—“Microsoft SQL Server”—启动“查询分析器”出来登陆窗口后:,点击“确定”登陆2.建表,在定义中要求声明:(1)每个表的主外码;主键:外键:(2)学生的年龄介于16到40之间;(3)学生的姓名和课程名不能为空值;(4)选课成绩要么为空值,要么取0到100之间的整数。
数据库应用实验报告创建数据库和表以及表操作

实验一创建数据库和表以及表操作一、实验目的1.了解SQL Server数据库的逻辑结构和物理结构,表的结构特点;2.了解SQL Server的基本数据类型,空值概念;3.学会在企业管理器中创建数据库和表;4.学会使用T—SQL语句创建数据库和表;5.学会在企业管理器中对数据表进行插入、修改、删除数据操作;6.学会使用T-SQL对数据表进行插入、修改、删除数据操作;二、实验内容1.实验题目(1)创建用于企业管理的员工管理数据库,数据库名为YGGL,包含员工的信息、部门信息以及员工的薪水信息。
数据库YGGL包含下列3个表。
(1)Employees:员工自然信息表。
(2)Departments:部门信息表。
(3)Salary:员工薪水情况表。
各表的结构分别如表T2.1,表T2.2,表T2.3所示。
表T2.1 Employees表结构表T2.2 Departments表结构实验步骤1.在企业管理器中创建数据库YGGL要求:数据库YGGL初始大小为10MB,最大大小为50MB,数据库自动增长,增长方式是按5%比例增长;日志文件初始为2MB,最大可增长到5MB(默认为不限制),按1MB增长(默认是按5%比例增长)。
数据库的逻辑文件名和物理文件名均采用默认值,分别为 YGGL_data 和e:\sql\data\MSSQL\Data\YGGL.mdf,其中e:\sql\data\MSSQL为SQL Server 的系统安装目录;事务日志的逻辑文件名和物理文件名也均采用默认值分别为YGGL—LOG 和 e:\sql\data\MSSQL\Data\YGGL_Log.1df。
以系统管理员Administrator是被授权使用CREATE DATABASE语句的用户登录SQL Server服务器,启动企业管理器一>在服务器上单击鼠标右键一>新建数据库一>输入数据库名“YGGL”一>选择“数据文件”选项卡一>设置增长方式和增长比例一>选择“事务口志”选项卡一设置增长方式和增长比例。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
课程设计说明书设计题目数据库课程设计专业计算机科学与技术班级设计人学号山东科技大学2012年04月07日摘要本次设计是使用一种高级语言(C、C++、JAVA等)进行开发一中类似于DBMS的程序,主要功能包括表的建立、添加、删除、修改属性信息等基本操作。
此文档为此编写。
通过对题目的分析我使用了C语言进行编写。
将程序设计成以命令提示方式进行操作的不算很人性化的界面。
但具有操作提示(另附txt)。
此次设计包含了自己定义的几个头文件、小程序程序,利用函数调用实现主函数的实现。
自己编写了一个相当于DBMS的程序,经过不断改善能够很好的运行。
由于知识水平有限参考了前人的一些方法、技巧。
特此说明。
目录1.课程题目 (7)2.设计目的 (7)3.需求分析 (7)a)创建一表 (7)b)对表的修改 (7)c)数据类型的定义 (7)4.实现方式 (8)a)算法分析 (8)b)主要函数 (9)c)程序流程图 (9)d)详细设计 (11)5.程序实现 (21)6.总结 (26)7.附录 (27)正文一.课程题目用高级语言设计一个简单的DBMS二.设计目的设计一个小型的的DBMS实现对表的添加修改等属性操作,加深对数据库知识的理解。
三.需求分析1.创建一表。
(1).要求:必须用到关键字“create table”;常用的符号“()”、“,”“;”;表的名字可以任意定义;定义最基本的权限:unique、not null、default、check,如果列中有性别一列则需要性别只能选择“男”、“女”;列不能重名;数据类型只能是已经定义的类型;约束只能是已经定义的约束;当遇到“;”时表的建立完成。
(2).可能的错误:有两列或多列重名;定义的类型和约束不存、关键字错误。
2.表的修改(1).加一行、列(Insert 、Alter table).所添加的与原有的不能重名;修改表中已存在一项;删除表中的一行列。
(2).可能错误的操作:添加的表名或列已存在;字符输入错误。
3.数据类型的定义常见的数据类型 char,int ,short,long等四.实现方式1.算法分析编写一个简单的DBMS,能从文本文件中识别出各种命令语句:create ,select ,delete ,insert。
实现一个已固定属性的关系表的建立,元组记录的插入,查找,修改,浏览,删除操作。
整体采用链表结构,节点由结构体构成,结构体包含关系的各种属性,通过对链表的各种操作来实现对关系表的各种操作,然后将所建的表以文本文档的形式存储在同一2.主要成员函数int Sql_CREATE()//创建表int Sql_INSERT()//插入表int Sql_ALTER()//修改元组属性int Sql_SELECT()//查找元组int Sql_UPDATE()//查询记录int Sql_DELETE()//删除表3程序流程图图一4.详细设计(1). 关于自定义的两个头文件在程序中自定义了sql.h与dbf.h两个头文件,分别实现对函数中所用到的主函数进行定义与定义结构体变量、全局变量、宏定义等一些基本操作。
#ifndef dbf_H#define dbf_H#include <stdio.h>#include <stdlib.h>#include <string.h>//------------宏定义--------------------------------------------------------//#define GET_YEAR 0#define GET_MONTH 1#define GET_DAY 2#define FOX_VERISON_INFO 262#define WIN_32#define MAX_FIELD_COUNTS 40//字段类型#define FIELD_CHAR_TYPE 0x43#define FIELD_DATE_TYPE 0x44#define FIELD_FLOAT_TYPE 0x46#define FIELD_LOG_TYPE 0x4C#define FIELD_MEMO_TYPE 0x4D#define FIELD_NUMIC_TYPE 0x4E#define FIELD_INT_TYPE 0x49//条件查询#define CON_SMALL 0#define CON_EQUAL 1#define CON_LARGE 2//排序#define CON_SORT_INCREASE 0#define CON_SORT_DECREASE 1#define TRUE 1#define FALSE 0#define BOOL int//文件句柄/////////////////////////Struct definition////////////////////////////// //文件头结构体定义struct _DbfHead{char dbFlag;char year;char month;char day;int recCounts;short firstRecAddr;short recLen;char undo[20];};typedef struct _DbfHead DbfHead, *pDbfHead;//字段描述结构体定义struct _FieldDcp{char fieldName[10];char undo1;char fieldType;short offset;char undo2[2];char fieldLen;char numDecis;char undo3[14];};typedef struct _FieldDcp FieldDcp, *pFieldDcp; //字段数据结构体定义struct _DbfField{char *fieldData;char fieldName[10];char fieldType;char fieldLen;char fieldDcis;short offset;};typedef struct _DbfField DbfField, *pDbfField; //记录结构体定义struct _DbfRec{char delFlag;DbfField field[MAX_FIELD_COUNTS];int realCounts;};typedef struct _DbfRec DbfRec, *pDbfRec;//dbf文件句柄定义struct _DbfHand{char filename[50];DbfHead header;DbfRec rec;long curRecNo;long curFpAddr;FILE *fd;};typedef struct _DbfHand DbfHand, *pDbfHand;//创建DBF文件BOOL GetNum(pDbfHand hand, char*name);pDbfHand CreateDbf(char *filename, DbfRec rec);//增加字段pDbfHand AddField(pDbfHand hand, char*name,char tpye,int len,int dec);//修改字段属性pDbfHand ModifyField(pDbfHand hand, char*name, char tpye,int len,int dec);//修改记录BOOL UpdateRec(pDbfHand hand, char *str, int fieldId,pDbfRec rec1);//打开DBF文件pDbfHand OpenDbf(char *filename);//关闭DBF文件BOOL CloseDbf(pDbfHand hand);//删除DBF文件BOOL RemoveDbf(pDbfHand hand);//是否第一条纪录BOOL IsTopRec(pDbfHand hand);//是否最后一条纪录BOOL IsBottomRec(pDbfHand hand);//文件操作到第一条记录处BOOL GotoTop(pDbfHand hand);//文件操作到最后一条记录处BOOL GotoBottom(pDbfHand hand);//到指定的纪录BOOL GotoRec(pDbfHand hand, long recNo);//下一条BOOL GoNextRec(pDbfHand hand);//上一条BOOL GoPrevRec(pDbfHand hand);//聚集函数double JuJi(pDbfHand hand,int flag,int fieldid);//在文件尾部增加一条纪录pDbfHand AddRec(pDbfHand hand, pDbfRec record); //在当前位置插入一条纪录pDbfHand InsertRec(pDbfHand hand, pDbfRec record);//删除当前纪录pDbfHand DelCurRec(pDbfHand hand);//删除指定的记录BOOL DeleteRec(pDbfHand hand, char *str, int fieldId) ; //把表中的所有的记录容清掉pDbfHand TurnateRec(pDbfHand hand);//修改当前纪录BOOL ModifyRec(pDbfHand handle, pDbfRec record); //得到当前纪录pDbfRec GetCurRec(pDbfHand handle);BOOL GetCurRec1(pDbfHand hand,pDbfRec rec);//得到当前纪录的第fieldId个子段pDbfField GetCurField(pDbfHand handle, pDbfRec rec, int fieldId);//pDbfField GetFiledByName(pDbfHand handle,pDbfRec rec, char *filedName);//long GetRecordNO(pDbfHand hand);BOOL SetFiledByName(pDbfHand handle,pDbfRec rec,char *filedName,char* data,int len);//得到表中现有记录条数long GetRecCounts(pDbfHand handle);//查找一条纪录pDbfRec FindRec(pDbfHand handle, char *str, int Id);//关键字查询pDbfRec KeySearch(pDbfHand hand, char *str); //条件查询pDbfRec ConSearch(pDbfHand hand, char *strContent, int fieldIndex, int conditionID);//对表中一个字段的容排序pDbfHand SortDbf(pDbfHand hand, int fieldId, int sortCon);char* UCase(char *str);//得到当前时间char GetDate(int getMode);//得到记录长度short GetRecLen(pDbfRec rec);//文件头长度short GetHeadLen(pDbfRec rec);//新建文件头pDbfHand NewDbfHead(pDbfHand hand, pDbfRec rec); //更新文件头pDbfHand UpdateHead(pDbfHand hand);//写字段描述部分pDbfHand WrFieldDcp(pDbfHand hand, pDbfRec rec); //写文件头结束标志void WrtFileEnd(pDbfHand hand);//读文件头信息pDbfHand ReadDbfHead(pDbfHand hand);//得到字段个数int GetFieldCount(pDbfHand hand);//读字段描述信息pDbfHand ReadFieldDcp(pDbfHand hand);//保存容为日期时,格式华char *SaveDate( char *str);//读日期时,格式化char *ReadDbfDate(char *str);//去掉字符串的后面空格char *DsdStrEndSpace(char *str, int size);//在当前位置写一条纪录,覆盖原有容BOOL WriteRec(pDbfHand hand, pDbfRec record);(2). Sql.c在这个.C文件中包含了几乎全部的主要操作函数。