最近被问道了一个问题,就是如何对两个数据库里面的表进行联合查询。
后来我就用了最笨的方法实现了。希望看到的朋友能给个好的解决方法,只用一个连接字符串。最好是给个详细的教程。
表里面的数据也很简单,就是学生表和专业表,用专业号关联。
下面就在Winfrom的DataGridView上绑定数据,显示学生的编号、姓名、年龄和专业。效果如下:
由于对数据的操作我用到了linq to dataset 所以项目的.net 版本为3.5以上。
下面就是绑定数据的代码:
代码如下 | 复制代码 |
using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Text; using System.Windows.Forms; using System.Data.SqlClient; using System.Linq; namespace LinkTwoData { public partial class Form1 : Form { public Form1() { InitializeComponent(); } string strcon1 = @"Data Source=FENG-PCSQLEXPRESS;Initial Catalog=test1;User ID=sa;PassWord=sa2008"; string strcon2 = @"Data Source=FENG-PCSQLEXPRESS;Initial Catalog=test2;User ID=sa;PassWord=sa2008"; private void Form1_Load(object sender, EventArgs e) { SqlDataAdapter sda1 = new SqlDataAdapter("select * from stu1",strcon1); SqlDataAdapter sda2 = new SqlDataAdapter("select * from stu1", strcon2); DataSet ds = new DataSet(); sda1.Fill(ds,"stu1"); sda2.Fill(ds, "stu2");
var query = from stu in ds.Tables["stu1"].AsEnumerable() from sc in ds.Tables["stu2"].AsEnumerable() where stu.Field select new { sno = stu.Field sname=stu.Field sage = stu.Field scname = sc.Field };
DataTable dt = new DataTable(); dt.Columns.Add("sno", typeof(int)); dt.Columns.Add("sname", typeof(string)); dt.Columns.Add("sage", typeof(string)); dt.Columns.Add("scname", typeof(string)); foreach (var item in query) { DataRow newRow = dt.NewRow(); newRow["sno"] = item.sno; newRow["sname"] = item.sname; newRow["sage"] = item.sage; newRow["scname"] = item.scname; dt.Rows.Add(newRow); } dataGridView1.DataSource = dt.DefaultView; } } |
我的博物馆故事 官方安卓版v1.61.2
我的博物馆故事是一款以消除为主题的经营养成类手游,在这里玩家
专业模拟飞行10 手机版v12.2.4
专业模拟飞行10安卓版是一款飞行休闲手游,顶尖的物理飞行引擎
动物起义战斗模拟器二琳同款 最新版v4.1.1
动物起义战斗模拟器是一个非常有趣的模拟类游戏,玩家可以召唤各
迷你世界七周年 安卓手机版v1.43.0
迷你世界7周年是一款由《迷你世界》官方推出的庆祝特别版本,在
劫后公司无限资源版 v1.0.5.1
劫后公司内置菜单版是游戏的破解版本,在该版本中为玩家提供了内