「Tep3-onk-2」を編集中

移動先: 案内検索

警告: ログインしていません。編集を行うと、あなたの IP アドレスが公開されます。ログインまたはアカウントを作成すれば、あなたの編集はその利用者名とともに表示されるほか、その他の利点もあります。

この編集を取り消せます。 下記の差分を確認して、本当に取り消していいか検証してください。よろしければ変更を保存して取り消しを完了してください。
最新版 編集中の文章
1行目: 1行目:
 
[[category:memo|{{PAGENAME}}]]
 
[[category:memo|{{PAGENAME}}]]
 
{{Font color}}
 
{{Font color}}
== tep5 準備 ==
+
== 準備 ==
 
プロジェクトディレクトリ作成 移動 [[rails前バージョン確認|バージョン確認]]
 
プロジェクトディレクトリ作成 移動 [[rails前バージョン確認|バージョン確認]]
  
 
== new ==
 
== new ==
  % rails new . -d postgresql --css tailwind または bootstrap
+
  % rails new . -d postgresql --css tailwind
 
  % bundle install
 
  % bundle install
 
  % rails db:create
 
  % rails db:create
12行目: 12行目:
 
  % rails db:migrate
 
  % rails db:migrate
 
  % rails server
 
  % rails server
 
bootstrapのとき
 
<nowiki>
 
package.json
 
 
{
 
  "name": "app",
 
  "private": "true",
 
  "dependencies": {
 
    "@hotwired/stimulus": "^3.0.1",
 
    "@hotwired/turbo-rails": "^7.1.0",
 
    "@popperjs/core": "^2.11.0",
 
    "bootstrap": "^5.1.3",
 
    "esbuild": "^0.14.9",
 
    "sass": "^1.45.1"
 
  },
 
  "scripts": {
 
    "build": "esbuild app/javascript/*.* --bundle --sourcemap --outdir=app/assets/builds",
 
    "build:css": "sass ./app/assets/stylesheets/application.bootstrap.scss ./app/assets/builds/application.css --no-source-map --load-path=node_modules"
 
  }
 
}</nowiki>
 
  
 
=== daisyui ===
 
=== daisyui ===
56行目: 35行目:
 
  $ createdb mydb
 
  $ createdb mydb
 
  $ pg_restore --verbose --clean --no-acl --no-owner -h localhost -U myuser -d mydb latest.dump
 
  $ pg_restore --verbose --clean --no-acl --no-owner -h localhost -U myuser -d mydb latest.dump
 
=== postgres dump restore ===
 
% pg_dump -Fc tep5_development > ../202212141027.dump
 
% pg_restore --verbose --clean --no-acl --no-owner -h localhost -U jq -d tep5_development  ../202212141027.dump
 
  
 
=== 作り直すアプリはデータベース構造を変えるのでテーブルごとにダンプ・リストアする ===
 
=== 作り直すアプリはデータベース構造を変えるのでテーブルごとにダンプ・リストアする ===
177行目: 152行目:
  
 
=== clientsテーブル othersテーブル ===
 
=== clientsテーブル othersテーブル ===
+
  % pg_dump --username=jq --table clients_old heroku_dump > clients_old.sql
==== 2022-12 -14 clientsテーブル ====
 
latest_dumpデータベースからダンプして 作業データベースにリストアする
 
% pg_dump -t clients latest_dump > ../client_dump.sql
 
 
 
<nowiki>% psql -d update_dump < ../client_dump.sql
 
SET
 
SET
 
SET
 
SET
 
SET
 
set_config
 
------------
 
 
(1 row)
 
 
 
SET
 
SET
 
SET
 
SET
 
SET
 
SET
 
CREATE TABLE
 
ALTER TABLE
 
CREATE SEQUENCE
 
ALTER TABLE
 
ALTER SEQUENCE
 
ALTER TABLE
 
COPY 5138
 
setval
 
--------
 
  5428
 
(1 row)
 
 
 
ALTER TABLE
 
CREATE INDEX
 
CREATE INDEX
 
CREATE INDEX
 
CREATE INDEX
 
ERROR:  relation "public.users" does not exist
 
ERROR:  relation "public.jiins" does not exist</nowiki>
 
 
 
重複確認
 
<nowiki>=# SELECT ie_id, COUNT(ie_id)
 
FROM clients
 
where nusi = true GROUP BY ie_id
 
HAVING COUNT(ie_id) > 1
 
ORDER BY ie_id;
 
ie_id | count
 
-------+-------
 
  2090 |    2
 
  2129 |    2
 
  2167 |    2
 
  2174 |    2
 
.
 
.
 
.
 
(131 rows)</nowiki>
 
 
 
桁数を変えて重複を解消する
 
<nowiki>update_dump=# update clients SET ie_id = ie_id + 20000 where jiin_id = 2;
 
UPDATE 777
 
update_dump=# update clients SET ie_id = ie_id + 30000 where jiin_id = 3;
 
UPDATE 826
 
update_dump=# update clients SET ie_id = ie_id + 40000 where jiin_id = 4;
 
UPDATE 334</nowiki>
 
 
 
主重複解消
 
<nowiki>update_dump=# update clients set nusi = false where id = 3703;
 
