使用OleDb的SQL语句操作ACCESS数据库问题

acqy 2005-09-12 05:05:08
1、使用如下的SQL语句创建了两个数据表:
CREATE TABLE tab_master (ID integer primary key, name varchar(20))
CREATE TABLE tab_detail (ID integer primary key, pid integer, value integer not null)
现在需要使用foreign key约束将tab_detail.pid字段关联到tab_master.id字段,这个SQL语句应该怎么写呢?

2、我在ACCESS环境中的Query中新建了一个Query,写了如下的语句:
CREATE TABLE tab (ID integer constraint tab_PK primary key, name varchar(20) constraint tab_UN unique constraint tab_NN not null)
执行后创建数据表成功,但是,新建另外一个Query并写入“alter table tab drop constraint tab_NN”后,提示:约束tab_NN没有定义,这是为什么呢?如果我只需要去掉name字段的非空约束,SQL语句应该怎么写呢?

3、使用下面的SQL语句创建了两个数据表,之间存在约束:
CREATE TABLE tab_master (ID integer primary key, name varchar(20))
CREATE TABLE tab_detail (ID integer primary key, pid integer foreign key references tab_master, value integer not null)
现在需要将这个foreign key的约束去掉,应该怎么写SQL语句呢?
...全文
125 3 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
changechange 2005-09-14
  • 打赏
  • 举报
回复
关于此主题请参考:
如何用sql语句建立删除表关系?《查询》
http://access911.net/index.asp?u1=a&u2=72FABF1E1ADC
关于此主题请参考:
关系如何用VBA程序来建立《其他》
http://access911.net/index.asp?u1=a&u2=75FAB41E10DC
wwwwb 2005-09-13
  • 打赏
  • 举报
回复
1、ALTER TABLE tab_detail add CONSTRAINT dd FOREIGN KEY (Id) REFERENCES tab_master
wwwwb 2005-09-13
  • 打赏
  • 举报
回复
试试:
3、ALTER TABLE tab_detail DROP CONSTRAINT pid
2、去掉name字段的非空约束: ALTER TABLE 表 aLTER COLUMN name TEXT(10) NOT NULL
1、ALTER TABLE tab_detail ADD CONSTRAINT dd REFERENCES tab_master id
本文介绍C#访问操作Access数据库的基础知识,并提供一个相关的例程。 1.通过ADO.NET的OleDb相关类来操作Access 主要知识点如下: using System.Data.OleDb; using System.Data; 连接字符串:String connectionString = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=product.mdb"; 建立连接:OleDbConnection connection = new OleDbConnection(connectionString); 使用OleDbCommand类来执行Sql语句OleDbCommand cmd = new OleDbCommand(sql, connection); connection.Open(); cmd.ExecuteNonQuery(); 2.取得Access自增标识字段在插入数据后的id值 cmd.CommandText = @"select @@identity"; int value = Int32.Parse(cmd.ExecuteScalar().ToString()); return value; 3.执行事务 需要用到OleDbTransaction,关键语句如下: OleDbConnection connection = new OleDbConnection(connectionString); OleDbCommand cmd = new OleDbCommand(); OleDbTransaction transaction = null; cmd.Connection = connection; connection.Open(); transaction = connection.BeginTransaction(); cmd.Transaction = transaction; cmd.CommandText=sql1; cmd.ExecuteNonQuery(); cmd.CommandText=sql2; cmd.ExecuteNonQuery(); transaction.Commit(); 4.执行查询,返回DataSet OleDbConnection connection = new OleDbConnection(connectionString); DataSet ds = new DataSet(); connection.Open(); OleDbDataAdapter da = new OleDbDataAdapter(sql, connection); da.Fill(ds,"ds"); 5.分页查询 分页查询使用OleDbDataReader来读取数据,并将结果写到一个DataSet中返回。 以上内容封装为三个可重用的类:AccessDBUtil,AccessPageUtil,Page 代码这里下载AccessDBUtilDemo.rar (191.37 KB , 下载:999次) 本例程是一个c#的winform程序,但是数据访问类可以在Web环境下使用。 本例程演示了: 1.Access数据库的插入,更新,修改,查询; 2.带参数的sql语句使用,而不是拼SQL; 3.使用DataReader的分页查询,而不是用嵌套的SQL语句来分页; 4.用事务同时执行多个SQL语句; 5.在插入数据的同时返回最新的ID值; 6.整型,实型,字符串,日期型,布尔型五种数据类型的操作; 7.使用正则表达式来验证整数和实数; 8.listview用来显示数据的一些基本用法。 本示例不包括: 1.高效的分页查询,仅仅是提供了一种分页的方法,但我认为DataReader应该比嵌套的SQL语句快(未测试)。 2.完善的分页封装,只提供了分页的简单包装。 3.嵌套的事务处理,提供了同时执行多个sql语句的事务处理,但不支持嵌套事务。 4.listview的使用,只是利用winform控件来演示数据访问,因此不能作为winform编程的良好示例,例如添加数据时界面并没有很好地更新。

7,732

社区成员

发帖
与我相关
我的任务
社区描述
Microsoft Office Access是由微软发布的关系数据库管理系统。它结合了 MicrosoftJet Database Engine 和 图形用户界面两项特点。
社区管理员
  • Access
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