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

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

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

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

SQL Server

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

.NET Framework

.NET Framework は、Microsoft Windowsのオペレーティングシステムのために開発されたソフトウェア開発環境/実行環境です。多くのプログラミング言語をサポートしています。

Q&A

解決済

2回答

2074閲覧

ユーザー定義型の値を、任意の書式でManagementStudio(SSMS)の結果セットに表示させたい

hsk

総合スコア728

C#

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

SQL Server

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

.NET Framework

.NET Framework は、Microsoft Windowsのオペレーティングシステムのために開発されたソフトウェア開発環境/実行環境です。多くのプログラミング言語をサポートしています。

0グッド

1クリップ

投稿2018/01/18 02:24

編集2018/01/18 02:28

こんにちは。よろしくお願いします。

###前提・実現したいこと
SQL Server 2014 へ、SQL CLR のユーザー定義型 (UDT) を作成しています。

###発生している問題・エラーメッセージ
SQL Server Management Studio の(クエリーの)結果セット表示で文字列表示をさせたいのですが、バイナリ形式で表現されてしまいます(ToStringメソッドを実装していても、中身がバイナリ表現になってしまうようです。Parse と ToString の各メソッドは型変換用?)
結果セットの値に、(VARCHAR 型などへ明示的に変換しなくても)ソースコード上の _string メンバーの中身を文字列そのものの表現で表示させたいです(試した画像を添付しました。1つめのクエリー(SELECT文)で、2つめの結果セットのように表示させたいです)
実現方法をご存知の方、ご教示いただけますと幸いです。

イメージ説明
###該当のソースコード

C#

1using System; 2using System.Data; 3using System.Data.SqlClient; 4using System.Data.SqlTypes; 5using Microsoft.SqlServer.Server; 6 7[Serializable] 8[Microsoft.SqlServer.Server.SqlUserDefinedType(Format.UserDefined, IsByteOrdered = true, IsFixedLength = false, MaxByteSize = -1)] 9public struct StringEx: INullable, IBinarySerialize 10{ 11 public override string ToString() 12 { 13 return _string; 14 } 15 16 public bool IsNull 17 { 18 get 19 { 20 return _null; 21 } 22 } 23 24 public static StringEx Null 25 { 26 get 27 { 28 StringEx h = new StringEx(); 29 h._null = true; 30 return h; 31 } 32 } 33 34 public static StringEx Parse(SqlString s) 35 { 36 if (s.IsNull) 37 return Null; 38 StringEx u = new StringEx(); 39 u._string = s.Value; 40 return u; 41 } 42 43 // SAMPLE 44 public bool IsNumeric() 45 { 46 decimal dmy; 47 return decimal.TryParse(_string, out dmy); 48 } 49 50 private bool _null; 51 private string _string; 52 53 public void Read(System.IO.BinaryReader r) 54 { 55 _null = r.ReadBoolean(); 56 if (!_null) 57 _string = r.ReadString(); 58 } 59 60 public void Write(System.IO.BinaryWriter w) 61 { 62 w.Write(_null); 63 if (!_null) 64 w.Write(_string); 65 } 66}

###補足情報(言語/FW/ツール等のバージョンなど)

  • Windows Server 2008 R2 SP1
  • Visual Studio 2013 Professional Update 5
  • SQL Server 2014 Express Edition SP2

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

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

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

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

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

guest

回答2

0

ベストアンサー

原則として、ユーザー定義型のインスタンスはバイナリ評価です。
CAST(COL AS VERCHAR) → COL.ToString()
又は、
StringEx に string を返すプロパティを実装してSQLでそれを呼ぶなど、型を明確にする必要があります。

投稿2018/01/18 04:27

hihijiji

総合スコア4150

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

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

hsk

2018/01/18 05:52 編集

> 原則として、ユーザー定義型のインスタンスはバイナリ評価です。 ありがとうございます。残念ですが、明示的に変換したり、メソッドを設けたりしなけねばならないのですね。。 SSMSから「上位1000行の選択」メニューから結果セットの値を、任意の書式でさくっと表示させる手段が欲しかったのです(本来の列位置で) .NET の DebuggerDisplayAttribute(VisualStudio のデバッグ時のウォッチ書式指定)のようなことをSSMS に連携適用させる機能があればよかったですが、それは贅沢というものですかね...
guest

0

TESTのテーブルでcast(col as varchar())した計算列を設けてはダメなのですか?

sql

1ALTER TABLE dbo.TEST ADD 2 col_v AS cast(col as varchar(max))

投稿2018/01/18 02:42

編集2018/01/18 02:42
sousuke

総合スコア3828

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

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

hsk

2018/01/18 05:39

すみません、ダメなんです...
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問