打开2007数据库
外部数据库1.打开 (“ODBC;DSN=MS Access Database;DBQ=” + 取运行目录 () + “\\数据库.accdb;Driver={Microsoft Access Driver (*.mdb, *.accdb)};;DriverId=25;FIL=MS Access;MaxBufferSize=2048;PageTimeout=5;PWD=”, , 真)
易语言对ACCESS数据库
学习使用数据库,难免要使用SQL语句。外部数据库使用SQL语句可以快速地完成对数据库的种种操作,如:查询、修改、插入记录、删除记录等。至于更多的,比如:创建表、删除表、加密数据等等,等我们能够比较熟练地掌握数据库的操作再研究。 一、基本命令格式 1、查询记录
基本格式:select 字段名 from 表名 where 条件
例如:要查询“员工表"中“张三"的信息,可以这么写:“select * from 员工表 where 姓名='张三'"。这里,“员工表"是要查询的表的名称,“姓名"是字段名称。 如果要查询的是张三的电话呢?就得这么写:“select 电话 from 员工表 where 姓名='张三'"。“电话"也是该表中的字段。
如果要查询整个表的信息,就不需要加“where"。比如,要查询“员工表"中所有员工的全部信息,就可以这么写:“select * from 员工表"。 2、删除记录
基本格式:delete from 表名 where 条件
例如:要删除“学生表"中“成绩"小于50的学生名字,可以这么写:“delete from 学生表 where 成绩<50"
如果不加条件,就会删除该表中所有记录,该表就变成一个没有记录的空表,以后还可以向表中添加记录。本命令与删除表“drop table"不同,“drop table"删除的是被操作的表,删除后,整个表都不存在,也就不可以再添加记录了。 3、添加记录
基本格式:insert into 表名(字段1,字段2,字段3) values (字段1的值,字段2的值,字段3的值)
本命令是往指定的表中添加记录。要注意,“表名"后面括号中是被操作的字段名称,“values"后面括号中是对应的字段值,不要弄错了位置的先后顺序。还有,本命令不可以跟“where",因为你要添加的记录在表中根本没有,所以也就不可以有什么条件了。 4、修改记录
基本格式:update 表名 set 欲修改的字段名1=该字段的新值,欲修改的字段名2=该字段的新值 where 条件
该命令是修改表中已经存在的记录数据。如果不加“where"条件,就会把所有指定的字段都改成新值。 比如:要修改“员工表"中“张三"的工资为1500,应该这么写:“update 员工表 set 工资=1500 where 姓名='张三'"。 二、易语言命令操作数据库
在易语言中,对外部数据库,比如ACCESS的操作,有如下方法:
一个是用“外部数据库",另一个是用“数据库连接"和“记录集"。前一种是我这段时间正在学习的,操作起来比较方便。后一种我还没有用过,不敢多讲。不过,我觉得记录
集就象一张表格,只是这表格是看不见的,是动态的。在这里,我只说一下“外部数据库"。 1、查询操作
基本命令:外部数据库控件名称.查询(SQL命令语句)
这一命令只可以用来进行查询操作。使用的时候要注意SQL语句是否正确。 如果查询的记录存在,则回车满足查询条件的记录的条数,否则回车0。 2、非查询操作
基本命令:外部数据库控件名称.执行(SQL命令语句,操作的数据) 这一命令可以完成对数据的添加、删除、修改等操作,也可以完成对数据库中表的创建、删除。此命令有两个参数,第一个是SQL命令,后一个是你要操作的数据。第二个参数是可以省略的,只在对表中的备注型、OLE型字段进行操作时才用。 本命令执行成功回车真,否则回车假。这样我们就可以通过执行的结果来判断操作是否正确了。
比如,你想把一张图片放入数据库,应该这么做: 外部数据库1.执行(“insert into 图片表(图片名,图片) values ('美丽的图片',?)",读入文件(你要放入的图片的文件名称)) 其中,“图片表"是你的数据库中存放图片的表的名称,“图片名"和“图片"是字段名称,前一字段是文本型的,后一字段是OLE型,也就是易语言中字节集型的。
“美丽的图片"是在表中插入的新记录中“图片名"字段所对应的值,在SQL语句中要用单引号括起来。“?"表示你要操作的数据,如果你操作的数据中有字节集型的,应该用“?"代替,在后面的第二参数中写入真正的数据内容。如果你同时操作多个字节集型的数据,应该用多个“?",并且后面按照顺序放置相应的值。 3、读数据库数据
读数据的时候,首先要用查询命令,要不然是没法读数据的。 建立一个变量,存放查询的结果。如:查询结果,整数型。 查询结果=外部数据库控件名称.查询(查询类的SQL语句) 外部数据库控件名称.到首记录(查询结果)
存放数据的变量=外部数据库控件名称.读(查询结果,要读的字段名称)
好了,以上是我学习数据库以来的一点体会,与朋友们一同分享。朋友们也可以看一下我最近发的软件《小小日记本》、《易用通讯录》和例程《图片导入数据库》,里面用了SQL语句对ACCESS数据库进行记录的增删、修改、查询等操作。
常用命令格式
insert into 表名 (项目名,项目名2) values ('内容','内容')
update 修改 update 表名 Set 姓名='” + 编辑框1.内容 + “',性别='” + 编辑框2.内容
delete 删除 delete from 表名 where 条件 数组可直接 文字用''
select 查询 select * from 表名称
“select * from 资料 where 姓名 like ” + “'%” + 搜索内容 编辑框 + “%';”
“select * from 用户信息 where 姓名='” + 编辑框8.内容 + “'”
update 表名 set name=? where ID = 更新图片
INSERT INTO 表名 (name) values (?) 写到图片 access文件
update 表名 set 要更改的=更改的,要更改的=更改的where 条件=条件 (修改多处)
分页显示数据 SELECT * FROM jy ORDER BY id DESC LIMIT 5,5;
第一个5,是起点 第二个5,是取几条
反向排序 “select * from 表名 order by 字段名 DESC”
正向排序 “select * from 表名 order by 字段名 ASC”
like % where 条件 and 并且 or 或者
--复制表结构有句型的 --跨数据库
--复制结构+数据
select * into 数据库名.dbo.新表名 from 数据库名.dbo.原表名 --只复制结构
select * into 数据库名.dbo.新表名 from 数据库名.dbo.原表名 where 1=0 select * into data.mdb.新用户 from data.mdb.用户日志 where 1=0
--复制到临时表
select * into #temptablename from 数据库名.dbo.原表名 where 1=0
drop table 新用户 删除表
--后面的where 1=0 只要不成立就行了,管它是1=2,还是1000=1001...
插入时间
Replace(Replace(Replace('2013年4月11日', '年', '-'), '月', '-'), '日', '')这样把年月日去掉然后再to_char(to_date('2013411','yyyymdd'),'yyyy-mm-dd') 就得到日期(2013-04-11)再insert into tableName (time) values ('2013-04-11') 后面的分秒我省略了,你自己加mi:ss
一、基础