No.2ベストアンサー
- 回答日時:
#1です。
ユーザ名がdboって、要はsaアカウントに対して制限を掛けようとしているということですか?
基本的にsysadminを持っている人は「何でもできる人」ですから、発想的に無理がありますよ。その点は認識してください。
(方法1)
SQL Serverはテーブル単位に読み取り専用にする機能がありませんので、
・ファイルグループを新設し(SECONDARYなど)、そこにデータファイルを追加します。
・新設したファイルグループに、対象テーブルを新規に作成し、そこにデータを移します。
(テーブル自体を「移動」することはできないと思います)
・新設したファイルグループを読み取り専用にします。
基本的には全部GUIでできます。
上記の通り、テーブルの再作成ができることが条件で、これをやるとファイルグループの属性を変更しない限り、「例外なく」誰も更新できません。ただ、sysadmin権限を持っている人がファイルグループの属性を変更しようとしても、阻止できません。
(方法2)
条件付きですし、ちょっと姑息なのでおまけです。
INSTEAD OFトリガは、更新処理自体は行わないため、トリガ内で更新処理を書かないと何もしません。
(RAISERRORも書かなければ、実行したときにあたかもうまくいったように見えます)
CREATE TRIGGER tr_(テーブル名)
ON dbo.(テーブル名)
INSTEAD OF INSERT,UPDATE,DELETE
AS
BEGIN
SET NOCOUNT ON
RAISERROR('Insert/Update/Delete is not allowed',16,1)
END
ただし、この方法は制限を掛けたいユーザがトリガをオフにする方法を知っているとアウトです。
ユーザがトリガをオフにする方法を知っている場合は、それを阻止する方法はありません。
丁寧に教えていただきありがとうございます。
今までこのようなことを想定せずにSQLServer+アクセスプロジェクトで小規模システムを作ってきましたが、大変参考になりました。
次のシステムを作る時に参考にしたいと思います。
ありがとうございます
No.3
- 回答日時:
No.1
- 回答日時:
対象のユーザがsysadmin権限を持っていないことが条件です。
DENY INSERT,UPDATE,DELETE ON (テーブル名) TO (ユーザ名)
この回答への補足
早速のご教授ありがとうございます。
ご教授いただいた記述をユーザー名であるdboに対して実行しましたが、
反映されませんでした。
おそらくご指摘のようにdboにはsysadmin権限があるせいだと思います。
当方のシステムのユーザーはdboしかなく、新たにユーザーを作るのはかなり大変のように思います。
そこでお尋ねしたいのですが、ユーザーがdboであってもデータの追加、変更、削除ができないようにする方法はないのでしょうか
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Ruby pandasでsqlite3にテーブル作成・追加・読み出しでindexの取り扱い方教えてください 5 2023/03/08 09:57
- その他(Microsoft Office) エクセルでテーブルの最終行が自動追加されない 1 2023/01/04 15:09
- JavaScript javascriptでテーブルに追加した項目のid追加してローカルストレージを操作したい 5 2023/01/01 15:52
- その他(データベース) c言語の問題です。これを踏まえてコーディングしたいのでおしえていただきたいです。 3 2023/08/03 09:27
- Access(アクセス) Access DAOのExecuteメソッドのオプション(RecordsetOptionEnum)に 1 2022/09/19 07:34
- Access(アクセス) Access 登録ボタンからサブフォームの更新 1 2022/07/22 10:23
- Access(アクセス) access,vbaでフォルダ内のファイルをテーブルにインポート、ファイル名もフィールドに追加したい 1 2022/08/31 11:11
- Excel(エクセル) Excel ドロップダウンリスト(入力規則)に関してです データの入力規則で元データ79000行のド 3 2023/07/17 10:06
- Access(アクセス) accessについて(超初心者です) 1 2023/02/11 11:18
- その他(データベース) pythonでsqlight勉強中、クエリー結果の利用法教えて下さい 1 2022/04/28 20:38
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
accessテーブル作成クエリを実...
-
UNIONなどで複数のテーブルから...
-
SI Object Browserのテーブルス...
-
テーブル作成クエリで新テーブ...
-
DBのCreate文スクリプト作成に...
-
Accessにインポートした複数の...
-
レプリケーションしているテー...
-
ユニオンクエリの結果をテーブ...
-
位置を指定してフィールドを追...
-
Access のリレーションシップで...
-
SQLサーバーのテーブルの値...
-
PL/SQLでFROM句に変数を使いたい
-
ロータスアプローチ2001とACCES...
-
クエリのキャンセルがいつにな...
-
「マスタ」と「テーブル」の違...
-
2つのテーブルから条件に一致...
-
SELECT時の行ロックの必要性に...
-
データの二重表示の原因
-
重複するキーから一番古い年月...
-
[ BETWEEN ] vs [ >= AND <= ]
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
エクセルでテーブルの最終行が...
-
accessテーブル作成クエリを実...
-
クエリのキャンセルがいつにな...
-
ユニオンクエリの結果をテーブ...
-
SI Object Browserのテーブルス...
-
UNIONなどで複数のテーブルから...
-
あるテーブルのデータを追加、...
-
ストアドをまたがるローカル一...
-
Accessにインポートした複数の...
-
コンボボックスで入力したもの...
-
列サイズ変更時、DB停止は必要?
-
SQLサーバーのテーブルの値...
-
Access のリレーションシップで...
-
レプリケーションしているテー...
-
位置を指定してフィールドを追...
-
SQLスクリプトを自動生成する方法
-
テーブル作成クエリで新テーブ...
-
ADOでSeekメッソッドが使えませ...
-
excel テーブル
-
VIEWしか読み取れないユーザの...
おすすめ情報