tableadapter.update 不起作用?

发布于 2024-11-14 19:52:25 字数 1335 浏览 5 评论 0原文

我有一个问题让我发疯...... 我的 PC 上有一个本地数据库 (.sdf),在互联网上有一个数据库 (MySQL),两者具有相同的结构。 我首先通过数据适配器从互联网加载数据到数据集中,然后在数据集中加载一些本地数据。

现在我想将来自互联网的数据也存储在本地数据库中,我用 Update 语句尝试了它。这必须有效,但是每次我运行程序(调试)并返回本地数据库(通过数据库资源管理器,右键单击表,显示表数据...)时,互联网数据尚未保存!

需要明确的是,我确实在我的 dataGrid1 中看到了这两个数据(来自互联网的本地数据)。

您认为问题出在哪里?

        klantenTableAdapter.ClearBeforeFill = false;

        DigiLocalDataSet dataset = new DigiLocalDataSet();

        string MyConString = "SERVER=server;" +
                    "DATABASE=db;" +
                    "UID=uid;" +
                    "PASSWORD=pass;";
        string sql = "SELECT klantnr, geslacht, voorletters, roepnaam, achternaam, tussenvoegsel, straat, huisnr, subhuisnr, postcode, plaats, telthuis, telmobiel, email, geboortedatum FROM klanten ORDER BY roepnaam";

        MySqlConnection connection = new MySqlConnection(MyConString);

        MySqlCommand cmdSel = new MySqlCommand(sql, connection);

        MySqlDataAdapter da = new MySqlDataAdapter(cmdSel);


        //Fill from internet
        da.Fill(dataset.klanten);


        //Fill from local database
        klantenTableAdapter.Fill(dataset.klanten);

        klantenTableAdapter.Update(dataset.klanten);

        //dataset.AcceptChanges();

        this.DataContext = dataset.klanten.DefaultView;

提前致谢!

I have a problem that drives me crazy...
I have a local database (.sdf) on my PC en a database on the internet (MySQL), both with same structure.
I first load data from the internet in the dataset via the dataadapter and secondly I load some local data in the dataset.

Now I want to store the data from internet also in the local database, I tried it with the Update statement. This has to work, but everytime I run the program (debug) and I went back to the local database (via the database explorer, right click on table, Show Table data...), the internet data has not been saved!

To be clear I do see both data (local en from internet) in my dataGrid1.

What do you think is the problem?

        klantenTableAdapter.ClearBeforeFill = false;

        DigiLocalDataSet dataset = new DigiLocalDataSet();

        string MyConString = "SERVER=server;" +
                    "DATABASE=db;" +
                    "UID=uid;" +
                    "PASSWORD=pass;";
        string sql = "SELECT klantnr, geslacht, voorletters, roepnaam, achternaam, tussenvoegsel, straat, huisnr, subhuisnr, postcode, plaats, telthuis, telmobiel, email, geboortedatum FROM klanten ORDER BY roepnaam";

        MySqlConnection connection = new MySqlConnection(MyConString);

        MySqlCommand cmdSel = new MySqlCommand(sql, connection);

        MySqlDataAdapter da = new MySqlDataAdapter(cmdSel);


        //Fill from internet
        da.Fill(dataset.klanten);


        //Fill from local database
        klantenTableAdapter.Fill(dataset.klanten);

        klantenTableAdapter.Update(dataset.klanten);

        //dataset.AcceptChanges();

        this.DataContext = dataset.klanten.DefaultView;

Thanks in advance!

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

一百个冬季 2024-11-21 19:52:25

对此很陌生,但是您是否也需要调用 SaveChanges 将其提交到数据库?

New to this, but don't you need to call SaveChanges too to commit it to the database?

仅此而已 2024-11-21 19:52:25

看来de db引用使用了相对路径。数据集向导建议将数据库复制到您的输出目录。然而,在服务器资源管理器中,您仍在检查原始数据库。会是这样吗? ;-)

It seems that de db reference uses a relative path. The Dataset wizard proposes to copy the database to your output directory. However in the Server explorer you are still examining the original database. Could that be it? ;-)

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文