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も見ています
-
新NISA制度は今までと何が変わる?非課税枠の拡大や投資対象の変更などを解説!
少額から投資を行う人のための非課税制度であるNISAが、2024年に改正される。おすすめの銘柄や投資額の目安について教えてもらった。
-
エラーを起こす方法
Oracle
-
PL/SQLカーソルの2重FORループができません
Oracle
-
VBでグローバル変数を宣言するには
Visual Basic(VBA)
-
-
4
アクセスからエクセルのシートを追加して、名前をつける方法
Excel(エクセル)
-
5
SQLサーバーのテーブルの値が更新できません
SQL Server
-
6
メッセージボックスのボタン名変更
Visual Basic(VBA)
-
7
access テーブル内のレコードの編集を不可に。
その他(データベース)
-
8
「RunSQL」と「Execute」の違い
Access(アクセス)
-
9
html でのテキスト結合について
その他(プログラミング・Web制作)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
accessテーブル作成クエリを実...
-
エクセルでテーブルの最終行が...
-
クエリのキャンセルがいつにな...
-
Accessにインポートした複数の...
-
テーブル作成クエリで新テーブ...
-
SQLスクリプトを自動生成する方法
-
レプリケーションしているテー...
-
SQL Serverのテーブル追加を、A...
-
SQLサーバーのテーブルの値...
-
SI Object Browserのテーブルス...
-
位置を指定してフィールドを追...
-
Access のリレーションシップで...
-
列サイズ変更時、DB停止は必要?
-
「マスタ」と「テーブル」の違...
-
ACCESSのSQLで、NULLかNULLでな...
-
SELECT時の行ロックの必要性に...
-
sqlserverで集計結果をUPDATEし...
-
2つの項目が重複するレコード...
-
数百万件レコードのdelete
-
ACCESS2007 フォーム 「バリア...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
accessテーブル作成クエリを実...
-
クエリのキャンセルがいつにな...
-
SI Object Browserのテーブルス...
-
エクセルでテーブルの最終行が...
-
UNIONなどで複数のテーブルから...
-
Accessにインポートした複数の...
-
ストアドをまたがるローカル一...
-
SQLについて質問です。 テーブ...
-
ユニオンクエリの結果をテーブ...
-
あるテーブルのデータを追加、...
-
SQLサーバーのテーブルの値...
-
位置を指定してフィールドを追...
-
レプリケーションしているテー...
-
コンボボックスで入力したもの...
-
AccessVBAで降順にするテーブル...
-
重複するレコードに対しフラグ...
-
列サイズ変更時、DB停止は必要?
-
SQLスクリプトを自動生成する方法
-
Access のリレーションシップで...
-
VIEWしか読み取れないユーザの...
おすすめ情報