UPDATE 1
 
update_dump=# update clients set nusi = false where id = 1346;
 
UPDATE 1</nowiki>
 
 
 
不要データ削除 修正
 
<nowiki>update_dump=# delete from clients where id in (4028,3911,3912,2998,3007,4359);
 
DELETE 0</nowiki>
 
<nowiki>update_dump=# update clients set nusi = true where id = 523;
 
UPDATE 1
 
update_dump=# delete from clients where id = 845;
 
DELETE 1
 
update_dump=# update clients set ie_id = 1264 where id = 515;
 
UPDATE 1
 
update_dump=# update clients set ie_id = 1264 where id = 1463;
 
UPDATE 1
 
update_dump=# update clients set nusi = false where id = 515;
 
UPDATE 1
 
update_dump=# delete from clients where id = 217;
 
DELETE 1
 
update_dump=# update clients set nusi = false where id = 218;
 
UPDATE 1
 
update_dump=# update clients set ie_id = 204 where id = 218;
 
UPDATE 1
 
update_dump=# delete from clients where id = 811;
 
DELETE 1
 
update_dump=# update clients set nusi = true where id = 1792;
 
UPDATE 1
 
update_dump=# delete from clients where id = 810;
 
DELETE 1
 
update_dump=# delete from clients where ie_id = 22653;
 
DELETE 3</nowiki>
 
 
 
確認
 
<nowiki>update_dump=# select count(*) from clients;
 
count
 
-------
 
  5131
 
(1 row)</nowiki>
 
 
 
テーブル名変更
 
update_dump=# ALTER TABLE clients RENAME TO clients_old;
 
 
 
新テーブルのスキーマをダンプ リストア
 
  % pg_dump --username=jq --schema-only --table clients tep5_development > ../clients_schema.sql
 
% psql --username=jq update_dump < ../clients_schema.sql
 
 
 
旧テーブルをセレクトして新テーブルにインサート
 
<nowiki>update_dump=# insert into clients
 
(
 
    id, user_id, note_id, content, client_line, memo, created_at, updated_at
 
)
 
select
 
    ie_id, user_id, jiin_id, name, table_order, memo, created_at, updated_at
 
from
 
    clients_old
 
where
 
    nusi = true;
 
INSERT 0 1304</nowiki>
 
 
 
テーブルの増分を求める
 
<nowiki>update_dump=# SELECT created_at FROM clients_new EXCEPT SELECT created_at FROM clients;
 
        created_at       
 
----------------------------
 
2022-11-20 11:38:24.975644
 
2021-10-09 17:50:13.19454
 
2022-11-18 18:24:26.100683
 
2022-12-02 14:31:59.651794
 
2020-01-05 16:08:24.725981
 
2022-10-13 18:18:47.00945
 
2022-10-16 12:13:27.960598
 
2022-09-19 17:04:20.793626
 
2022-10-14 21:58:23.012871
 
2022-09-26 18:41:40.679061
 
(10 rows)</nowiki>
 
 
 
update_dump=# select * from clients_new where created_at > '2022-09-19';
 
 
 
書き出す
 
% psql -d update_dump -U jq -c "select * from clients_new where created_at > '2022-09-19'" -F, > ../clients_add.csv
 
 
 
増分をインサートする
 
<nowiki>tep5_development=# INSERT INTO clients (id, user_id, note_id, list_id, content, created_at, updated_at) VALUES
 
(35375,2,3,1,'支所','2022-11-18 18:24:26.100683','2022-11-18 18:24:26.108051'),
 
(5360,2,1,1,'広島門会','2022-10-13 18:18:47.00945 ','2022-10-13 18:18:47.023412'),
 
.
 
.
 
.
 
(25362,13,2,1,'岡山族会','2022-10-16 12:13:27.960598','2022-10-16 12:13:27.968872');
 
INSERT 0 7</nowiki>
 
 
 
ここまでのバックアップを取る
 
% pg_dump -Fc tep5_development > ../202212151515.dump
 
 
 
==== 2022-12 -14 othersテーブル ====
 
09-15以降の増分を取る nusiがfalseのもの
 
% psql -d update_dump -U jq -c "select id, user_id, jiin_id, ie_id, name, yomi, nusi, each_order, memo, generation, created_at, updated_at from clients_old where created_at  > '2022-09-15' and nusi = false" -A -F, > ../others_add.csv
 
 
 
nusiがtrueのもの 両方必要
 
  % psql -d update_dump -U jq -c "select id, user_id, jiin_id, ie_id, name, yomi, nusi, each_order, memo, generation, created_at, updated_at from clients_old where created_at  > '2022-09-15' and nusi = true" -A -F, > ../others_nusi_add.csv
 
 
 
コピーコマンドで追加ができる
 
memoの改行削除が必要 vim中でcontrol+v control+mで^Mが入力できる :%s/^M//gc
 
 
=# \COPY others FROM '../others_add.csv' DELIMITER ',' CSV HEADER;
 
 
 
<nowiki>=# \COPY others FROM '../others_nusi_add.csv' DELIMITER ',' CSV HEADER;
 
COPY 8</nowiki>
 
 
 
ここまでのバックアップを取る
 
