Beispiel #1
0
        /// <summary>
        /// データ取得
        /// </summary>
        public void SEARCH_MST900501(DataSet ds, int no)
        {
            using (TRAC3Entities context = new TRAC3Entities(CommonData.TRAC3_GetConnectionString()))
            {
                context.Connection.Open();
                try
                {
                    using (DbTransaction transaction = context.Connection.BeginTransaction())
                    {
                        //変数宣言
                        DataTable dt;
                        dt = ds.Tables["CSV取り込み"];
                        DateTime 登録日時, 更新日時;
                        DateTime?削除日時, 削除日付;
                        DateTime CheckDate;
                        int      init;
                        decimal  dec;
                        int      Cnt = 0;
                        string   sql = string.Empty;
                        int      count;

                        switch (no)
                        {
                        case 0:
                            #region TRN
                            foreach (DataRow row in dt.Rows)
                            {
                                // 新番号取得
                                var 明細番号M = (from n in context.M88_SEQ
                                             where n.明細番号ID == 1
                                             select n
                                             ).FirstOrDefault();
                                if (明細番号M == null)
                                {
                                    break;
                                }
                                int p明細番号 = 明細番号M.現在明細番号 + 1;
                                明細番号M.現在明細番号 = p明細番号;
                                明細番号M.AcceptChanges();

                                //IDからKEYを取得
                                int?    code    = null;
                                decimal?nulldec = null;

                                code          = row["得意先KEY"].ToString() == "" ? code : Convert.ToInt32(row["得意先KEY"].ToString());
                                row["得意先KEY"] = (from m01 in context.M01_TOK where m01.得意先ID == code select m01.得意先KEY).Any() == false ? 0 : (from m01 in context.M01_TOK where m01.得意先ID == code select m01.得意先KEY).First();
                                code          = null;
                                code          = row["車輌KEY"].ToString() == "" ? code : Convert.ToInt32(row["車輌KEY"].ToString());
                                row["車輌KEY"]  = (from m05 in context.M05_CAR where m05.車輌ID == code select m05.車輌KEY).Any() == false ? 0 : (from m05 in context.M05_CAR where m05.車輌ID == code select m05.車輌KEY).First();
                                code          = null;
                                code          = row["支払先KEY"].ToString() == "" ? code : Convert.ToInt32(row["支払先KEY"].ToString());
                                row["支払先KEY"] = (from m01 in context.M01_TOK where m01.得意先ID == code select m01.得意先KEY).Any() == false ? 0 : (from m01 in context.M01_TOK where m01.得意先ID == code select m01.得意先KEY).First();
                                code          = null;
                                code          = row["乗務員KEY"].ToString() == "" ? code : Convert.ToInt32(row["乗務員KEY"].ToString());
                                row["乗務員KEY"] = (from m04 in context.M04_DRV where m04.乗務員ID == code select m04.乗務員KEY).Any() == false ? 0 : (from m04 in context.M04_DRV where m04.乗務員ID == code select m04.乗務員KEY).First();

                                T01_TRN t01 = new T01_TRN();
                                code    = null;
                                nulldec = null;

                                t01.明細番号       = p明細番号;
                                t01.明細行        = 1;
                                t01.登録日時       = DateTime.Now;
                                t01.更新日時       = DateTime.Now;
                                t01.明細区分       = 1;
                                t01.入力区分       = 3;
                                t01.請求日付       = Convert.ToDateTime(row["請求日付"].ToString());
                                t01.支払日付       = Convert.ToDateTime(row["支払日付"].ToString());
                                t01.配送日付       = Convert.ToDateTime(row["配送日付"].ToString());
                                t01.配送時間       = Convert.ToDecimal(row["配送時間"].ToString());
                                t01.得意先KEY     = Convert.ToInt32(row["得意先KEY"].ToString());
                                t01.請求内訳ID     = row["請求内訳ID"].ToString() == "" ? code : Convert.ToInt32(row["請求内訳ID"].ToString());
                                t01.車輌KEY      = row["車輌KEY"].ToString() == "" ? code : Convert.ToInt32(row["車輌KEY"].ToString());
                                t01.車種ID       = row["車種ID"].ToString() == "" ? code : Convert.ToInt32(row["車種ID"].ToString());
                                t01.支払先KEY     = row["支払先KEY"].ToString() == "" ? code : Convert.ToInt32(row["支払先KEY"].ToString());
                                t01.乗務員KEY     = row["乗務員KEY"].ToString() == "" ? code : Convert.ToInt32(row["乗務員KEY"].ToString());
                                t01.自社部門ID     = row["自社部門ID"].ToString() == "" ? 0 : Convert.ToInt32(row["自社部門ID"].ToString());
                                t01.車輌番号       = Convert.ToString(row["車輌番号"].ToString());
                                t01.支払先名2次     = Convert.ToString(row["支払先名2次"].ToString());
                                t01.実運送乗務員     = Convert.ToString(row["実運送乗務員"].ToString());
                                t01.乗務員連絡先     = Convert.ToString(row["乗務員連絡先"].ToString());
                                t01.請求運賃計算区分ID = row["請求運賃計算区分ID"].ToString() == "" ? 0 : Convert.ToInt32(row["請求運賃計算区分ID"].ToString());
                                t01.支払運賃計算区分ID = row["支払運賃計算区分ID"].ToString() == "" ? 0 : Convert.ToInt32(row["支払運賃計算区分ID"].ToString());
                                t01.数量         = row["数量"].ToString() == "" ? 0 : Convert.ToDecimal(row["数量"].ToString());
                                t01.単位         = Convert.ToString(row["単位"].ToString());
                                t01.重量         = row["重量"].ToString() == "" ? 0 : Convert.ToDecimal(row["重量"].ToString());
                                t01.走行KM       = row["走行KM"].ToString() == "" ? 0 : Convert.ToInt32(row["走行KM"].ToString());
                                t01.実車KM       = row["実車KM"].ToString() == "" ? 0 : Convert.ToInt32(row["実車KM"].ToString());
                                t01.待機時間       = row["待機時間"].ToString() == "" ? 0 : Convert.ToDecimal(row["待機時間"].ToString());
                                t01.売上単価       = row["売上単価"].ToString() == "" ? 0 : Convert.ToDecimal(row["売上単価"].ToString());
                                t01.売上金額       = row["売上金額"].ToString() == "" ? 0 : Convert.ToInt32(row["売上金額"].ToString());
                                t01.通行料        = row["通行料"].ToString() == "" ? 0 : Convert.ToInt32(row["通行料"].ToString());
                                t01.請求割増1      = row["請求割増1"].ToString() == "" ? 0 : Convert.ToInt32(row["請求割増1"].ToString());
                                t01.請求割増2      = row["請求割増2"].ToString() == "" ? 0 : Convert.ToInt32(row["請求割増2"].ToString());
                                t01.請求消費税      = row["請求消費税"].ToString() == "" ? 0 : Convert.ToInt32(row["請求消費税"].ToString());
                                t01.支払単価       = row["支払単価"].ToString() == "" ? 0 : Convert.ToDecimal(row["支払単価"].ToString());
                                t01.支払金額       = row["支払金額"].ToString() == "" ? 0 : Convert.ToInt32(row["支払金額"].ToString());
                                t01.支払通行料      = row["支払通行料"].ToString() == "" ? 0 : Convert.ToInt32(row["支払通行料"].ToString());
                                t01.支払割増1      = row["支払割増1"].ToString() == "" ? 0 : Convert.ToInt32(row["支払割増1"].ToString());
                                t01.支払割増2      = row["支払割増2"].ToString() == "" ? 0 : Convert.ToInt32(row["支払割増2"].ToString());
                                t01.支払消費税      = row["支払消費税"].ToString() == "" ? 0 : Convert.ToInt32(row["支払消費税"].ToString());
                                t01.水揚金額       = row["水揚金額"].ToString() == "" ? 0 : Convert.ToInt32(row["水揚金額"].ToString());
                                t01.社内区分       = row["社内区分"].ToString() == "" ? 0 : Convert.ToInt32(row["社内区分"].ToString());
                                t01.請求税区分      = row["請求税区分"].ToString() == "" ? 0 : Convert.ToInt32(row["請求税区分"].ToString());
                                t01.支払税区分      = row["支払税区分"].ToString() == "" ? 0 : Convert.ToInt32(row["支払税区分"].ToString());
                                t01.商品ID       = row["商品ID"].ToString() == "" ? code : Convert.ToInt32(row["商品ID"].ToString());
                                t01.商品名        = Convert.ToString(row["商品名"].ToString());
                                t01.発地ID       = row["発地ID"].ToString() == "" ? code : Convert.ToInt32(row["発地ID"].ToString());
                                t01.発地名        = Convert.ToString(row["発地名"].ToString());
                                t01.着地ID       = row["着地ID"].ToString() == "" ? code : Convert.ToInt32(row["着地ID"].ToString());
                                t01.着地名        = Convert.ToString(row["着地名"].ToString());
                                t01.請求摘要ID     = row["請求摘要ID"].ToString() == "" ? code : Convert.ToInt32(row["請求摘要ID"].ToString());
                                t01.請求摘要       = Convert.ToString(row["請求摘要"].ToString());
                                t01.社内備考ID     = row["社内備考ID"].ToString() == "" ? code : Convert.ToInt32(row["社内備考ID"].ToString());
                                t01.社内備考       = Convert.ToString(row["社内備考"].ToString());
                                t01.入力者ID      = row["入力者ID"].ToString() == "" ? code : Convert.ToInt32(row["入力者ID"].ToString());

                                context.T01_TRN.ApplyChanges(t01);
                                context.SaveChanges();


                                t01.明細番号       = p明細番号;
                                t01.明細行        = 2;
                                t01.登録日時       = DateTime.Now;
                                t01.更新日時       = DateTime.Now;
                                t01.明細区分       = 1;
                                t01.入力区分       = 3;
                                t01.請求日付       = Convert.ToDateTime(row["請求日付"].ToString());
                                t01.支払日付       = Convert.ToDateTime(row["支払日付"].ToString());
                                t01.配送日付       = Convert.ToDateTime(row["配送日付"].ToString());
                                t01.配送時間       = Convert.ToDecimal(row["配送時間"].ToString());
                                t01.得意先KEY     = Convert.ToInt32(row["得意先KEY"].ToString());
                                t01.請求内訳ID     = row["請求内訳ID"].ToString() == "" ? code : Convert.ToInt32(row["請求内訳ID"].ToString());
                                t01.車輌KEY      = row["車輌KEY"].ToString() == "" ? code : Convert.ToInt32(row["車輌KEY"].ToString());
                                t01.車種ID       = row["車種ID"].ToString() == "" ? code : Convert.ToInt32(row["車種ID"].ToString());
                                t01.支払先KEY     = row["支払先KEY"].ToString() == "" ? code : Convert.ToInt32(row["支払先KEY"].ToString());
                                t01.乗務員KEY     = row["乗務員KEY"].ToString() == "" ? code : Convert.ToInt32(row["乗務員KEY"].ToString());
                                t01.自社部門ID     = row["自社部門ID"].ToString() == "" ? 0 : Convert.ToInt32(row["自社部門ID"].ToString());
                                t01.車輌番号       = Convert.ToString(row["車輌番号"].ToString());
                                t01.支払先名2次     = Convert.ToString(row["支払先名2次"].ToString());
                                t01.実運送乗務員     = Convert.ToString(row["実運送乗務員"].ToString());
                                t01.乗務員連絡先     = Convert.ToString(row["乗務員連絡先"].ToString());
                                t01.請求運賃計算区分ID = row["請求運賃計算区分ID"].ToString() == "" ? 0 : Convert.ToInt32(row["請求運賃計算区分ID"].ToString());
                                t01.支払運賃計算区分ID = row["支払運賃計算区分ID"].ToString() == "" ? 0 : Convert.ToInt32(row["支払運賃計算区分ID"].ToString());
                                t01.数量         = row["数量"].ToString() == "" ? 0 : Convert.ToDecimal(row["数量"].ToString());
                                t01.単位         = Convert.ToString(row["単位"].ToString());
                                t01.重量         = row["重量"].ToString() == "" ? 0 : Convert.ToDecimal(row["重量"].ToString());
                                t01.走行KM       = row["走行KM"].ToString() == "" ? 0 : Convert.ToInt32(row["走行KM"].ToString());
                                t01.実車KM       = row["実車KM"].ToString() == "" ? 0 : Convert.ToInt32(row["実車KM"].ToString());
                                t01.待機時間       = row["待機時間"].ToString() == "" ? 0 : Convert.ToDecimal(row["待機時間"].ToString());
                                t01.売上単価       = row["売上単価"].ToString() == "" ? 0 : Convert.ToDecimal(row["売上単価"].ToString());
                                t01.売上金額       = row["売上金額"].ToString() == "" ? 0 : Convert.ToInt32(row["売上金額"].ToString());
                                t01.通行料        = row["通行料"].ToString() == "" ? 0 : Convert.ToInt32(row["通行料"].ToString());
                                t01.請求割増1      = row["請求割増1"].ToString() == "" ? 0 : Convert.ToInt32(row["請求割増1"].ToString());
                                t01.請求割増2      = row["請求割増2"].ToString() == "" ? 0 : Convert.ToInt32(row["請求割増2"].ToString());
                                t01.請求消費税      = row["請求消費税"].ToString() == "" ? 0 : Convert.ToInt32(row["請求消費税"].ToString());
                                t01.支払単価       = row["支払単価"].ToString() == "" ? 0 : Convert.ToDecimal(row["支払単価"].ToString());
                                t01.支払金額       = row["支払金額"].ToString() == "" ? 0 : Convert.ToInt32(row["支払金額"].ToString());
                                t01.支払通行料      = row["支払通行料"].ToString() == "" ? 0 : Convert.ToInt32(row["支払通行料"].ToString());
                                t01.支払割増1      = row["支払割増1"].ToString() == "" ? 0 : Convert.ToInt32(row["支払割増1"].ToString());
                                t01.支払割増2      = row["支払割増2"].ToString() == "" ? 0 : Convert.ToInt32(row["支払割増2"].ToString());
                                t01.支払消費税      = row["支払消費税"].ToString() == "" ? 0 : Convert.ToInt32(row["支払消費税"].ToString());
                                t01.水揚金額       = row["水揚金額"].ToString() == "" ? 0 : Convert.ToInt32(row["水揚金額"].ToString());
                                t01.社内区分       = row["社内区分"].ToString() == "" ? 0 : Convert.ToInt32(row["社内区分"].ToString());
                                t01.請求税区分      = row["請求税区分"].ToString() == "" ? 0 : Convert.ToInt32(row["請求税区分"].ToString());
                                t01.支払税区分      = row["支払税区分"].ToString() == "" ? 0 : Convert.ToInt32(row["支払税区分"].ToString());
                                t01.商品ID       = row["商品ID"].ToString() == "" ? code : Convert.ToInt32(row["商品ID"].ToString());
                                t01.商品名        = Convert.ToString(row["商品名"].ToString());
                                t01.発地ID       = row["発地ID"].ToString() == "" ? code : Convert.ToInt32(row["発地ID"].ToString());
                                t01.発地名        = Convert.ToString(row["発地名"].ToString());
                                t01.着地ID       = row["着地ID"].ToString() == "" ? code : Convert.ToInt32(row["着地ID"].ToString());
                                t01.着地名        = Convert.ToString(row["着地名"].ToString());
                                t01.請求摘要ID     = row["請求摘要ID"].ToString() == "" ? code : Convert.ToInt32(row["請求摘要ID"].ToString());
                                t01.請求摘要       = Convert.ToString(row["請求摘要"].ToString());
                                t01.社内備考ID     = row["社内備考ID"].ToString() == "" ? code : Convert.ToInt32(row["社内備考ID"].ToString());
                                t01.社内備考       = Convert.ToString(row["社内備考"].ToString());
                                t01.入力者ID      = row["入力者ID"].ToString() == "" ? code : Convert.ToInt32(row["入力者ID"].ToString());

                                context.T01_TRN.ApplyChanges(t01);
                                context.SaveChanges();
                            }
                            break;
                            #endregion

                        case 1:
                            #region UTRN
                            foreach (DataRow row in dt.Rows)
                            {
                                // 新番号取得
                                var 明細番号M = (from n in context.M88_SEQ
                                             where n.明細番号ID == 1
                                             select n
                                             ).FirstOrDefault();
                                if (明細番号M == null)
                                {
                                    break;
                                }
                                int p明細番号 = 明細番号M.現在明細番号 + 1;
                                明細番号M.現在明細番号 = p明細番号;
                                明細番号M.AcceptChanges();


                                //IDからKEYを取得
                                int?    code    = null;
                                decimal?nulldec = null;
                                code          = row["車輌KEY"].ToString() == "" ? code : Convert.ToInt32(row["車輌KEY"].ToString());
                                row["車輌KEY"]  = (from m05 in context.M05_CAR where m05.車輌ID == code select m05.車輌KEY).Any() == false ? 0 : (from m05 in context.M05_CAR where m05.車輌ID == code select m05.車輌KEY).First();
                                code          = null;
                                code          = row["乗務員KEY"].ToString() == "" ? code : Convert.ToInt32(row["乗務員KEY"].ToString());
                                row["乗務員KEY"] = (from m04 in context.M04_DRV where m04.乗務員ID == code select m04.乗務員KEY).Any() == false ? 0 : (from m04 in context.M04_DRV where m04.乗務員ID == code select m04.乗務員KEY).First();

                                T02_UTRN t02 = new T02_UTRN();
                                code       = null;
                                nulldec    = null;
                                t02.明細番号   = p明細番号;
                                t02.明細行    = 1;
                                t02.登録日時   = DateTime.Now;
                                t02.更新日時   = DateTime.Now;
                                t02.明細区分   = 1;
                                t02.入力区分   = 2;
                                t02.実運行日開始 = Convert.ToDateTime(row["実運行日開始"].ToString());
                                t02.実運行日終了 = Convert.ToDateTime(row["実運行日終了"].ToString());
                                t02.車輌KEY  = row["車輌KEY"].ToString() == "" ? code : Convert.ToInt32(row["車輌KEY"].ToString());
                                t02.乗務員KEY = row["乗務員KEY"].ToString() == "" ? code : Convert.ToInt32(row["乗務員KEY"].ToString());
                                t02.車種ID   = row["車種ID"].ToString() == "" ? code : Convert.ToInt32(row["車種ID"].ToString());
                                t02.車輌番号   = Convert.ToString(row["車輌番号"].ToString());
                                t02.自社部門ID = row["自社部門ID"].ToString() == "" ? code : Convert.ToInt32(row["自社部門ID"].ToString());
                                t02.出庫時間   = row["出庫時間"].ToString() == "" ? nulldec : Convert.ToDecimal(row["出庫時間"].ToString());
                                t02.帰庫時間   = row["帰庫時間"].ToString() == "" ? nulldec : Convert.ToDecimal(row["帰庫時間"].ToString());
                                t02.出勤区分ID = row["出勤区分ID"].ToString() == "" ? 0 : Convert.ToInt32(row["出勤区分ID"].ToString());
                                t02.拘束時間   = row["拘束時間"].ToString() == "" ? nulldec : Convert.ToDecimal(row["拘束時間"].ToString());
                                t02.運転時間   = row["運転時間"].ToString() == "" ? nulldec : Convert.ToDecimal(row["運転時間"].ToString());
                                t02.高速時間   = row["高速時間"].ToString() == "" ? nulldec : Convert.ToDecimal(row["高速時間"].ToString());
                                t02.作業時間   = row["作業時間"].ToString() == "" ? nulldec : Convert.ToDecimal(row["作業時間"].ToString());
                                t02.待機時間   = row["待機時間"].ToString() == "" ? nulldec : Convert.ToDecimal(row["待機時間"].ToString());
                                t02.休憩時間   = row["休憩時間"].ToString() == "" ? nulldec : Convert.ToDecimal(row["休憩時間"].ToString());
                                t02.残業時間   = row["残業時間"].ToString() == "" ? nulldec : Convert.ToDecimal(row["残業時間"].ToString());
                                t02.深夜時間   = row["深夜時間"].ToString() == "" ? nulldec : Convert.ToDecimal(row["深夜時間"].ToString());
                                t02.走行KM   = row["走行KM"].ToString() == "" ? 0 : Convert.ToInt32(row["走行KM"].ToString());
                                t02.実車KM   = row["実車KM"].ToString() == "" ? 0 : Convert.ToInt32(row["実車KM"].ToString());
                                t02.輸送屯数   = row["輸送屯数"].ToString() == "" ? 0 : Convert.ToDecimal(row["輸送屯数"].ToString());
                                t02.出庫KM   = row["出庫KM"].ToString() == "" ? 0 : Convert.ToInt32(row["出庫KM"].ToString());
                                t02.帰庫KM   = row["帰庫KM"].ToString() == "" ? 0 : Convert.ToInt32(row["帰庫KM"].ToString());
                                t02.備考     = Convert.ToString(row["備考"].ToString());
                                t02.勤務開始日  = Convert.ToDateTime(row["勤務開始日"].ToString());
                                t02.勤務終了日  = Convert.ToDateTime(row["勤務終了日"].ToString());
                                t02.労務日    = Convert.ToDateTime(row["労務日"].ToString());
                                t02.入力者ID  = row["入力者ID"].ToString() == "" ? code : Convert.ToInt32(row["入力者ID"].ToString());

                                context.T02_UTRN.ApplyChanges(t02);
                                context.SaveChanges();
                                Cnt += 1;
                            }
                            break;
                            #endregion


                        case 2:
                            #region KTRN  注:データベースが車輌IDになっている。
                            foreach (DataRow row in dt.Rows)
                            {
                                // 新番号取得
                                var 明細番号M = (from n in context.M88_SEQ
                                             where n.明細番号ID == 1
                                             select n
                                             ).FirstOrDefault();
                                if (明細番号M == null)
                                {
                                    break;
                                }
                                int p明細番号 = 明細番号M.現在明細番号 + 1;
                                明細番号M.現在明細番号 = p明細番号;
                                明細番号M.AcceptChanges();

                                //IDからKEYを取得
                                int?    code    = null;
                                decimal?nulldec = null;
                                code          = row["車輌ID"].ToString() == "" ? code : Convert.ToInt32(row["車輌ID"].ToString());
                                row["車輌ID"]   = (from m05 in context.M05_CAR where m05.車輌ID == code select m05.車輌KEY).Any() == false ? 0 : (from m05 in context.M05_CAR where m05.車輌ID == code select m05.車輌KEY).First();
                                code          = null;
                                code          = row["支払先KEY"].ToString() == "" ? code : Convert.ToInt32(row["支払先KEY"].ToString());
                                row["支払先KEY"] = (from m01 in context.M01_TOK where m01.得意先ID == code select m01.得意先KEY).Any() == false ? 0 : (from m01 in context.M01_TOK where m01.得意先ID == code select m01.得意先KEY).First();
                                code          = null;
                                code          = row["乗務員KEY"].ToString() == "" ? code : Convert.ToInt32(row["乗務員KEY"].ToString());
                                row["乗務員KEY"] = (from m04 in context.M04_DRV where m04.乗務員ID == code select m04.乗務員KEY).Any() == false ? 0 : (from m04 in context.M04_DRV where m04.乗務員ID == code select m04.乗務員KEY).First();

                                T03_KTRN t03 = new T03_KTRN();
                                code    = null;
                                nulldec = null;

                                t03.明細番号   = p明細番号;
                                t03.明細行    = 1;
                                t03.登録日時   = DateTime.Now;
                                t03.更新日時   = DateTime.Now;
                                t03.明細区分   = 1;
                                t03.入力区分   = 1;
                                t03.経費発生日  = Convert.ToDateTime(row["経費発生日"].ToString());
                                t03.車輌ID   = row["車輌ID"].ToString() == "" ? code : Convert.ToInt32(row["車輌ID"].ToString());
                                t03.車輌番号   = Convert.ToString(row["車輌番号"].ToString());
                                t03.メーター   = row["メーター"].ToString() == "" ? code : Convert.ToInt32(row["メーター"].ToString());
                                t03.乗務員KEY = row["乗務員KEY"].ToString() == "" ? code : Convert.ToInt32(row["乗務員KEY"].ToString());
                                t03.支払先KEY = row["支払先KEY"].ToString() == "" ? code : Convert.ToInt32(row["支払先KEY"].ToString());
                                t03.自社部門ID = row["自社部門ID"].ToString() == "" ? code : Convert.ToInt32(row["自社部門ID"].ToString());
                                t03.経費項目ID = row["経費項目ID"].ToString() == "" ? code : Convert.ToInt32(row["経費項目ID"].ToString());
                                t03.経費補助名称 = Convert.ToString(row["経費補助名称"].ToString());
                                t03.単価     = row["単価"].ToString() == "" ? 0 : Convert.ToDecimal(row["単価"].ToString());
                                t03.内軽油税分  = row["内軽油税分"].ToString() == "" ? nulldec : Convert.ToDecimal(row["内軽油税分"].ToString());
                                t03.数量     = row["数量"].ToString() == "" ? nulldec : Convert.ToDecimal(row["数量"].ToString());
                                t03.金額     = row["金額"].ToString() == "" ? code : Convert.ToInt32(row["金額"].ToString());
                                t03.収支区分   = row["収支区分"].ToString() == "" ? code : Convert.ToInt32(row["収支区分"].ToString());
                                t03.摘要ID   = row["摘要ID"].ToString() == "" ? code : Convert.ToInt32(row["収支区分"].ToString());
                                t03.摘要名    = Convert.ToString(row["摘要名"].ToString());
                                t03.入力者ID  = row["入力者ID"].ToString() == "" ? code : Convert.ToInt32(row["入力者ID"].ToString());

                                context.T03_KTRN.ApplyChanges(t03);
                                context.SaveChanges();
                                Cnt += 1;
                            }
                            break;
                            #endregion

                        case 3:
                            #region NTRN
                            foreach (DataRow row in dt.Rows)
                            {
                                // 新番号取得
                                var 明細番号M = (from n in context.M88_SEQ
                                             where n.明細番号ID == 1
                                             select n
                                             ).FirstOrDefault();
                                if (明細番号M == null)
                                {
                                    break;
                                }
                                int p明細番号 = 明細番号M.現在明細番号 + 1;
                                明細番号M.現在明細番号 = p明細番号;
                                明細番号M.AcceptChanges();


                                //IDからKEYを取得
                                int?    code    = null;
                                decimal?nulldec = null;
                                code          = row["得意先KEY"].ToString() == "" ? code : Convert.ToInt32(row["得意先KEY"].ToString());
                                row["得意先KEY"] = (from m01 in context.M01_TOK where m01.得意先ID == code select m01.得意先KEY).Any() == false ? 0 : (from m01 in context.M01_TOK where m01.得意先ID == code select m01.得意先KEY).First();

                                T04_NYUK t04 = new T04_NYUK();
                                code    = null;
                                nulldec = null;

                                t04.明細番号   = p明細番号;
                                t04.明細行    = 1;
                                t04.登録日時   = DateTime.Now;
                                t04.更新日時   = DateTime.Now;
                                t04.明細区分   = Convert.ToInt32(row["明細区分"].ToString());
                                t04.入出金日付  = Convert.ToDateTime(row["入出金日付"].ToString());
                                t04.取引先KEY = Convert.ToInt32(row["得意先KEY"].ToString());
                                t04.入出金区分  = row["入出金区分"].ToString() == "" ? 0 : Convert.ToInt32(row["入出金区分"].ToString());
                                t04.入出金金額  = row["入出金金額"].ToString() == "" ? 0 : Convert.ToInt32(row["入出金金額"].ToString());
                                t04.摘要ID   = row["摘要ID"].ToString() == "" ? code : Convert.ToInt32(row["摘要ID"].ToString());
                                t04.摘要名    = Convert.ToString(row["摘要名"].ToString());
                                t04.手形日付   = Convert.ToDateTime(row["手形日付"].ToString());
                                t04.入力者ID  = row["入力者ID"].ToString() == "" ? code : Convert.ToInt32(row["入力者ID"].ToString());

                                context.T04_NYUK.ApplyChanges(t04);
                                context.SaveChanges();
                                Cnt += 1;
                            }
                            break;
                            #endregion
                        }
                        return;
                    }
                }
                catch (Exception ex)
                {
                    throw ex;
                }
            }
        }
