Member 10696161 Ответов: 2

Как вставить каждую ячейку в столбцы с датой и временем из ms excel в базу данных mysql?


Я пытаюсь написать код на этом языке, который импортирует данные из MS excel (Office 365) в datagridview, а затем в базу данных mysql. В этом случае у меня есть таблица, которую я делаю это лист:

https://i.stack.imgur.com/AD96e.png

Когда я импортирую данные в datagridview, то пытаюсь вставить их в базу данных mysql. Весь код находится ниже:

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
using MySql.Data.MySqlClient;
using System.Collections;
using System.Data.OleDb;
using System.IO;
using System.Configuration;

namespace ControlDataBase
{
    public partial class New_Tables : Form
    {
        public New_Tables()
        {
            InitializeComponent();
        }
        Form1 frm1 = (Form1)Application.OpenForms["Form1"];

        private void btnClose_Click(object sender, EventArgs e)
        {
            this.Close();
        }

        private void ImportData_Click(object sender, EventArgs e)
        {
            using (OpenFileDialog ofd = new OpenFileDialog() { Filter = "Excel Files|*.xlsx;*.xlsm;*.xlsb;*.xltx;*.xltm;*.xls;*.xlt;*.xls;*.xml;*.xml;*.xlam;*.xla;*.xlw;*.xlr;", ValidateNames = true })
            {
                if (ofd.ShowDialog() == DialogResult.OK)
                {
                    FileInfo fi = new FileInfo(ofd.FileName);
                    string FileName1 = ofd.FileName;

                    string excel = fi.FullName;

                    if (ofd.FileName.EndsWith(".xlsx"))
                    {
                        StrConn = @"Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" + excel + ";Extended Properties=\"Excel 12.0;\"";
                    }

                    if (ofd.FileName.EndsWith(".xls"))
                    {
                        StrConn = @"Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + excel + ";Extended Properties=\"Excel 1.0;HDR=Yes;IMEX=1\"";
                    }
                    OleDbConnection oledbconn = new OleDbConnection(StrConn);

                    OleDbDataAdapter dta5 = new OleDbDataAdapter("SELECT * FROM [Order_status$]", oledbconn);
                    oledbconn.Open();

                    DataSet dsole5 = new DataSet();
                    dta5.Fill(dsole5, "Order_status$");
                    datagrdStatus_order.DataSource = dsole5.Tables["Order_status$"];

                    oledbconn.Close();

                    MySqlConnection connection = new MySqlConnection("datasource=localhost;port=3306;username=root;password=");
                    connection.Open();

                    for (int i = 0; i < datagrdStatus_order.Rows.Count; i++)
                    {
                        MySqlCommand cmd = new MySqlCommand("INSERT IGNORE INTO try1.order_status(ID_WORKER, ID_ORDER, ID_MODULE, ID_PROJECT, AMOUNT_OF_PRODUCTS, BEGIN_DATE, END_DATE) SELECT workers.ID_WORKER, orders.ID_ORDER, module.ID_MODULE, projects.ID, @AMOUNT_OF_PRODUCTS, @BEGIN_DATE, @END_DATE FROM try1.workers INNER JOIN try1.orders INNER JOIN try1.modules INNER JOIN try1.projects WHERE workers.FNAME = @FNAME AND workers.LNAME = @LNAME AND workers.ID_WORKER = @ID_WORKER AND orders.ORDER_DESC = @ORDER_DESC AND orders.ORDER_NUMBER = @ORDER_NUMBER AND modules.NAME = @MODULES_NAME AND projects.PROJECT_NAME = @PROJECT_NAME", connection);

                    DateTime begin_date = Convert.ToDateTime(datagrdStatus_order.Rows[i].Cells[8].Value);
                    DateTime end_date = Convert.ToDateTime(datagrdStatus_order.Rows[i].Cells[9].Value);

                        cmd.Parameters.AddWithValue("@ID_WORKER", datagrdStatus_order.Rows[i].Cells[0].Value);
                        cmd.Parameters.AddWithValue("@FNAME", datagrdStatus_order.Rows[i].Cells[1].Value);
                        cmd.Parameters.AddWithValue("@LNAME", datagrdStatus_order.Rows[i].Cells[2].Value);
                        cmd.Parameters.AddWithValue("@ORDER_DESC", datagrdStatus_order.Rows[i].Cells[3].Value);
                        cmd.Parameters.AddWithValue("@NUMBER_ORDER", datagrdStatus_order.Rows[i].Cells[4].Value);
                        cmd.Parameters.AddWithValue("@MODULES_NAME", datagrdStatus_order.Rows[i].Cells[5].Value);
                        cmd.Parameters.AddWithValue("@PROJECT_NAME", datagrdStatus_order.Rows[i].Cells[6].Value);
                        cmd.Parameters.AddWithValue("@AMOUNT_OF_PRODUCTS", datagrdStatus_order.Rows[i].Cells[7].Value);
                        cmd.Parameters.AddWithValue("@BEGIN_DATE", begin_date);
                        cmd.Parameters.AddWithValue("@END_DATE", end_date);
                        cmd.ExecuteNonQuery();
                    }
                    connection.Close();
                    MessageBox.Show("The data are imported correctly");

                    loaddataalldatagridview();
                }
            }
        }

