🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
Oracle Database

Oracle Databaseは、米オラクルが開発・販売を行うリレーショナルデータベース管理システムです。

Oracle

Oracleは、米オラクルが取り扱うリレーショナルデータベース管理システムです。メインフレームからPCまで、多様なプラットフォームに対応しています。

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

置換

置換とは文字列中の特定の文字に対して、別の文字列に置き換えることを指します。

文字コード

文字コードとは、文字や記号をコンピュータ上で使用するために用いられるバイト表現を指します。

Q&A

解決済

1回答

13068閲覧

データマスキング(先頭1文字目+2文字目以降を"〇"にする)SQLを作成したい(Oracle)

urozero

総合スコア21

Oracle Database

Oracle Databaseは、米オラクルが開発・販売を行うリレーショナルデータベース管理システムです。

Oracle

Oracleは、米オラクルが取り扱うリレーショナルデータベース管理システムです。メインフレームからPCまで、多様なプラットフォームに対応しています。

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

置換

置換とは文字列中の特定の文字に対して、別の文字列に置き換えることを指します。

文字コード

文字コードとは、文字や記号をコンピュータ上で使用するために用いられるバイト表現を指します。

0グッド

0クリップ

投稿2021/01/29 06:53

お世話になっております。

タイトルのようにある列の値を、先頭1文字目 + 2文字目以降"〇" とするupdate文を書きたいです

SQL> select name from a;

―――――――――――――
ああああ
いいいいい
うううううう

―――――――――――――

これを下記のように変更するupdate文が書きたいです

―――――――――――――
あ〇〇〇
い〇〇〇〇
う〇〇〇〇〇

―――――――――――――

以上、よろしくお願いいたします。

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

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

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

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

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

guest

回答1

0

ベストアンサー

substr(), rpad(), length()などを使用して以下の様に出来ます。

SQL

1select rpad(substr('あいうえお',1,1), length('あいうえお') +1,'○') 2from dual

SQL

1update xxx set yyy=rpad(substr(yyy,1,1), length(yyy) +1,'○')

投稿2021/01/29 07:15

編集2021/01/29 07:17
sazi

総合スコア25327

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

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

urozero

2021/01/29 07:19

早々のご回答ありがとうございます! ご丁寧にリンクも張っていただき感謝です。 ありがとうございます!!!
urozero

2021/01/29 07:53

お疲れ様です。 update文を一応確認させてください。 length(yyy) +1 なんですが、リンク先では「文字列の長さ len に満ちるまで」とあるので、+1は不要なように考えたのですが違うでしょうか? (DB環境を変えた影響で、現在SQL文実行して試せないので、ご了承ください)
sazi

2021/01/29 10:14 編集

置き換える元の文字が半角だと良いのですが、全角の場合+1しておかないと正しく充当されませんでした。 その辺は環境に合わせて調整して下さい。
urozero

2021/02/01 00:01

なるほど。承知いたしました!! (全角の予定です) ありがとうございます!!!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問