% pg_dump -Fc tep5_development > ../202212151649.dump
 
  
 
==== 旧clientsテーブルをリストアする ====
 
==== 旧clientsテーブルをリストアする ====
% pg_dump --username=jq --table clients_old heroku_dump > clients_old.sql
 
 
 
  <nowiki>% psql --username=jq tep5_development < ../old_other.sql  
 
  <nowiki>% psql --username=jq tep5_development < ../old_other.sql  
 
SET
 
SET
537行目: 332行目:
  
 
=== placesテーブル ===
 
=== placesテーブル ===
==== 12-16 ====
 
確認
 
<nowiki>latest_dump=# select count(*) from places;
 
count
 
-------
 
  921</nowiki>
 
 
=# select * from places where created_at > '2022-09-15';
 
 
増分書き出し
 
% psql -d latest_dump -U jq -c "select id, user_id, jiin_id, ie_id, zip, ken, city, etc, flag, created_at, updated_at from places where created_at  > '2022-09-15'" -A -F, > ../places_add.csv
 
 
places_add.csv memo列を,で作る client_id(ie_id)の桁数を調整する
 
 
コピーで追加
 
=# \COPY places FROM '../places_add.csv' DELIMITER ',' CSV HEADER;
 
 
ここまでのバックアップを取る
 
% pg_dump -Fc tep5_development > ../202212160911.dump
 
 
==== 以前 ====
 
 
確認
 
確認
 
  <nowiki>heroku_dump=# select count(*) from places;
 
  <nowiki>heroku_dump=# select count(*) from places;
568行目: 342行目:
 
dump
 
dump
 
  % pg_dump --username=jq --table places_old heroku_dump > places_old.sql
 
  % pg_dump --username=jq --table places_old heroku_dump > places_old.sql
 
 
==== 新データベースにリストア ====
 
==== 新データベースにリストア ====
 
  <nowiki>% psql --username=jq tep5_development < ../places_old.sql  
 
  <nowiki>% psql --username=jq tep5_development < ../places_old.sql  
621行目: 394行目:
 
INSERT 0 918</nowiki>
 
INSERT 0 918</nowiki>
  
generate
+
==== generate ====
 
  % rails generate scaffold Place user:references note:references client:references zip:string ken:string city:string etc:string flag:boolean memo:text
 
  % rails generate scaffold Place user:references note:references client:references zip:string ken:string city:string etc:string flag:boolean memo:text
  
665行目: 438行目:
  
 
=== schedulesテーブル ===
 
=== schedulesテーブル ===
==== 12-16 ====
 
確認
 
<nowiki>=# select count(*) from schedules;
 
count
 
-------
 
  3716
 
</nowiki>
 
 
<nowiki>=# select count(*) from schedules;
 
count
 
-------
 
  4026
 
</nowiki>
 
 
書き出し jiin_id(note_id)変更のため並べ変える
 
% psql -d latest_dump -U jq -c "select id, user_id, jiin_id, ie_id, datetime, content, client_id, every_year, goji, created_at, updated_at from schedules where created_at >= '2022-09-13' order by jiin_id" -A -F, > ../schedules_add.csv
 
 
../schedules_add.csv vimで修正する
 
jiin_id(note_id)2,3,4はそれぞれ20000,30000,40000を足す gojiは修正する :%s/,f,f/,f,/gc
 
 
copyで追加
 
=# \COPY schedules FROM '../schedules_add.csv' DELIMITER ',' CSV HEADER;
 
 
ここまでのバックアップを取る
 
% pg_dump -Fc tep5_development > ../202212161430.dump
 
 
==== 以前 ====
 
 
確認
 
確認
 
  <nowiki>heroku_dump=# select count(*) from schedules;
 
  <nowiki>heroku_dump=# select count(*) from schedules;
856行目: 602行目:
 
テーブルの変更
 
テーブルの変更
 
  =# ALTER TABLE accounts RENAME COLUMN account TO content;
 
  =# ALTER TABLE accounts RENAME COLUMN account TO content;
 
データ修正
 
=# update accounts set debit_credit = 1 where id = 43;
 
  
 
変更したテーブルをリストアし アプリのデータベースにコピーする
 
変更したテーブルをリストアし アプリのデータベースにコピーする
901行目: 644行目:
  
 
=== 仕訳帳テーブル ===
 
=== 仕訳帳テーブル ===
==== 12-16 17:18 ====
 
確認
 
<nowiki>latest_dump=# select count(*) from journals;
 
count
 
-------
 
14885</nowiki>
 
 
最新をテーブルダンプする
 
% pg_dump --username=jq --table journals latest_dump > ../update_journals.sql
 
 
update_dumpデータベースにリストアする
 
<nowiki>% psql --username=jq update_dump < ../update_journals.sql
 
SET
 
SET
 
SET
 
SET
 
SET
 
set_config
 
------------
 
 
(1 row)
 
 
SET
 
SET
 
SET
 
SET
 
SET
 
SET
 
CREATE TABLE
 
ALTER TABLE
 
CREATE SEQUENCE
 
ALTER TABLE
 
ALTER SEQUENCE
 
ALTER TABLE
 
COPY 14885</nowiki>
 
 
update_dump=# ALTER TABLE journals RENAME COLUMN client_id TO other_id;
 