        private void loaddataalldatagridview()
        {
            frm1.loaddata5();
        }
    }
}


Когда я выполняю этот код то получаю ошибку в строке кода:

DateTime begin_date = Convert.ToDateTime(datagrdStatus_order.Rows[i].Cells[8].Value);


показывающий:

Цитата:
Система.InvalidCastException: "вы не можете привести элемент DBNull к другим типам."


Но он вставил большую часть импортированных данных, но не все из них. Я хочу импортировать все данные.

Что я уже пробовал:

1) я просто добавляю объекты datetime
.ToString();


for (int i = 0; i < datagrdStatus_order.Rows.Count; i++)
            {
                MySqlCommand cmd = new MySqlCommand("INSERT IGNORE INTO try1.order_status(ID_WORKER, ID_ORDER, ID_MODULE, ID_PROJECT, AMOUNT_OF_PRODUCTS, BEGIN_DATE, END_DATE) SELECT workers.ID_WORKER, orders.ID_ORDER, module.ID_MODULE, projects.ID, @AMOUNT_OF_PRODUCTS, @BEGIN_DATE, @END_DATE FROM try1.workers INNER JOIN try1.orders INNER JOIN try1.modules INNER JOIN try1.projects WHERE workers.FNAME = @FNAME AND workers.LNAME = @LNAME AND workers.ID_WORKER = @ID_WORKER AND orders.ORDER_DESC = @ORDER_DESC AND orders.ORDER_NUMBER = @ORDER_NUMBER AND modules.NAME = @MODULES_NAME AND projects.PROJECT_NAME = @PROJECT_NAME", connection);

                DateTime begin_date = Convert.ToDateTime(datagrdStatus_order.Rows[i].Cells[8].Value.ToString());
                DateTime end_date = Convert.ToDateTime(datagrdStatus_order.Rows[i].Cells[9].Value.ToString());

                cmd.Parameters.AddWithValue("@ID_WORKER", datagrdStatus_order.Rows[i].Cells[0].Value);
                cmd.Parameters.AddWithValue("@FNAME", datagrdStatus_order.Rows[i].Cells[1].Value);
                cmd.Parameters.AddWithValue("@LNAME", datagrdStatus_order.Rows[i].Cells[2].Value);
                cmd.Parameters.AddWithValue("@ORDER_DESC", datagrdStatus_order.Rows[i].Cells[3].Value);
                cmd.Parameters.AddWithValue("@NUMBER_ORDER", datagrdStatus_order.Rows[i].Cells[4].Value);
                cmd.Parameters.AddWithValue("@MODULES_NAME", datagrdStatus_order.Rows[i].Cells[5].Value);
                cmd.Parameters.AddWithValue("@PROJECT_NAME", datagrdStatus_order.Rows[i].Cells[6].Value);
                cmd.Parameters.AddWithValue("@AMOUNT_OF_PRODUCTS", datagrdStatus_order.Rows[i].Cells[7].Value);
                cmd.Parameters.AddWithValue("@BEGIN_DATE", begin_date);
                cmd.Parameters.AddWithValue("@END_DATE", end_date);
                cmd.ExecuteNonQuery();
            }


Но это видно:

Цитата:
Система.Formatexception версия: "строка не распознана как действительное значение datetime."


2) я пытался это сделать, добавляя строку к объектам, а затем преобразуя ее в datetime:

