私の問題は、SQL Server データベースを使用することです。
次のコードを使用して、C# から SQL Server テーブルにデータを正常に格納しました。
internal static void SaveAutocadFileOnDataBase(string MapCode, byte[] dataElecMap, string dataElecMapName,byte[] dataCivilMap, string dataCivilMapName, byte[] dataArchiMap, string dataArchiMapName,byte[]dataMechaMap,string dataMechaMapName)
{
string sqlcommand = string.Concat("INSERT INTO AutoCadFiles VALUES ('", MapCode, "' , ", "cast ('", dataElecMap, "' as varbinary(max)),", " '", dataElecMapName, "' ", " , cast ('", dataCivilMap, "' as varbinary(max)) ,", " '", dataCivilMapName, "' ", " , cast ('", dataArchiMap, "' as varbinary(max)) ,", " '", dataArchiMapName, "' "," , cast ('", dataMechaMap, "' as varbinary(max)) ,", " '", dataMechaMapName, "' ", ")"); ExecuteNonQuery(sqlcommand);
}
このコードでそれを取得します。
internal static DataTable RetriveMaps(string MapNumber, string MapType)
{
string s = MapType + "Name";
string SqlCommand = string.Concat("SELECT ", MapType, " , ", s, " FROM AutoCadFiles WHERE MapCode='",MapNumber, "'");
return GetBinaryFiles(SqlCommand);
}
private static DataTable GetBinaryFiles(string SqlCommand)
{
SqlConnection SqlConnction = null;
DataTable dt = new DataTable();
SqlCommand sqlcom = GetConnection(SqlCommand, ref SqlConnction);
SqlDataReader sdldr = sqlcom.ExecuteReader();
dt.Load(sdldr);
return dt;
}
dataTable からファイルを正常に取得し、ファイルシステムに保存しました。しかし、保存されたファイルのボリュームは0バイトです
または、データベースに保存されているファイルよりも 13 バイト少ない。