スキップしてメイン コンテンツに移動

唯識論の五位百法の各項目の有無とNullを表す情報をデータベース化する場合、詳細な項目に従ってSQL文をどう書きますか?MySqlで例示してください

 唯識論の五位百法には、100の事象を分類するための5つの範疇があります¹。各項目がNullであるかどうかを表す情報を含める場合、1事象に対して必要な情報量は3000ビットとなります¹。ここでは、各項目がNullであるかどうかを表す情報を含める場合のSQL文をMySqlで例示します。


以下のようなテーブルを作成します。


```sql

CREATE TABLE gowi_hyappou (

  id INT NOT NULL AUTO_INCREMENT,

  shingou INT,

  shingou_null BOOL,

  shoyuu_hou INT,

  shoyuu_hou_null BOOL,

  shikihou INT,

  shikihou_null BOOL,

  fushoudou_hou INT,

  fushoudou_hou_null BOOL,

  muhi_hou INT,

  muhi_hou_null BOOL,

  PRIMARY KEY (id)

);

```


各項目がNullであるかどうかを表す情報を含める場合、以下のようなINSERT文を使用してデータを挿入します。


```sql

INSERT INTO gowi_hyappou (

  shingou, shingou_null, shoyuu_hou, shoyuu_hou_null, shikihou, shikihou_null, fushoudou_hou, fushoudou_hou_null, muhi_hou, muhi_hou_null

) VALUES (

  1, true, 2, false, 3, true, 4, false, 5, true

);

```


各項目がNullであるかどうかを表す情報を含める場合、以下のようなSELECT文を使用してデータを取得します。


```sql

SELECT

  shingou,

  IF(shingou_null, 'NULL', 'NOT NULL') AS shingou_null,

  shoyuu_hou,

  IF(shoyuu_hou_null, 'NULL', 'NOT NULL') AS shoyuu_hou_null,

  shikihou,

  IF(shikihou_null, 'NULL', 'NOT NULL') AS shikihou_null,

  fushoudou_hou,

  IF(fushoudou_hou_null, 'NULL', 'NOT NULL') AS fushoudou_hou_null,

  muhi_hou,

  IF(muhi_hou_null, 'NULL', 'NOT NULL') AS muhi_hou_null

FROM gowi_hyappou;

```


以上のように、各項目がNullであるかどうかを表す情報を含める場合、SQL文を記述することができます。