ALTER TABLE
 
 
update_dump=# ALTER TABLE journals ADD COLUMN client_id integer;
 
ALTER TABLE
 
 
update_dump=# ALTER TABLE journals RENAME COLUMN jiin_id TO note_id;
 
ALTER TABLE
 
 
=# update journals set account_id = 99 where account_id is null;
 
UPDATE 10379
 
 
% pg_dump -t journals update_dump > ../journals_latest.sql
 
 
<nowiki>tep5_development=# delete from journals ;
 
DELETE 14719
 
tep5_development=# TRUNCATE TABLE journals RESTART IDENTITY;
 
TRUNCATE TABLE
 
tep5_development=# select * from journals_id_seq ;
 
last_value | log_cnt | is_called
 
------------+---------+-----------
 
          1 |      0 | f</nowiki>
 
 
<nowiki>% psql --username=jq tep5_development < ../journals_latest.sql
 
SET
 
SET
 
SET
 
SET
 
SET
 
set_config
 
------------
 
 
(1 row)
 
 
SET
 
SET
 
SET
 
SET
 
SET
 
SET
 
ERROR:  relation "journals" already exists
 
ALTER TABLE
 
ERROR:  relation "journals_id_seq" already exists
 
ALTER TABLE
 
ALTER SEQUENCE
 
ALTER TABLE
 
COPY 14885
 
setval
 
--------
 
  15199
 
(1 row)
 
 
ERROR:  multiple primary keys for table "journals" are not allowed
 
ERROR:  relation "index_journals_on_account_id" already exists
 
ERROR:  relation "index_journals_on_credit_and_credit_money_and_account_id" already exists
 
ERROR:  relation "index_journals_on_credit_s" already exists
 
ERROR:  relation "index_journals_on_debit_and_client_id_and_debit_money" already exists
 
ERROR:  relation "index_journals_on_debit_s" already exists
 
ERROR:  relation "index_journals_on_description_id_and_schedule_id" already exists
 
ERROR:  relation "index_journals_on_jiin_id" already exists
 
ERROR:  relation "index_journals_on_user_id" already exists
 
ERROR:  relation "index_journals_on_user_id_and_jiin_id_and_journal_number" already exists</nowiki>
 
 
ここまでのバックアップを取る
 
% pg_dump -Fc tep5_development > ../202212170834.dump
 
 
==== 以前 ====
 
 
確認
 
確認
 
  <nowiki>=# select count(*) from journals;
 
  <nowiki>=# select count(*) from journals;
1,011行目: 651行目:
 
(1 row)</nowiki>
 
(1 row)</nowiki>
  
  % rails generate scaffold Journal user:references note:references account:references client_id:integer other_id:integer journal_number:integer date:date schedule_id:integer debit:string debit_money:integer description_id:integer etc:string credit:string credit_money:integer debit_s:integer credit_s:integer
+
  % rails generate scaffold Journal user:references note:references client_id:integer other_id:integer account_id:integer journal_number:integer date:date schedule_id:integer debit:string debit_money:integer description_id:integer etc:string credit:string credit_money:integer debit_s:integer credit_s:integer
  
 
  % rails db:migrate
 
  % rails db:migrate
1,077行目: 717行目:
 
  % pg_dump tep5_development > ../202209270816_tep5.sql
 
  % pg_dump tep5_development > ../202209270816_tep5.sql
  
==== 替え玉 ====
+
== 摘要テーブル 変更あり ==
update_heroku=# insert into accounts(account_cd, content, bs_pl, debit_credit, created_at, updated_at) VALUES ('9999', '替え玉', 1, 1, '2022-09-28', '2022-09-28');
 
tep5_development=# insert into accounts(account_cd, content, bs_pl, debit_credit, created_at, updated_at) VALUES ('9999', '替え玉', 1, 1, '2022-09-28', '2022-09-28');
 
 
 
確認
 
<nowiki>tep5_development=# select * from accounts order by id desc limit 1;
 
id | account_cd | content | bs_pl | debit_credit |    created_at      |    updated_at     
 
----+------------+---------+-------+--------------+---------------------+---------------------
 
99 | 9999      | 替え玉  |    1 |            1 | 2022-09-28 00:00:00 | 2022-09-28 00:00:00
 
(1 row)</nowiki>
 
 
 
<nowiki>update_heroku=# select count(*) from journals where account_id is null;
 
count
 
-------
 
10379
 
(1 row)</nowiki>
 
 
 
替え玉挿入
 
<nowiki>update_heroku=# update journals set account_id = 99 where account_id is null;
 
UPDATE 10379</nowiki>
 
 
 
=== 摘要テーブル 変更あり ===
 
 
確認
 
確認
 
  <nowiki>heroku_dump=# select count(*) from descriptions;
 
  <nowiki>heroku_dump=# select count(*) from descriptions;
1,105行目: 724行目:
 
   640
 
   640
 
(1 row)</nowiki>
 
(1 row)</nowiki>
 
% rails generate scaffold Description user:references note:references account:references content:string money:integer desc_line:integer
 
 
(UUID削除 index追加)
 
 
% rails db:migrate
 
 
リストアして作業データベースにコピーする
 