for (int i = 0; i < datagrdStatus_order.Rows.Count; i++)
            {
                MySqlCommand cmd = new MySqlCommand("INSERT IGNORE INTO try1.order_status(ID_WORKER, ID_ORDER, ID_MODULE, ID_PROJECT, AMOUNT_OF_PRODUCTS, BEGIN_DATE, END_DATE) SELECT workers.ID_WORKER, orders.ID_ORDER, module.ID_MODULE, projects.ID, @AMOUNT_OF_PRODUCTS, @BEGIN_DATE, @END_DATE FROM try1.workers INNER JOIN try1.orders INNER JOIN try1.modules INNER JOIN try1.projects WHERE workers.FNAME = @FNAME AND workers.LNAME = @LNAME AND workers.ID_WORKER = @ID_WORKER AND orders.ORDER_DESC = @ORDER_DESC AND orders.ORDER_NUMBER = @ORDER_NUMBER AND modules.NAME = @MODULES_NAME AND projects.PROJECT_NAME = @PROJECT_NAME", connection);

                DateTime begin_date = Convert.ToDateTime(datagrdStatus_order.Rows[i].Cells[8].Value);
                string MysqlFormatDate = begin_date.ToString("yyyy-MM-dd HH:mm:ss");
                DateTime begin_date2 = Convert.ToDateTime(MysqlFormatDate);

                DateTime end_date = Convert.ToDateTime(datagrdStatus_order.Rows[i].Cells[9].Value);
                string MysqlFormatDate2 = end_date.ToString("yyyy-MM-dd HH:mm:ss");
                DateTime end_date2 = Convert.ToDateTime(MysqlFormatDate2);

                cmd.Parameters.AddWithValue("@ID_WORKER", datagrdStatus_order.Rows[i].Cells[0].Value);
                cmd.Parameters.AddWithValue("@FNAME", datagrdStatus_order.Rows[i].Cells[1].Value);
                cmd.Parameters.AddWithValue("@LNAME", datagrdStatus_order.Rows[i].Cells[2].Value);
                cmd.Parameters.AddWithValue("@ORDER_DESC", datagrdStatus_order.Rows[i].Cells[3].Value);
                cmd.Parameters.AddWithValue("@NUMBER_ORDER", datagrdStatus_order.Rows[i].Cells[4].Value);
                cmd.Parameters.AddWithValue("@MODULES_NAME", datagrdStatus_order.Rows[i].Cells[5].Value);
                cmd.Parameters.AddWithValue("@PROJECT_NAME", datagrdStatus_order.Rows[i].Cells[6].Value);
                cmd.Parameters.AddWithValue("@AMOUNT_OF_PRODUCTS", datagrdStatus_order.Rows[i].Cells[7].Value);
                cmd.Parameters.AddWithValue("@BEGIN_DATE", begin_date2);
                cmd.Parameters.AddWithValue("@END_DATE", end_date2);
                cmd.ExecuteNonQuery();
            }


Но это тоже не сработало (он показал ошибку, как в 1-й попытке).

3) я объявил объект string и преобразовал его в DateTime:

for (int i = 0; i < datagrdStatus_order.Rows.Count; i++)
            {
                MySqlCommand cmd = new MySqlCommand("INSERT IGNORE INTO try1.order_status(ID_WORKER, ID_ORDER, ID_MODULE, ID_PROJECT, AMOUNT_OF_PRODUCTS, BEGIN_DATE, END_DATE) SELECT workers.ID_WORKER, orders.ID_ORDER, module.ID_MODULE, projects.ID, @AMOUNT_OF_PRODUCTS, @BEGIN_DATE, @END_DATE FROM try1.workers INNER JOIN try1.orders INNER JOIN try1.modules INNER JOIN try1.projects WHERE workers.FNAME = @FNAME AND workers.LNAME = @LNAME AND workers.ID_WORKER = @ID_WORKER AND orders.ORDER_DESC = @ORDER_DESC AND orders.ORDER_NUMBER = @ORDER_NUMBER AND modules.NAME = @MODULES_NAME AND projects.PROJECT_NAME = @PROJECT_NAME", connection);

                string begin_date = Convert.ToDateTime(datagrdStatus_order.Rows[i].Cells[8].Value).ToString("yyyy-MM-dd HH:mm:ss);
                string end_date = Convert.ToDateTime(datagrdStatus_order.Rows[i].Cells[9].Value).ToString("yyyy-MM-dd HH:mm:ss");

                cmd.Parameters.AddWithValue("@ID_WORKER", datagrdStatus_order.Rows[i].Cells[0].Value);
                cmd.Parameters.AddWithValue("@FNAME", datagrdStatus_order.Rows[i].Cells[1].Value);
                cmd.Parameters.AddWithValue("@LNAME", datagrdStatus_order.Rows[i].Cells[2].Value);
                cmd.Parameters.AddWithValue("@ORDER_DESC", datagrdStatus_order.Rows[i].Cells[3].Value);
                cmd.Parameters.AddWithValue("@NUMBER_ORDER", datagrdStatus_order.Rows[i].Cells[4].Value);
                cmd.Parameters.AddWithValue("@MODULES_NAME", datagrdStatus_order.Rows[i].Cells[5].Value);
                cmd.Parameters.AddWithValue("@PROJECT_NAME", datagrdStatus_order.Rows[i].Cells[6].Value);
                cmd.Parameters.AddWithValue("@AMOUNT_OF_PRODUCTS", datagrdStatus_order.Rows[i].Cells[7].Value);
                cmd.Parameters.AddWithValue("@BEGIN_DATE", begin_date);
                cmd.Parameters.AddWithValue("@END_DATE", end_date);
                cmd.ExecuteNonQuery();
            }


Но тогда это показывает ошибку:

Цитата:
Система.InvalidCastException: "вы не можете привести элемент DBNull к другим типам."


Я понятия не имею и малейшего понятия, как ее решить. Я искал решение, но так и не нашел его? Может ли кто-нибудь объяснить, как это решить? Есть идеи? Спасибо Вам за любую помощь и совет. :)