¹: [コトバンク](https://kotobank.jp/word/%E4%BA%94%E4%BD%8D%E7%99%BE%E6%B3%95-61314)


ソース: Bing との会話 2024/1/12

(1) 五位百法(ごいひゃっぽう)とは? 意味や使い方 - コトバンク. https://kotobank.jp/word/%E4%BA%94%E4%BD%8D%E7%99%BE%E6%B3%95-61314.

(2) ごいひゃっぽう - WikiDharma. http://www.wikidharma.org/index.php/%E3%81%94%E3%81%84%E3%81%B2%E3%82%83%E3%81%A3%E3%81%BD%E3%81%86.

(3) 法相宗(唯識宗)本山と開祖、その教えとは?. https://true-buddhism.com/shuha/hossoshu/.

(4) 唯識思想 3.五位百法は、説一切有部の五位七十五法を .... http://www.obpen.com/essay/20170711_03.html.

コメント

このブログの人気の投稿

さくらインターネットのレンタルサーバにMysqlの大きいdumpファイルのインポート

 さくらインターネットのレンタルサーバはFreeBSDをつかっています。 LAMP の環境が揃っています。 基本的にFTPアカウントが発行されて、Webベースでファイルの転送もデータベースの作成および管理(phpMyAdmin)ができます。 しかし、phpMyAdminは、dumpファイルをインポートする場合、最大16MBのファイルしかアプロードできません。 明確的にSSHアカウントは提示されていないが、実際にSSHでの接続も可能だと確認しました。しかし、SSHで接続してもmysqlでリモートMysqlサーバへの接続はできなかったようです。 そこで、dumpファイルの中身はSQL文なので、 A5m2 というSQLクライアントからインポートすることを試しました。 もちろん、自宅のパソコンから直接Mysqlサーバを接続できるとは思いませんが、一応試してみました。案の定、当たり前に制限がかけられています。 で、よく考えるとレンタルサーバからアクセスできるから、そのIPは許可されているだろうと思います。 なので、SSHトンネルを Bitvise SSH Client で掘ろうと考えていました。 BitviseのSSH設定はそんなに難しくないので、割愛しますが、 C2Sのタブの設定は下記の通りです。 listen interface => 127.0.0.1 List Port => 3306 (ローカルにMysqlが稼働している場合、3326とかに設定してください) Destination Host => レンタルサーバが提供しているMysqlサーバ mysql~.~.ac.jp Dest. Port => 3306 A5m2のデータベース設定は、Mysql直接接続で、IPを127.0.0.1にすれば、接続できるはずです。 それから、Dumpファイルを読み込んで「先頭からすべて」実行をすれば、いまのところ500MB位のファイルでも実行できました。だが、1.2GBのファイルは読み込みの途中にエラーになったが、ファイルが大きい過ぎたか、それともUTF8コードの問題なのか調査中です。結果がわかった次第追記します。

iPhoneのカレンダーに見知らぬアカウントによるフィティングリンクの恐れ

 昨日突然妻から、iPhoneのカレンダーに怪しい予定はいっぱい書き込まれました。 最初はメールアドレスの盗用されたと思って、メールアカウントのパスワードと、そのメールアドレスのApple IDのパスワードを急遽変更しました。しかし、書き込みが消えず、よくカレンダーの設定のアカウントを調べると下記の画像のような気持ち悪いアカウントがいつの間にか設定されてしまいました。おそらく料理紹介のホームページにある怪しい広告をクリックしたかもしれません。くれぐれもご注意ください。 幸い、このアカウントを削除すれば、書き込みも消えました。なにが違和感を感じたときは、絶対にリンク等をクリックしないほうが身のためでしょう。 さらにnslookupで ylevelsoft.funを調べてみるとIPは13.226.77.* セグメント内の4つのようです。 $ nslookup ylevelsoft.fun Server:         192.168.11.1 Address:        192.168.11.1#53 Non-authoritative answer: Name:   ylevelsoft.fun Address: 13.226.77.19 Name:   ylevelsoft.fun Address: 13.226.77.33 Name:   ylevelsoft.fun Address: 13.226.77.8 Name:   ylevelsoft.fun Address: 13.226.77.15 これらのIPアドレスを調べると、東京にあるIPアドレスがわかって、Amazonにホスティングしてるようです。 13.226.77.19 IP Address Details - IPinfo.io カレンダーのアカウントに登録したサーばをnslookupを調べると13.33.9.*セグメントの4つが使われて、Amazonにホスティングしてるようです。 このホスト名は、server-13-33-9-105.nrt57.r.cloudfront.net 上記のIPのホスト名server-13-...

閉域網の電子カルテにJitsiを稼働させてみた!(続き)

 前回は、 閉域網の電子カルテにJitsiを稼働してみた! を紹介しました。 サーバは古いMacminiですが、今回はインターネット環境のWindows 10のHyper-VでDebian 10を入れて、仮想サーバを電子カルテネットワーク内の、Windows server 2019とWindows server 2008のHyper-Vに移植する試みを紹介します。 Hyper-Vにすることで、新しい研究用仮想基盤や古いサーバ(旧国立大バックアップシステム等)の仮想基盤化で必要数に応じて簡単にJitsiサーバを増やすことが可能という利点があります。それから、故障した場合も簡単に他のHyper-V仮想基盤にすぐ再稼働することが可能なので耐障害になります。 今回利用したDebianのインストーラは、 debian-10.7.0-amd64-netinst.iso です。 基本のDebianのインストールはインストーラの指示通りでできますので、こちらで割愛します。必要なサービスは、VNCやSSHあたりです。GUIが利用したい場合、お好みのデスクトップで構いません。 Jitsi Meetのインストールは、 こちらのサイト(英文) を参考していますが、 こちらの環境では、下記のコマンドでやってみました。ドメイン名を使わず、IPアドレスのみでの設定なので、Hyper-Vのチェックポインの機能でIP変更のたびにJitsiをインストールします。 $ wget https://download.jitsi.org/jitsi-key.gpg.key $ sudo apt-key add jitsi-key.gpg.key $ sudo nano /etc/apt/sources.list.d/jitsi-stable.list #下記の一行を追記 deb https://download.jitsi.org stable/ $ sudo apt update $ sudo apt -d install jitsi-meet #電子カルテから簡単にインターネットからダウンロードできない環境を考えるととりあえず-dでダウンロードオンリーにします #ここでHyper-Vのチェックポインにします。 $ sudo apt install jitsi-meet イン...