% pg_dump --username=jq --table descriptions heroku_dump > ../new_descriptions.sql
 
% psql --username=jq update_heroku < ../new_descriptions.sql
 
 
テーブルの変更
 
=# ALTER TABLE descriptions RENAME COLUMN jiin_id TO note_id;
 
 
リストア コピー
 
% pg_dump --username=jq --table descriptions update_heroku > ../new_descriptions.sql
 
<nowiki>% psql --username=jq tep5_development < ../new_descriptions.sql
 
SET
 
SET
 
SET
 
SET
 
SET
 
set_config
 
------------
 
 
(1 row)
 
 
SET
 
SET
 
SET
 
SET
 
SET
 
SET
 
ERROR:  relation "descriptions" already exists
 
ALTER TABLE
 
ERROR:  relation "descriptions_id_seq" already exists
 
ALTER TABLE
 
ALTER SEQUENCE
 
ALTER TABLE
 
COPY 640
 
setval
 
--------
 
    871
 
(1 row)
 
 
ERROR:  multiple primary keys for table "descriptions" are not allowed
 
ERROR:  relation "index_descriptions_on_account_id" already exists
 
CREATE INDEX
 
ERROR:  relation "index_descriptions_on_user_id" already exists
 
CREATE INDEX
 
ALTER TABLE
 
ERROR:  relation "public.jiins" does not exist</nowiki>
 
 
  
 
ダンプ ここまで形を整えたデータベースをバックアップしとく
 
ダンプ ここまで形を整えたデータベースをバックアップしとく
 
  % pg_dump tep5_development > ../202209270816_tep5.sql
 
  % pg_dump tep5_development > ../202209270816_tep5.sql
 
=== 戒名テーブル 変更あり ===
 
==== 12-17 11:14 ====
 
確認
 
<nowiki>latest_dump=# select count(*) from kaimyous;
 
count
 
-------
 
  3445</nowiki>
 
 
増分を書き出す
 
% psql -d latest_dump -U jq -c "select id, user_id, jiin_id, ie_id, client_id, content, date, g_age, relationship, ie_id_v, created_at, updated_at from kaimyous where created_at >= '2022-09-13' order by jiin_id" -A -F, > ../kaimyous_add.csv
 
 
ie_id(client_id)は修正する ie_id_vはmemoに対応するために書き出した
 
 
コピーで追加
 
<nowiki>=# \COPY kaimyous FROM '../kaimyous_add.csv' DELIMITER ',' CSV HEADER;
 
COPY 70</nowiki>
 
 
==== 以前 ====
 
確認
 
<nowiki>heroku_dump=# select count(*) from kaimyous;
 
count
 
-------
 
  3375
 
(1 row)</nowiki>
 
 
rails generate scaffold Kaimyou user:references note:references client:references other:references content:string birth:date death:date g_age:string relationship:string memo:text
 
 
(UUID削除 index追加)
 
 
% rails db:migrate
 
 
リストアして作業データベースにコピーする
 
% pg_dump --username=jq --table kaimyous heroku_dump > ../new_kaimyous.sql
 
% psql --username=jq update_heroku < ../new_kaimyous.sql
 
 
テーブルの変更
 
<nowiki>update_heroku=# ALTER TABLE kaimyous RENAME COLUMN jiin_id TO note_id;
 
ALTER TABLE
 
update_heroku=# ALTER TABLE kaimyous RENAME COLUMN client_id TO other_id;
 
ALTER TABLE
 
update_heroku=# ALTER TABLE kaimyous RENAME COLUMN ie_id TO client_id;
 
ALTER TABLE
 
update_heroku=# ALTER TABLE kaimyous RENAME COLUMN date TO death;
 
ALTER TABLE
 
update_heroku=# ALTER TABLE kaimyous ADD COLUMN birth date;
 
ALTER TABLE
 
update_heroku=# ALTER TABLE kaimyous DROP COLUMN ie_id_v;
 
ALTER TABLE
 
update_heroku=# ALTER TABLE kaimyous ADD COLUMN memo text;
 
ALTER TABLE</nowiki>
 
 
新テーブルのclient_id other_idに合わせる other_idは一意なので変更しない
 
<nowiki>update_heroku=# update kaimyous SET client_id = client_id + 20000 where note_id = 2;
 
UPDATE 587
 
update_heroku=# update kaimyous SET client_id = client_id + 30000 where note_id = 3;
 
UPDATE 662
 
update_heroku=# update kaimyous SET client_id = client_id + 40000 where note_id = 4;
 
UPDATE 256</nowiki>
 
 
 
エラー clientsテーブルのidとkaimyousテーブルのclient_idを比較する
 
<nowiki>update_heroku=# SELECT id FROM clients
 
EXCEPT
 
SELECT client_id FROM kaimyous
 
UNION ALL
 
SELECT client_id FROM kaimyous
 
EXCEPT
 
SELECT id FROM clients order by id;
 
  id 
 
