关于ASP中多表查询的语句问题 5

有个Gridview绑定的数据源是AccessDataSource,现在要做的是多表查询关键字“444”。A、B、C三个表中结构一样,都有D字段。我在button的cli... 有个Gridview绑定的数据源是AccessDataSource,现在要做的是多表查询关键字“444”。A、B、C三个表中结构一样,都有D字段。我在button的click中触发多表查询。语句如下
AccessDataSource1.SelectCommand = "SELECT * FROM [A],[B],[C]where [D]= 444";
一直报错,请问正确的应该怎么写?模糊查询关键字“444”怎么写?
protected void Button1_Click1(object sender, EventArgs e)
{
string gjc;
gjc = TextBox2.Text;
AccessDataSource1.SelectCommand = "SELECT * FROM [工资] WHERE [制度名]="+ @gjc ;
}

以上是代码,理论上应该制度名为文本框中的文字的查询结果,但是一直都报错System.Data.OleDb.OleDbException: 标准表达式中数据类型不匹配。
开发工具是VS2010,C#写的。
问题在哪呢?还有[工资].[制度名]有这写法吗?或者有标准的全部语句写法。虽然单击树形框节点自动查询对应表用改写”AccessDataSource1.SelectCommand =“这种方式实现成功了。总感觉我这写的是走歪门左道。请赐教!!
展开
 我来答
jiangxibaiyi
2012-08-23 · 跟随风去旅行-伤心的歌
jiangxibaiyi
采纳数:3973 获赞数:14411

向TA提问 私信TA
展开全部
不好弄

你这个DW自动生成的代码,我还真不会。。。

本来sql语句是这样的:

select * from a,b,c where a.d = b.d and b.d=c.d and (a.d like '%444%' or b.d like '%444%' or c.d like '%444%')

但是怎么弄到你的程序里,我还真不知道。。。。

如果3个表的结构一模一样,那还可以使用union关键词:

select * from a where d like '%444%' union select * from b where d like '%444%' union select * from c where d like '%444%'
追问
protected void Button1_Click1(object sender, EventArgs e)
{
AccessDataSource1.SelectCommand = "SELECT * FROM [工资] WHERE ([制度名] like'" + '%' + @gjc + '%' + "')";
}
以上代码实现了单表的模糊查询功能,但是对于多表时却查询不出来。只能查第一个表,第二个表内容查不出来,请问为什么。用union的写法,表结构都一样的。
或标准写法什么样的?觉得设置AccessDataSource1.SelectCommand不好
追答
你这是asp吗?
superdzm722
2012-08-25 · 超过36用户采纳过TA的回答
知道小有建树答主
回答量:100
采纳率:0%
帮助的人:73.2万
展开全部
不太确定你的要求,也不太记得相关语法了。你试试:
SELECT * FROM [A],[B],[C]where A.D LIKE %444% AND B.D LIKE %444% AND C.D LIKE %444%
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式