質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

SQL Server

SQL Serverはマイクロソフトのリレーショナルデータベース管理システムです。データマイニングや多次元解析など、ビジネスインテリジェンスのための機能が備わっています。

LINQ to SQL

LINQ to SQLは.NET Framework 3.5のコンポーネントで、リレーショナル データをオブジェクトとして管理するためのランタイム インフラストラクチャを提供します。

LINQ

LINQとはLanguage INtegrated Queryの略で、「統合言語クエリ」という意味です。C#やVisual Basicといった言語のコード内に記述することができるクエリです。

Q&A

解決済

1回答

21946閲覧

SQLサーバにクエリ式でデータを挿入すると日本語が文字化けする

makiikeda1216

総合スコア128

C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

SQL Server

SQL Serverはマイクロソフトのリレーショナルデータベース管理システムです。データマイニングや多次元解析など、ビジネスインテリジェンスのための機能が備わっています。

LINQ to SQL

LINQ to SQLは.NET Framework 3.5のコンポーネントで、リレーショナル データをオブジェクトとして管理するためのランタイム インフラストラクチャを提供します。

LINQ

LINQとはLanguage INtegrated Queryの略で、「統合言語クエリ」という意味です。C#やVisual Basicといった言語のコード内に記述することができるクエリです。

0グッド

3クリップ

投稿2014/08/18 08:33

下記サイトで現在LINQ to SQL を勉強中なのですがクエリ式でSQL Serverにレコードを挿入すると日本語が文字化けしてしまいます。Entity Frameworkはいろいろ理由があり使えません。

http://ufcpp.net/study/csharp/sp3_linqtosql.html

いろいろ調べてみるとデータ型をvarcharにしていたのでnvarcharに直したのですが文字化けがもどりませんでした。こちらのソースコードのエンコードはUnicode(UTF-8 シグネチャ付き)です。
クエリ式なのでNプレフィックスもつけれないようなので困っています。

どなたかご教授ください。

下記がコードです。テーブルやmdbファイルなどは上記サイトに書かれているとおりに
作りました。Authorテーブルを使用しています。コードでわからないところがあれば
気軽に質問してください。

lang

1string _connectionString = ConfigurationManager.ConnectionStrings["LinqToSqlTest.Properties.Settings.ComicDatabaseConnectionString"].ConnectionString; 2 3var db = new ComicDataContext(_connectionString); 4Author a = new Author(); 5a.Name = "N'赤松健'"; 6db.Author.InsertOnSubmit(a); 7db.SubmitChanges(); 8 9Console.ReadLine();

Author デザインテーブルが以下になります。
![イメージ説明]WIDTH:470


08/19 お騒がせしました。解決方法です。


すいません。
自己解決できました。
みなさまお騒がせしました。

原因:
はっきりとは分からなかったのですが。どうやら
①最初にvarcharでデータの型を宣言→自動マッピングされる
②そのあとデータの型をvarcharからnvarcharに直した→マッピングしなおされたはず
(でも両方ともstring型でマッピングされている

の部分だったようです。

解決方法:
データーベースを削除して、新しく作り直し初めからnvarcharに設定する。
で解決できました。

作り直した際に、実行ファイルのデータベース側のファイルアイコンが@
に変化しました。

これも何か関係があるのかも。(8/20関係ありませんでした。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

DBのデータをnvarchar等n付きにして、
a.Name = "赤松健";のように普通に書けばいけるはずですが。
(一応コンパイルしなおしてください)
参考:文字列Mapping

投稿2014/08/19 01:13

bonchan

総合スコア204

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

makiikeda1216

2014/08/19 02:24

bonchan さん 返信ありがとうございます。 >>DBのデータをnvarchar等n付きにして、 DBのデータはnvarcharにしてコンパイル、更新を行って確認しましたがやはり文字化けしてしまいます。 >>a.Name = "赤松健";のように普通に書けばいけるはずですが。 いろいろためしていたので a.Name = "N'赤松健'"; のままでした a.Name = "赤松健";でもやはり”???”になってしまいました。 OTL
makiikeda1216

2014/08/19 04:38

すいません。 自己解決できました。 みなさまお騒がせしました。 原因:  はっきりとは分からなかったのですが。   ①どうやら最初にvarcharでデータの型を宣言   ②そのあとデータの型をvarcharからnvarcharに直した  の部分だったようです。 解決方法:  データーベースを削除して、新しく作り直し初めからnvarcharに設定する。  で解決できました。 作り直した際に、実行ファイルのデータベース側のファイルアイコンが@ に変化しました。 これも何か関係があるのかも。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問