-------
 
    21
 
    27
 
    35
 
    38
 
    39
 
    44
 
    46
 
    56
 
    57
 
    63
 
    71
 
    73
 
    78
 
    89
 
  101
 
  106
 
  111
 
  126
 
  127
 
  135
 
  144
 
  147
 
  156
 
  173
 
  174
 
  176
 
  186
 
  188
 
  189
 
  230
 
  310
 
  373
 
  404
 
  473
 
  701
 
  804
 
  872
 
  936
 
  953
 
  972
 
  998
 
  1590
 
  1671
 
  1777
 
  2249
 
  2290
 
22653
 
34681
 
(48 rows)</nowiki>
 
 
書き出す
 
<nowiki>% psql update_heroku -c "SELECT id FROM clients
 
EXCEPT
 
SELECT client_id FROM kaimyous
 
UNION ALL
 
SELECT client_id FROM kaimyous
 
EXCEPT
 
SELECT id FROM clients order by id;" > ../hikaku/clients_kaimyous_client_id.csv</nowiki>
 
 
,挿入 改行削除
 
:%s/\n//g
 
 
削除する戒名を書き出す
 
<nowiki>% psql update_heroku -c "select * from kaimyous where client_id in (21,    27,    35,    38,    39,    44,    46,    56,    57,    63,    71,    73,    78,    89,  101,  106,  111,  126,  127,  135,  144,  147,  156,  173,  174,  176,  186,  188,  189,  230,  310,  373,  404,  473,  701,  804,  872,  936,  953,  972,  998,  1590,  1671,  1777,  2249,  2290, 22653, 34681);" > ../tmp/delete_kaimyou.csv</nowiki>
 
 
削除
 
<nowiki>update_heroku=# delete from kaimyous where client_id in (21,    27,    35,    38,    39,    44,    46,    56,    57,    63,    71,    73,    78,    89,  101,  106,  111,  126,  127,  135,  144,  147,  156,  173,  174,  176,  186,  188,  189,  230,  310,  373,  404,  473,  701,  804,  872,  936,  953,  972,  998,  1590,  1671,  1777,  2249,  2290, 22653, 34681);
 
DELETE 81</nowiki>
 
 
ダンプ リストア
 
<nowiki>jq@MacBook-Pro tep5 % pg_dump --username=jq --table kaimyous update_heroku > ../new_kaimyous.sql
 
jq@MacBook-Pro tep5 % psql --username=jq tep5_development < ../new_kaimyous.sql
 
SET
 
SET
 
SET
 
SET
 
SET
 
set_config
 
------------
 
 
(1 row)
 
 
SET
 
SET
 
SET
 
SET
 
SET
 
SET
 
ERROR:  relation "kaimyous" already exists
 
ALTER TABLE
 
ERROR:  relation "kaimyous_id_seq" already exists
 
ALTER TABLE
 
ALTER SEQUENCE
 
ALTER TABLE
 
COPY 3294
 
setval
 
--------
 
  4230
 
(1 row)
 
 
ERROR:  multiple primary keys for table "kaimyous" are not allowed
 
ERROR:  relation "index_kaimyous_on_client_id" already exists
 
ERROR:  relation "index_kaimyous_on_client_id_and_content" already exists
 
ERROR:  relation "index_kaimyous_on_date" already exists
 
ERROR:  relation "index_kaimyous_on_ie_id" already exists
 
ERROR:  relation "index_kaimyous_on_jiin_id" already exists
 
ERROR:  relation "index_kaimyous_on_user_id" already exists
 
ERROR:  relation "index_kaimyous_on_user_id_and_jiin_id" already exists
 
ERROR:  relation "public.jiins" does not exist</nowiki>
 
 
ダンプ ここまで形を整えたデータベースをバックアップしとく
 
% pg_dump tep5_development > ../202210031034_tep5.sql
 
 
=== 通帳テーブル ===
 
確認
 
<nowiki>heroku_dump=# select count(*) from bankbooks;
 
count
 
-------
 
    36</nowiki>
 
 
% rails generate scaffold Bankbook user:references note:references content:string memo:text
 
 
やり直し
 
% rails destroy scaffold Bankbook user:references note:references content:string memo:text
 
% rails generate scaffold Bankbook user:references note:references content:string bank_line:integer memo:text
 
 
(UUID削除 index追加)
 
% rails db:migrate
 
 
リストアして作業データベースにコピーする
 
% pg_dump --username=jq --table bankbooks heroku_dump > ../new_bankbooks.sql
 
% psql --username=jq update_heroku < ../new_bankbooks.sql
 
 
テーブルの変更
 
update_heroku=# ALTER TABLE bankbooks RENAME COLUMN jiin_id TO note_id;
 
ALTER TABLE
 
 
ダンプ リストア
 
<nowiki>jq@MacBook-Pro tep5 % pg_dump --username=jq --table bankbooks update_heroku > ../new_bankbooks.sql
 
jq@MacBook-Pro tep5 % psql --username=jq tep5_development < ../new_bankbooks.sql
 
SET
 
SET
 
SET
 
SET
 
SET
 
set_config
 
------------
 
 
(1 row)
 
 
SET
 
SET
 
SET
 
SET
 
SET
 
SET
 
ERROR:  relation "bankbooks" already exists
 
ALTER TABLE
 
ERROR:  relation "bankbooks_id_seq" already exists
 
ALTER TABLE
 
ALTER SEQUENCE
 
ALTER TABLE
 