2 Ответов

Рейтинг:
18

Member 10696161

Хорошо я нашел то решение которое использую в цикле foreach:

string constring = "datasource = localhost; port = 3306; username = root; password = ";
 string query5 = "INSERT IGNORE INTO try1.order_status(ID_WORKER, ID_ORDER, ID_MODULE, ID_PROJECT, AMOUNT_OF_PRODUCTS, BEGIN_DATE, END_DATE) SELECT workers.ID_WORKER, orders.ID_ORDER, module.ID_MODULE, projects.ID, @AMOUNT_OF_PRODUCTS, @BEGIN_DATE, @END_DATE FROM try1.workers INNER JOIN try1.orders INNER JOIN try1.modules INNER JOIN try1.projects WHERE workers.FNAME = @FNAME AND workers.LNAME = @LNAME AND workers.ID_WORKER = @ID_WORKER AND orders.DESC_ORDER = @DESC_ORDER AND orders.ORDER_NUMBER = @ORDER_NUMBER AND modules.NAME = @MODULES_NAME AND projects.PROJECT_NAME = @PROJECT_NAME";

 using (MySqlConnection con = new MySqlConnection(constring))
 {
     using (MySqlCommand cmd = new MySqlCommand(query5, con))
     {
         cmd.Parameters.Add("@ID_WORKER", MySqlDbType.Int32);
         cmd.Parameters.Add("@FNAME", MySqlDbType.VarChar);
         cmd.Parameters.Add("@LNAME", MySqlDbType.VarChar);
         cmd.Parameters.Add("@DESC_ORDER", MySqlDbType.VarChar);
         cmd.Parameters.Add("@ORDER_NUMBER", MySqlDbType.VarChar);
         cmd.Parameters.Add("@MODULES_NAME", MySqlDbType.VarChar);
         cmd.Parameters.Add("@PROJECT_NAME", MySqlDbType.VarChar);
         cmd.Parameters.Add("@AMOUNT_OF_PRODUCTS", MySqlDbType.Int32);
         cmd.Parameters.Add("@BEGIN_DATE", MySqlDbType.DateTime);
         cmd.Parameters.Add("@END_DATE", MySqlDbType.DateTime);
         con.Open();

         foreach (DataGridViewRow row in datagrdStatus_order.Rows)
         {
             cmd.Parameters.AddWithValue("@ID_WORKER", row.Cells["ID_WORKER"].Value);
             cmd.Parameters.AddWithValue("@FNAME", row.Cells["FNAME"].Value);
             cmd.Parameters.AddWithValue("@LNAME", row.Cells["LNAME"].Value);
             cmd.Parameters.AddWithValue("@DESC_ORDER", row.Cells["DESC_ORDER"].Value);
             cmd.Parameters.AddWithValue("@ORDER_NUMBER", row.Cells["ORDER_NUMBER"].Value);
             cmd.Parameters.AddWithValue("@MODULES_NAME", row.Cells["NAME"].Value);
             cmd.Parameters.AddWithValue("@PROJECT_NAME", row.Cells["PROJECT_NAME"].Value);
             cmd.Parameters.AddWithValue("@AMOUNT_OF_PRODUCTS", row.Cells["AMOUNT_OF_PRODUCTS"].Value);
             cmd.Parameters.AddWithValue("@BEGIN_DATE", row.Cells["BEGIN_DATE"].Value);
             cmd.Parameters.AddWithValue("@END_DATE", row.Cells["END_DATE"].Value);
             cmd.ExecuteNonQuery();
         }
         con.Close();
     }
 }
 MessageBox.Show("Imported correctly");
 loaddataalldatagridview();


CHill60

Пожалуйста, не публикуйте несколько решений - это сбивает с толку - какое из них правильное?
Вы можете использовать ссылку "улучшить решение" для обновления поста

CHill60

Кроме того, вам не нужно использовать параметры.Добавьте, если вы используете параметры.AddWithValue - просто используйте последнее

Рейтинг:
0

Gerry Schmitz

DateTime begin_date;

bool ok = DateTime.TryParse(datagrdStatus_order.Rows[i].Cells[8].Value, out begin_date);

if (!ok){
   begin_date = ...
}


значение datetime.Метод TryParse (Система) | Microsoft Docs[^]


Member 10696161

Я только что написал строку кода:

bool ok = Дата-Время.Метод tryparse(datagrdStatus_order.Строки[я].Клеток[8].Значение, вне использоваться следующие переменные);

и он "кричит" об ошибке : "Аргумент "1": не может быть преобразован из "объекта" в "строку" ".

Как с этим бороться?