Beispiel #2
0
        /// <summary>
        /// データ取得
        /// </summary>
        public void SEARCH_MST900601(DataSet ds, int no)
        {
            using (TRAC3Entities context = new TRAC3Entities(CommonData.TRAC3_GetConnectionString()))
            {
                context.Connection.Open();
                try
                {
                    using (DbTransaction transaction = context.Connection.BeginTransaction())
                    {
                        //変数宣言
                        DataTable dt;
                        dt = ds.Tables["CSV取り込み"];

                        switch (no)
                        {
                        case 0:
                            #region TRN


                            foreach (DataRow row in dt.Rows)
                            {
                                // 20150715 wada add エラーでない行を登録対象とする。
                                if (!row.HasErrors)
                                {
                                    int i明細番号 = ConvertToInt(row["明細番号"]);
                                    int i明細行  = ConvertToInt(row["明細行"]);
                                    // 新番号取得
                                    var 明細番号M = (from n in context.M88_SEQ
                                                 where n.明細番号ID == 1
                                                 select n
                                                 ).FirstOrDefault();
                                    if (明細番号M.現在明細番号 < i明細番号)
                                    {
                                        int p明細番号 = i明細番号 + 1;
                                        明細番号M.現在明細番号 = p明細番号;
                                        明細番号M.AcceptChanges();
                                    }
                                    if (i明細番号 == 0)
                                    {
                                        i明細番号 = 明細番号M.現在明細番号 + 1;
                                        i明細行  = 1;

                                        int p明細番号 = i明細番号;
                                        明細番号M.現在明細番号 = p明細番号;
                                        明細番号M.AcceptChanges();
                                    }

                                    int i得意先KEY = ConvertToInt(row["得意先KEY"]);
                                    int i支払先KEY = ConvertToInt(row["支払先KEY"]);
                                    int i車輌KEY  = ConvertToInt(row["車輌KEY"]);
                                    int i乗務員KEY = ConvertToInt(row["乗務員KEY"]);
                                    //得意先
                                    var ret = (from m01 in context.M01_TOK
                                               where m01.得意先ID == i得意先KEY
                                               select new MST90060_KEY
                                    {
                                        Key = m01.得意先KEY,
                                    }).AsQueryable();
                                    foreach (var keys in ret)
                                    {
                                        i得意先KEY = keys.Key;
                                    }
                                    //支払先
                                    var ret1 = (from m01 in context.M01_TOK
                                                where m01.得意先ID == i支払先KEY
                                                select new MST90060_KEY
                                    {
                                        Key = m01.得意先KEY,
                                    }).AsQueryable();
                                    foreach (var keys in ret1)
                                    {
                                        i支払先KEY = keys.Key;
                                    }
                                    //車輌
                                    var ret2 = (from m05 in context.M05_CAR
                                                where m05.車輌ID == i車輌KEY
                                                select new MST90060_KEY
                                    {
                                        Key = m05.車輌KEY,
                                    }).AsQueryable();
                                    foreach (var keys in ret2)
                                    {
                                        i車輌KEY = keys.Key;
                                    }
                                    //乗務員
                                    var ret3 = (from m04 in context.M04_DRV
                                                where m04.乗務員ID == i乗務員KEY
                                                select new MST90060_KEY
                                    {
                                        Key = m04.乗務員KEY,
                                    }).AsQueryable();
                                    foreach (var keys in ret3)
                                    {
                                        i乗務員KEY = keys.Key;
                                    }


                                    T01_TRN t01 = new T01_TRN();
                                    t01.明細番号       = i明細番号;                                      //ConvertToInt(row["明細番号"]);
                                    t01.明細行        = i明細行;                                       //ConvertToInt(row["明細行"]);
                                    t01.登録日時       = DateTime.Now;
                                    t01.更新日時       = DateTime.Now;
                                    t01.明細区分       = ConvertToInt(row["明細区分"]);
                                    t01.入力区分       = ConvertToInt(row["入力区分"]);
                                    t01.請求日付       = ConvertToDateTime(row["請求日付"]);
                                    t01.支払日付       = ConvertToDateTime(row["支払日付"]);
                                    t01.配送日付       = ConvertToDateTime(row["配送日付"]);
                                    t01.配送時間       = ConvertToDecimal(row["配送時間"]);
                                    t01.得意先KEY     = i得意先KEY;
                                    t01.請求内訳ID     = ConvertToIntNullable(row["請求内訳ID"]);
                                    t01.車輌KEY      = i車輌KEY;
                                    t01.車種ID       = ConvertToIntNullable(row["車種ID"]);
                                    t01.支払先KEY     = i支払先KEY;
                                    t01.乗務員KEY     = i乗務員KEY;
                                    t01.自社部門ID     = ConvertToInt(row["自社部門ID"]);
                                    t01.車輌番号       = ConvertToStringNullable(row["車輌番号"]);
                                    t01.支払先名2次     = ConvertToStringNullable(row["支払先名2次"]);
                                    t01.実運送乗務員     = ConvertToStringNullable(row["実運送乗務員"]);
                                    t01.乗務員連絡先     = ConvertToStringNullable(row["乗務員連絡先"]);
                                    t01.請求運賃計算区分ID = ConvertToInt(row["請求運賃計算区分ID"]);
                                    t01.支払運賃計算区分ID = ConvertToInt(row["支払運賃計算区分ID"]);
                                    t01.数量         = ConvertToDecimal(row["数量"]);
                                    t01.単位         = ConvertToStringNullable(row["単位"]);
                                    t01.重量         = ConvertToDecimal(row["重量"]);
                                    t01.走行KM       = ConvertToInt(row["走行KM"]);
                                    t01.実車KM       = ConvertToInt(row["実車KM"]);
                                    t01.待機時間       = ConvertToDecimal(row["重量"]);
                                    t01.売上単価       = ConvertToDecimal(row["売上単価"]);
                                    t01.売上金額       = ConvertToInt(row["売上金額"]);
                                    t01.通行料        = ConvertToInt(row["通行料"]);
                                    t01.請求割増1      = ConvertToInt(row["請求割増1"]);
                                    t01.請求割増2      = ConvertToInt(row["請求割増2"]);
                                    t01.請求消費税      = ConvertToInt(row["請求消費税"]);
                                    t01.支払単価       = ConvertToDecimal(row["支払単価"]);
                                    t01.支払金額       = ConvertToInt(row["支払金額"]);
                                    t01.支払通行料      = ConvertToInt(row["支払通行料"]);
                                    t01.支払割増1      = ConvertToInt(row["支払割増1"]);
                                    t01.支払割増2      = ConvertToInt(row["支払割増2"]);
                                    t01.支払消費税      = ConvertToInt(row["支払消費税"]);
                                    t01.水揚金額       = ConvertToInt(row["水揚金額"]);
                                    t01.社内区分       = ConvertToInt(row["社内区分"]);
                                    t01.請求税区分      = ConvertToInt(row["請求税区分"]);
                                    t01.支払税区分      = ConvertToInt(row["支払税区分"]);
                                    t01.商品ID       = ConvertToIntNullable(row["商品ID"]);
                                    t01.商品名        = ConvertToStringNullable(row["商品名"]);
                                    t01.発地ID       = ConvertToIntNullable(row["発地ID"]);
                                    t01.発地名        = ConvertToStringNullable(row["発地名"]);
                                    t01.着地ID       = ConvertToIntNullable(row["着地ID"]);
                                    t01.着地名        = ConvertToStringNullable(row["着地名"]);
                                    t01.請求摘要ID     = ConvertToIntNullable(row["請求摘要ID"]);
                                    t01.請求摘要       = ConvertToStringNullable(row["請求摘要"]);
                                    t01.社内備考ID     = ConvertToIntNullable(row["社内備考ID"]);
                                    t01.社内備考       = ConvertToStringNullable(row["社内備考"]);
                                    t01.入力者ID      = ConvertToIntNullable(row["入力者ID"]);

                                    context.T01_TRN.ApplyChanges(t01);
                                }
                            }
                            context.SaveChanges();
                            transaction.Commit();
                            break;
                            #endregion

                        case 1:
                            #region UTRN
                            foreach (DataRow row in dt.Rows)
                            {
                                // 20150715 wada add エラーでない行を登録対象とする。
                                if (!row.HasErrors)
                                {
                                    int i明細番号 = ConvertToInt(row["明細番号"]);
                                    int i明細行  = ConvertToInt(row["明細行"]);
                                    // 新番号取得
                                    var 明細番号M = (from n in context.M88_SEQ
                                                 where n.明細番号ID == 1
                                                 select n
                                                 ).FirstOrDefault();
                                    if (明細番号M.現在明細番号 < i明細番号)
                                    {
                                        int p明細番号 = i明細番号 + 1;
                                        明細番号M.現在明細番号 = p明細番号;
                                        明細番号M.AcceptChanges();
                                    }
                                    if (i明細番号 == 0)
                                    {
                                        i明細番号 = 明細番号M.現在明細番号 + 1;
                                        i明細行  = 1;

                                        int p明細番号 = i明細番号;
                                        明細番号M.現在明細番号 = p明細番号;
                                        明細番号M.AcceptChanges();
                                    }

                                    int i車輌KEY  = ConvertToInt(row["車輌KEY"]);
                                    int i乗務員KEY = ConvertToInt(row["乗務員KEY"]);
                                    //車輌
                                    var ret = (from m05 in context.M05_CAR
                                               where m05.車輌ID == i車輌KEY
                                               select new MST90060_KEY
                                    {
                                        Key = m05.車輌KEY,
                                    }).AsQueryable();
                                    foreach (var keys in ret)
                                    {
                                        i車輌KEY = keys.Key;
                                    }
                                    //乗務員
                                    var ret1 = (from m04 in context.M04_DRV
                                                where m04.乗務員ID == i乗務員KEY
                                                select new MST90060_KEY
                                    {
                                        Key = m04.乗務員KEY,
                                    }).AsQueryable();
                                    foreach (var keys in ret1)
                                    {
                                        i乗務員KEY = keys.Key;
                                    }


                                    T02_UTRN t02 = new T02_UTRN();
                                    t02.明細番号   = i明細番号;                                         // ConvertToInt(row["明細番号"]);
                                    t02.明細行    = i明細行;                                          // ConvertToInt(row["明細行"]);
                                    t02.登録日時   = DateTime.Now;
                                    t02.更新日時   = DateTime.Now;
                                    t02.明細区分   = 1;
                                    t02.入力区分   = 2;
                                    t02.実運行日開始 = ConvertToDateTimeNullable(row["実運行日開始"]);
                                    t02.実運行日終了 = ConvertToDateTimeNullable(row["実運行日終了"]);
                                    t02.車輌KEY  = i車輌KEY;
                                    t02.乗務員KEY = i乗務員KEY;
                                    t02.車種ID   = ConvertToIntNullable(row["車種ID"]);
                                    t02.車輌番号   = ConvertToStringNullable(row["車輌番号"]);
                                    t02.自社部門ID = ConvertToIntNullable(row["自社部門ID"]);
                                    t02.出庫時間   = ConvertToDecimal(row["出庫時間"]);
                                    t02.帰庫時間   = ConvertToDecimal(row["帰庫時間"]);
                                    t02.出勤区分ID = ConvertToInt(row["出勤区分ID"]);
                                    t02.拘束時間   = ConvertToDecimal(row["拘束時間"]);
                                    t02.運転時間   = ConvertToDecimal(row["運転時間"]);
                                    t02.高速時間   = ConvertToDecimal(row["高速時間"]);
                                    t02.作業時間   = ConvertToDecimal(row["作業時間"]);
                                    t02.待機時間   = ConvertToDecimal(row["待機時間"]);
                                    t02.休憩時間   = ConvertToDecimal(row["休憩時間"]);
                                    t02.残業時間   = ConvertToDecimal(row["残業時間"]);
                                    t02.深夜時間   = ConvertToDecimal(row["深夜時間"]);
                                    t02.走行KM   = ConvertToInt(row["走行KM"]);
                                    t02.実車KM   = ConvertToInt(row["実車KM"]);
                                    t02.輸送屯数   = ConvertToDecimal(row["輸送屯数"]);
                                    t02.出庫KM   = ConvertToInt(row["出庫KM"]);
                                    t02.帰庫KM   = ConvertToInt(row["帰庫KM"]);
                                    t02.備考     = ConvertToStringNullable(row["備考"]);
                                    t02.勤務開始日  = ConvertToDateTime(row["勤務開始日"]);
                                    t02.勤務終了日  = ConvertToDateTime(row["勤務終了日"]);
                                    t02.労務日    = ConvertToDateTime(row["労務日"]);
                                    t02.入力者ID  = ConvertToIntNullable(row["入力者ID"]);
                                    context.T02_UTRN.ApplyChanges(t02);
                                }
                            }
                            context.SaveChanges();
                            transaction.Commit();
                            break;
                            #endregion

                        case 2:
                            #region KTRN  注:データベースが車輌IDになっている。
                            foreach (DataRow row in dt.Rows)
                            {
                                // 20150715 wada add エラーでない行を登録対象とする。
                                if (!row.HasErrors)
                                {
                                    int i明細番号 = ConvertToInt(row["明細番号"]);
                                    int i明細行  = ConvertToInt(row["明細行"]);
                                    // 新番号取得
                                    var 明細番号M = (from n in context.M88_SEQ
                                                 where n.明細番号ID == 1
                                                 select n
                                                 ).FirstOrDefault();
                                    if (明細番号M.現在明細番号 < i明細番号)
                                    {
                                        int p明細番号 = i明細番号;
                                        明細番号M.現在明細番号 = p明細番号;
                                        明細番号M.AcceptChanges();
                                    }
                                    if (i明細番号 == 0)
                                    {
                                        i明細番号 = 明細番号M.現在明細番号 + 1;
                                        i明細行  = 1;

                                        int p明細番号 = i明細番号;
                                        明細番号M.現在明細番号 = p明細番号;
                                        明細番号M.AcceptChanges();
                                    }

                                    int i支払先KEY = ConvertToInt(row["支払先KEY"]);
                                    int i乗務員KEY = ConvertToInt(row["乗務員KEY"]);
                                    int i車輌KEY  = ConvertToInt(row["車輌ID"]);
                                    //支払先
                                    var ret = (from m01 in context.M01_TOK
                                               where m01.得意先ID == i支払先KEY
                                               select new MST90060_KEY
                                    {
                                        Key = m01.得意先KEY,
                                    }).AsQueryable();
                                    foreach (var keys in ret)
                                    {
                                        i支払先KEY = keys.Key;
                                    }
                                    //乗務員
                                    var ret1 = (from m04 in context.M04_DRV
                                                where m04.乗務員ID == i乗務員KEY
                                                select new MST90060_KEY
                                    {
                                        Key = m04.乗務員KEY,
                                    }).AsQueryable();
                                    foreach (var keys in ret1)
                                    {
                                        i乗務員KEY = keys.Key;
                                    }
                                    //車輌
                                    var ret2 = (from m05 in context.M05_CAR
                                                where m05.車輌ID == i車輌KEY
                                                select new MST90060_KEY
                                    {
                                        Key = m05.車輌KEY,
                                    }).AsQueryable();
                                    foreach (var keys in ret2)
                                    {
                                        i車輌KEY = keys.Key;
                                    }


                                    T03_KTRN t03 = new T03_KTRN();
                                    t03.明細番号   = i明細番号;                                         // ConvertToInt(row["明細番号"]);
                                    t03.明細行    = i明細行;                                          // ConvertToInt(row["明細行"]);
                                    t03.登録日時   = DateTime.Now;
                                    t03.更新日時   = DateTime.Now;
                                    t03.明細区分   = 1;
                                    t03.入力区分   = 1;
                                    t03.経費発生日  = ConvertToDateTimeNullable(row["経費発生日"]);
                                    t03.車輌ID   = i車輌KEY;
                                    t03.車輌番号   = ConvertToStringNullable(row["車輌番号"]);
                                    t03.メーター   = ConvertToIntNullable(row["メーター"]);
                                    t03.乗務員KEY = i乗務員KEY;
                                    t03.支払先KEY = i支払先KEY;
                                    t03.自社部門ID = ConvertToIntNullable(row["自社部門ID"]);
                                    t03.経費項目ID = ConvertToIntNullable(row["経費項目ID"]);
                                    t03.経費補助名称 = ConvertToStringNullable(row["経費補助名称"]);
                                    t03.単価     = ConvertToDecimal(row["単価"]);
                                    t03.内軽油税分  = ConvertToDecimal(row["内軽油税分"]);
                                    t03.数量     = ConvertToDecimal(row["数量"]);
                                    t03.金額     = ConvertToInt(row["金額"]);
                                    t03.収支区分   = ConvertToIntNullable(row["収支区分"]);
                                    t03.摘要ID   = ConvertToIntNullable(row["摘要ID"]);
                                    t03.摘要名    = ConvertToStringNullable(row["摘要名"]);
                                    t03.入力者ID  = ConvertToIntNullable(row["入力者ID"]);

                                    context.T03_KTRN.ApplyChanges(t03);
                                }
                            }
                            context.SaveChanges();
                            transaction.Commit();
                            break;
                            #endregion

                        case 3:
                            #region NTRN
                            foreach (DataRow row in dt.Rows)
                            {
                                // 20150715 wada add エラーでない行を登録対象とする。
                                if (!row.HasErrors)
                                {
                                    int i明細番号 = ConvertToInt(row["明細番号"]);
                                    int i明細行  = ConvertToInt(row["明細行"]);
                                    // 新番号取得
                                    var 明細番号M = (from n in context.M88_SEQ
                                                 where n.明細番号ID == 1
                                                 select n
                                                 ).FirstOrDefault();
                                    if (明細番号M.現在明細番号 < i明細番号)
                                    {
                                        int p明細番号 = 明細番号M.現在明細番号 + 1;
                                        明細番号M.現在明細番号 = p明細番号;
                                        明細番号M.AcceptChanges();
                                    }
                                    if (i明細番号 == 0)
                                    {
                                        i明細番号 = 明細番号M.現在明細番号 + 1;
                                        i明細行  = 1;

                                        int p明細番号 = i明細番号;
                                        明細番号M.現在明細番号 = p明細番号;
                                        明細番号M.AcceptChanges();
                                    }

                                    int i得意先KEY = ConvertToInt(row["取引先KEY"]);
                                    //得意先
                                    var ret = (from m01 in context.M01_TOK
                                               where m01.得意先ID == i得意先KEY
                                               select new MST90060_KEY
                                    {
                                        Key = m01.得意先KEY,
                                    }).AsQueryable();
                                    foreach (var keys in ret)
                                    {
                                        i得意先KEY = keys.Key;
                                    }

                                    T04_NYUK t04 = new T04_NYUK();
                                    t04.明細番号   = i明細番号;                                         // ConvertToInt(row["明細番号"]);
                                    t04.明細行    = i明細行;                                          // ConvertToInt(row["明細行"]);
                                    t04.登録日時   = DateTime.Now;
                                    t04.更新日時   = DateTime.Now;
                                    t04.明細区分   = ConvertToInt(row["明細区分"]);
                                    t04.入出金日付  = ConvertToDateTimeNullable(row["入出金日付"]);
                                    t04.取引先KEY = i得意先KEY;
                                    t04.入出金区分  = ConvertToInt(row["入出金区分"]);
                                    t04.入出金金額  = ConvertToInt(row["入出金金額"]);
                                    t04.摘要ID   = ConvertToIntNullable(row["摘要ID"]);
                                    t04.摘要名    = ConvertToStringNullable(row["摘要名"]);
                                    t04.手形日付   = ConvertToDateTimeNullable(row["手形日付"]);
                                    t04.入力者ID  = ConvertToIntNullable(row["入力者ID"]);

                                    context.T04_NYUK.ApplyChanges(t04);
                                }
                            }
                            context.SaveChanges();
                            transaction.Commit();
                            break;
                            #endregion
                        }
                        return;
                    }
                }
                catch (Exception ex)
                {
                    throw ex;
                }
            }
        }