COPY 36
 
setval
 
--------
 
    68
 
(1 row)
 
 
ERROR:  multiple primary keys for table "bankbooks" are not allowed
 
CREATE INDEX
 
ERROR:  relation "index_bankbooks_on_user_id" already exists
 
CREATE INDEX
 
ERROR:  relation "public.jiins" does not exist</nowiki>
 
 
ダンプ ここまで形を整えたデータベースをバックアップしとく
 
% pg_dump tep5_development > ../202211021454_tep5.sql
 
 
=== relationshipsテーブル ===
 
確認
 
<nowiki>latest_dump=# select count(*) from relationships;
 
count
 
-------
 
    40</nowiki>
 
 
relationshipsテーブル ダンプ
 
% pg_dump --username=jq --table relationships latest_dump > ../new_relationships.sql
 
 
update_dumpデータベースにリストアしてロール列を削除する
 
% psql --username=jq update_dump < ../new_relationships.sql
 
=# ALTER TABLE relationships DROP COLUMN role;
 
 
修正したテーブルをダンプする
 
% pg_dump --username=jq --table relationships update_dump > ../relationships_dump.sql
 
 
リストアする
 
% psql -d tep5_development < ../relationships_dump.sql
 
 
バックアップを取る -Fc カスタム形式 圧縮ファイル形式
 
% pg_dump -Fc tep5_development > ../202212141027.dump
 
 
== house_note ==
 
旧データベースからダンプ
 
% pg_dump --username=jq --table house_notes latest_dump > ../hns.sql
 
 
サーバーへ転送
 
% rsync -r --delete --exclude-from='exclude-file.txt' ~/rails_app_tepnote/hns.sql jq:/home/jq/dump_data
 
 
リストア
 
$ psql update_dump < ../hns.sql
 
 
clientsのidとhouse_noteのidをあわせる
 
<nowiki>tep5_production=# update house_notes SET ie_id = ie_id + 20000 where jiin_id = 2;
 
UPDATE 30
 
tep5_production=# update house_notes SET ie_id = ie_id + 30000 where jiin_id = 3;
 
UPDATE 114
 
tep5_production=# update house_notes SET ie_id = ie_id + 40000 where jiin_id = 4;
 
UPDATE 25</nowiki>
 
 
セレクトしてアップデートする
 
tep5_production=# UPDATE clients as Cl SET memo = (SELECT content FROM house_notes as Hn WHERE Hn.ie_id = Cl.id);
 
 
削除
 
=# drop table house_notes ;
 
  
 
== UUIDを有効にする ==
 
== UUIDを有効にする ==
1,531行目: 803行目:
  
 
  $ rails generate scaffold Post content:text user:references picture:string
 
  $ rails generate scaffold Post content:text user:references picture:string
 
$ rails generate scaffold Post user:references title:string content:text notification_time:datetime reminder_type:integer post_type:integer picture:string
 
  
 
  $ rails generate model Relationship follower_id:integer followed_id:integer
 
  $ rails generate model Relationship follower_id:integer followed_id:integer
1,547行目: 817行目:
 
config/envitonments/production.rb
 
config/envitonments/production.rb
 
  config.assets.compile = true
 
  config.assets.compile = true
 
=== カラム追加 ===
 
<nowiki>% rails generate migration add_memo_to_schedules memo:text
 
      invoke  active_record
 
      create    db/migrate/20230311013341_add_memo_to_schedules.rb
 
% rails db:migrate
 
== 20230311013341 AddMemoToSchedules: migrating ===============================
 
-- add_column(:schedules, :memo, :text)
 
  -> 0.0056s
 
== 20230311013341 AddMemoToSchedules: migrated (0.0057s) ======================</nowiki>
 
 
=== 外部キー制約に変更 ===
 
rails generate migration AddScheduleReferenceToJournal schedule:references
 
  
 
== サーバーへ転送 ==
 
== サーバーへ転送 ==
1,567行目: 824行目:
 
     database.yml</nowiki>
 
     database.yml</nowiki>
  
すべて
 
 
  % rsync -r --delete --exclude-from='exclude-file.txt' ~/rails_app_tepnote/tep5/ jq:/home/jq/tep5/
 
  % rsync -r --delete --exclude-from='exclude-file.txt' ~/rails_app_tepnote/tep5/ jq:/home/jq/tep5/
  
appのみ
+
  % rsync ~/rails_app_tepnote/tep5_uuid_dump.sql jq:/home/jq/dump_data
% rsync -r --delete --exclude-from='exclude-file.txt' ~/rails_app_tepnote/tep5/app/ jq:/home/jq/tep5/app/
 
 
 
データベース
 
  % rsync ~/rails_app_tepnote/202212170834.dump jq:/home/jq/dump_data
 
  
 
== サーバー側 ==
 
== サーバー側 ==
リストア
 
$ pg_restore --verbose --clean --no-acl --no-owner -h localhost -U jq -d tep5_ production  ../dump_data/202212141027.dump
 
 
 
  $ bundle install  --without test development
 
  $ bundle install  --without test development
  
1,587行目: 836行目:
  
 
データベース削除
 
データベース削除
~$ dropdb tep5_production
 
