開発者向け機能:サーバスクリプト:saved
## 概要
「[サーバスクリプト](/manual/table-management-server-script)」で使用可能な更新前の「レコード」の情報をもつオブジェクトです。プロパティを使用し「[項目](/manual/table-management-column)」の値の読み取りが行えます。
## 制限事項
1. 「更新前」の条件で意味を持ちます。その他の条件では、参照できても model と同等となります。
1. 「[添付ファイル項目](/manual/table-management-attachments)」「[コメント項目](/manual/table-management-comments)」は使用できません。
1. 「[項目のアクセス制御](/manual/table-management-column-access-control)」で「読み取り権限」の無い「[項目](/manual/table-management-column)」は取得できません。
1. 「[項目のアクセス制御](/manual/table-management-column-access-control)」で「更新権限」の無い「[項目](/manual/table-management-column)」は値を代入しても画面の表示を変更できません。
1. 画面上に存在しない「[項目](/manual/table-management-column)」は取得できません。画面上にない「[項目](/manual/table-management-column)」を取得するには「AlwaysGetColumnsオブジェクト」を使用してください。
## プロパティ
|No|プロパティ名|type|説明|
|:----|:----|:----|:----|
|1|IssueId / ResultId|long|「[ID項目](/manual/table-management-id)」|
|2|SiteId|long|「サイトID項目」|
|3|Creator|int|「[作成者項目](/manual/table-management-creator)」|
|4|CreatedTime|DateTime|「[作成日時項目](/manual/table-management-created-time)」|
|5|Updator|int|「[更新者項目](/manual/table-management-updator)」|
|6|UpdatedTime|DateTime|「[更新日時項目](/manual/table-management-updated-time)」|
|7|Ver|int|「[バージョン項目](/manual/table-management-ver)」|
|8|Title|string|「[タイトル項目](/manual/table-management-title)」|
|9|Body|string|「[内容項目](/manual/table-management-body)」|
|10|StartTime|DateTime|「[開始項目](/manual/table-management-start-time)」|
|11|CompletionTime|DateTime|「[完了項目](/manual/table-management-completion-time)」|
|12|WorkValue|decimal|「[作業量項目](/manual/table-management-work-value)」|
|13|ProgressRate|decimal|「[進捗率項目](/manual/table-management-progress-rate)」|
|14|RemainingWorkValue|decimal|「[残作業量項目](/manual/table-management-remaining-work-value)」|
|15|Status|int|「[状況項目](/manual/table-management-status)」|
|16|Manager|int|「[管理者項目](/manual/table-management-manager)」|
|17|Owner|int|「[担当者項目](/manual/table-management-owner)」|
|18|Locked|bool|「[ロック項目](/manual/table-management-lock)」|
|19|ClassA~|string|「[分類項目](/manual/table-management-class)」|
|20|NumA~|decimal|「[数値項目](/manual/table-management-num)」|
|21|DateA~|DateTime|「[日付項目](/manual/table-management-date)」|
|22|DescriptionA~|string|「[説明項目](/manual/table-management-description)」|
|23|CheckA~|bool|「[チェック項目](/manual/table-management-check)」|
## メソッド
メソッドはありません。
## 使用例
「更新前」であっても model には、画面や CSV から送信されたデータで変更された値(これからデータベースに保持される値)が保持されています。
このため、model.Status が何であるかを判定するサーバスクリプトでは、ある状態に変更されたときだけ動作させたい処理を実現することが難しいです。
下記の例では「[状況項目](/manual/table-management-status)」が変化したかを saved を使って判定しています。
##### JavaScript(サーバスクリプト)
```
const prevStatus = saved.Status;
const currentStatus = model.Status;
if(prevStatus !== currentStatus) {
context.Log(`Status just has been changed.`);
}
```
同様にして、特定のデータ項目の変更前後の監視を実現することができます。
また、更新後に同様の判定を行いたい場合には 「[context.UserData](/manual/server-script-context-user-data)」 に変更があったことを検知する共有変数を保持することで実現できる可能性があります。
ステータスに対して羃等(idempotent)な処理については、このような対応をする必要はありません。
## 関連情報
<div id="ManualList"><ul><li><a href="/manual/table-management-column">テーブルの管理:項目</a><span>2023/06/13 up</span></li>
<li><a href="/manual/table-management-id">テーブルの管理:項目:ID</a><span>2023/04/19 up</span></li>
<li><a href="/manual/table-management-ver">テーブルの管理:項目:バージョン</a><span>2023/04/19 up</span></li>
<li><a href="/manual/table-management-title">テーブルの管理:項目:タイトル</a><span>2023/04/19 up</span></li>
<li><a href="/manual/table-management-body">テーブルの管理:項目:内容</a><span>2023/04/21 up</span></li>
<li><a href="/manual/table-management-start-time">テーブルの管理:項目:開始</a><span>2023/04/21 up</span></li>
<li><a href="/manual/table-management-completion-time">テーブルの管理:項目:完了</a><span>2023/04/21 up</span></li>
<li><a href="/manual/table-management-work-value">テーブルの管理:項目:作業量</a><span>2023/04/21 up</span></li>
<li><a href="/manual/table-management-progress-rate">テーブルの管理:項目:進捗率</a><span>2023/04/21 up</span></li>
<li><a href="/manual/table-management-remaining-work-value">テーブルの管理:項目:残作業量</a><span>2023/04/21 up</span></li>
<li><a href="/manual/table-management-status">テーブルの管理:項目:状況</a><span>2023/06/13 up</span></li>
<li><a href="/manual/table-management-manager">テーブルの管理:項目:管理者</a><span>2023/04/21 up</span></li>
<li><a href="/manual/table-management-owner">テーブルの管理:項目:担当者</a><span>2023/04/21 up</span></li>
<li><a href="/manual/table-management-lock">テーブルの管理:項目:ロック</a><span>2023/04/21 up</span></li>
<li><a href="/manual/table-management-class">テーブルの管理:項目:分類</a><span>2023/04/21 up</span></li>
<li><a href="/manual/table-management-num">テーブルの管理:項目:数値</a><span>2023/04/21 up</span></li>
<li><a href="/manual/table-management-date">テーブルの管理:項目:日付</a><span>2023/04/21 up</span></li>
<li><a href="/manual/table-management-description">テーブルの管理:項目:説明</a><span>2023/04/21 up</span></li>
<li><a href="/manual/table-management-check">テーブルの管理:項目:チェック</a><span>2023/04/21 up</span></li>
<li><a href="/manual/table-management-attachments">テーブルの管理:項目:添付ファイル</a><span>2023/04/07 up</span></li>
<li><a href="/manual/table-management-comments">テーブルの管理:項目:コメント</a><span>2023/04/21 up</span></li>
<li><a href="/manual/table-management-creator">テーブルの管理:項目:作成者</a><span>2023/04/21 up</span></li>
<li><a href="/manual/table-management-updator">テーブルの管理:項目:更新者</a><span>2023/04/21 up</span></li>
<li><a href="/manual/table-management-created-time">テーブルの管理:項目:作成日時</a><span>2023/04/21 up</span></li>
<li><a href="/manual/table-management-updated-time">テーブルの管理:項目:更新日時</a><span>2023/04/21 up</span></li></ul></article>
<ul><li><a href="/manual/table-management-column-access-control">テーブルの管理:アクセス制御:項目のアクセス制御</a><span>2023/05/18 up</span></li></ul></article>
<ul><li><a href="/manual/table-management-server-script">テーブルの管理:サーバスクリプト</a><span>2023/05/18 up</span></li></ul></article>
<ul><li><a href="/manual/dev-column-name">項目名とデータベース上のカラム名の対応</a><span>2024/03/05 up</span></li></ul></article>
<ul><li><a href="/manual/server-script">開発者向け機能:サーバスクリプト</a><span>2023/06/01 up</span></li>
<li><a href="/manual/server-script-context-user-data">開発者向け機能:サーバスクリプト:context.UserData</a><span>2023/06/21 up</span></li></ul></article>
<ul><li><a href="/manual/faq-server-script-log">FAQ:サーバスクリプトのエラーログを出力する</a><span>2023/01/05 up</span></li></ul></article></div><input id="SearchTextHidden" type="hidden" value="" />