2016-08-10 21 views
0

SQL Serverにデータベースのコピーを作成する必要があります。このように は私がADOXSQL Serverで列のプロパティを設定する方法

ADOX.Catalog cat, Dictionary<string, ADOX.DataTypeEnum> columntype) 
    { 
     List<string> primaryKeysList = GetPrimaryKey(tabelle); 
     Key priKey = new Key(); 

     Catalog catIn = new Catalog(); 
     catIn.ActiveConnection = dbInfo.ConIn; 
     Dictionary<string, List<string>> indexinfo = new Dictionary<string, List<string>>(); 
     GetSecondaryIndex(tabelle, indexinfo); 
     if (columntype.Count != 0) columntype.Clear(); 

     if (size.Count != 0) size.Clear(); 

     foreach (DataRow myField in schemaTable.Rows) 
     { 
      String columnNameValue = myField[columnName].ToString(); //SpaltenName 
      bool ich_darf_dbnull_sein = (bool)myField["AllowDBNull"]; 


      ADOX.Column columne = new ADOX.Column(); 
      columne.ParentCatalog = cat; 
      columne.Name = columnNameValue; 

      if (!columntype.ContainsKey(columnNameValue)) 
      { 
       columntype.Add(columnNameValue, (ADOX.DataTypeEnum)myField["ProviderType"]); 
      } 
      columne.Type = (ADOX.DataTypeEnum)myField["ProviderType"]; 
      //type.Add((ADODB.DataTypeEnum)myField["ProviderType"]); 
      columne.DefinedSize = (int)myField["ColumnSize"]; 
      dbInfo.ColumnName = columnNameValue; 
      dbInfo.TableName = tabelle; 

      dbInfo.Column_size = (int)myField["ColumnSize"]; 
      dbInfo.Column_Type = (ADOX.DataTypeEnum)myField["ProviderType"]; 
      size.Add((int)myField["ColumnSize"]); 
      if (primaryKeysList.Contains(columnNameValue)) 
      { 
       dbInfo.IsPrimary = true; 
      } 
      else dbInfo.IsPrimary = false; 

      object index = catIn.Tables[tabelle].Columns[columnNameValue].Attributes; 
      if (index.Equals(ColumnAttributesEnum.adColFixed) || (int)index == 3) 
       dbInfo.Fixed_length = true; 
      else 
       dbInfo.Fixed_length = false; 

      Console.WriteLine("{0}={1}", myField[columnName].ToString(), catIn.Tables[tabelle].Columns[columnNameValue].Attributes); 

       TargetDBMS.SetColumnProperties(columne, dbInfo); 



      switch (columne.Type) 
      { 
       case ADOX.DataTypeEnum.adChar: 
       case ADOX.DataTypeEnum.adWChar: 
       case ADOX.DataTypeEnum.adVarChar: 
       case ADOX.DataTypeEnum.adVarWChar: 
        columne.DefinedSize = (int)myField["ColumnSize"]; 
        break; 
       default: 
        break; 
      } 
      if (primaryKeysList.Contains(columnNameValue)) 
      { 
       priKey.Name = "PK_" + tabelle + "_" + columnNameValue; 
       primaryKeysList.Remove(columnNameValue); 
       priKey.Columns.Append(myField[columnName], (ADOX.DataTypeEnum)myField["ProviderType"], (int)myField["ColumnSize"]); 

      } 
      columnNameList.Add(columnNameValue); 

      table.Columns.Append(columne); 
     } 
     table.Keys.Append((object)priKey, KeyTypeEnum.adKeyPrimary); 
    } 

を持つテーブルを作成して新しいDB

ADODB.Connection connection = new ADODB.Connection(); 

     OleDbConnectionStringBuilder builder = new System.Data.OleDb.OleDbConnectionStringBuilder(); 
     builder["Provider"] = provider; 
     builder["Server"] = @"Themis\DEV"; 
     builder["Database"] = file_name; 
     builder["Integrated Security"] = "SSPI"; 
     string connection_string = builder.ConnectionString; 
     connection.Open(connection_string, null, null, 0); 

     return connection; 
    } 

への接続を得た。しかし、私は列のプロパティを設定するとき、私は例外だ

internal override void SetColumnProperties(ADOX.Column columne, DbInfo dbInfo) 
    { 
     GetColumnProperties(dbInfo); 
       columne.Properties["Autoincrement"].Value = dbInfo.Field_prop["Autoincrement"]; 
       columne.Properties["Default"].Value = dbInfo.Field_prop["Default"]; 
       columne.Properties["Nullable"].Value = dbInfo.Field_prop["Nullable"]; 
    } 

私のプログラムはAccess DBでうまく動作しますが、SQL Server上のDBには設定できません

例外(0x80040E21)複数ステップのOLE DB操作でエラーが発生しました。可能であれば、各OLE DBのステータス値を確認します。仕事は一切行われなかった。

私はそれがDBのプロパティを変更しません

string query = "SELECT * FROM Forms"; 
DataTable dt = new DataTable(); 
      using (SqlConnection sqlConn = Connection()) 
      using (SqlCommand cmd = new SqlCommand(query, sqlConn)) 
     { 
      sqlConn.Open(); 

      dt.Load(cmd.ExecuteReader()); 

     } 


     foreach (DataColumn col in dt.Columns) 
     { 
      Console.WriteLine(col.ColumnName); 
      col.AllowDBNull = true; 
      dt.AcceptChanges(); 
      col.AutoIncrement = false; 
      dt.AcceptChanges(); 


     } 

この方法を試してみた場合

dbInfo.Autoincrementだったので問題は部分的に
columne.Properties["Autoincrement"].Value = (bool)dbInfo.Autoincrement; 

を解決している

答えて

0

オブジェクトを書く必要があります(bool)dbInfo.Autoincrement

値DEFAULT_VALUEのタイプは0にすることができるので、解決されていない

この

columne.Properties["Default"].Value = (string)dbInfo.Default_Value; 

である、(「」)または「空 - 」...私はこのケースで何ができるか分からない

関連する問題