または
 
 
  postgres=# DROP DATABASE tep5_production;
 
  postgres=# DROP DATABASE tep5_production;
  
1,663行目: 910行目:
  
 
  $ rails db:migrate RAILS_ENV=production
 
  $ rails db:migrate RAILS_ENV=production
 
=== シーケンス操作 ===
 
確認
 
<nowiki>=# select * from others_id_seq ;
 
last_value | log_cnt | is_called
 
------------+---------+-----------
 
        14 |      30 | t</nowiki>
 
 
最大値確認
 
<nowiki>=# select max(id) from others;
 
max 
 
------
 
5428</nowiki>
 
 
変更
 
<nowiki>=# SELECT setval('others_id_seq', 5428, true);
 
setval
 
--------
 
  5428</nowiki>
 
 
=== バックアップ ===
 
dump
 
$ pg_dump -Fc tep5_production > ~/dump_data/202212180817.dump
 
 
ローカル側からコピーして二箇所で保存する
 
% scp jq:/home/jq/dump_data/202212180817.dump /Users/jq/rails_app_tepnote
 
 
== データベース変更 ==
 
=== まるごと ===
 
ダンプ 本番データベースバックアップ データのみ
 
$ pg_dump -a tep5_production > ~/dump_data/202212270953_data_only.sql
 
 
ローカルからコピー
 
% scp jq:/home/jq/dump_data/202212270953_data_only.sql /Users/jq/rails_app_tepnote
 
 
ローカルデータベース削除
 
% rails db:drop
 
 
データベース作成
 
% rails db:create
 
 
マイグレーション変更
 
 
マイグレーション
 
% rails db:migrate
 
 
リストア
 
% psql --username=jq tep5_development < ../202212270953_data_only.sql
 
 
=== カラム追加 boolean ===
 
% rails generate migration add_payment_to_descriptions payment:boolean
 
 
add_column :descriptions, :payment, :boolean, default: false
 
 
$ rails db:migrate
 
 
=== あとから外部キー制約を追加する手順 ===
 
親テーブルと子テーブルのIDを比較する 不整合があればテーブルを修正する
 
<nowiki>=# SELECT id FROM others
 
EXCEPT
 
SELECT other_id FROM journals
 
UNION ALL
 
SELECT other_id FROM journals
 
EXCEPT
 
SELECT id FROM others order by id;
 
  id 
 
------
 
 2435</nowiki>
 
 
外部キー制約を追加するmigration ファイルをつくる
 
<nowiki> % rails generate migration AddClientReferenceToJournal client:references
 
      invoke  active_record
 
      create    db/migrate/20230509044227_add_client_reference_to_journal.rb
 
% rails generate migration AddOtherReferenceToJournal other:references
 
      invoke  active_record
 
      create    db/migrate/20230509044353_add_other_reference_to_journal.rb</nowiki>
 
 
rails db:migrateでエラー
 
 
すでにother_idカラムが存在するのでadd_referenceメソッドが実行できない
 
 
直接データベースを操作してother_idカラム名をhoge_idカラム名に変更する
 
 
ALTER TABLE journals RENAME COLUMN other_id TO hoge_id;
 
 
rails db:migrate
 
 
hoge_idカラムの値をother_idカラムにコピーする
 
UPDATE journals SET other_id = hoge_id;
 
 
ローカルならrails consoleを使用して
 
 
Journal.update_all('other_id = hoge_id')
 
 
hoge_idを削除する
 
ALTER TABLE journals DROP COLUMN hoge_id;
 
 
=== エラー ===
 
例えば待避したhoge_idを戻すとき次のようなエラーがでる
 
<nowiki>=# UPDATE journals SET schedule_id = hoge_id;
 
ERROR:  insert or update on table "journals" violates foreign key constraint "fk_rails_9d4d4268db"
 
DETAIL:  Key (schedule_id)=(970) is not present in table "schedules".</nowiki>
 
journalsテーブルのschedule_idがschedulesテーブルにないのでそれを拾い出して削除する
 
<nowiki>=# delete from journals where hoge_id in (
 
SELECT id FROM schedules
 
EXCEPT
 
SELECT hoge_id FROM journals
 
UNION ALL
 
SELECT hoge_id FROM journals
 
EXCEPT
 
SELECT id FROM schedules);</nowiki>
 
 
== gemアップデート ==
 
確認
 
% gem -v
 
アップデート対象Gemを一覧表示
 
% bundle outdated
 
 
== 備忘 ==
 
現在UUIDコメントアウト中 config/initializers/generators.rb
 

wikipokpokへの投稿はすべて、クリエイティブ・コモンズ 表示-継承 (詳細はWikipokpok:著作権を参照)のもとで公開したと見なされることにご注意ください。 自分が書いたものが他の人に容赦なく編集され、自由に配布されるのを望まない場合は、ここに投稿しないでください。
また、投稿するのは、自分で書いたものか、パブリック ドメインまたはそれに類するフリーな資料からの複製であることを約束してください。 著作権保護されている作品は、許諾なしに投稿しないでください!

このページを編集するには、下記の確認用の質問に回答してください (詳細):

取り消し | 編集の仕方 (新しいウィンドウで開きます)

このページで使用されているテンプレート: