X



SQLなら俺に訊け [無断転載禁止]©2ch.net
0001デフォルトの名無しさん2017/07/14(金) 07:40:53.63ID:HFjsarQi
さあ
0002デフォルトの名無しさん2017/07/18(火) 22:00:59.52ID:siPNnjTj
count(*)の*と、select * fromの*は同じでしょうか
0004デフォルトの名無しさん2017/07/20(木) 17:41:19.81ID:3fjdXCU7
>>3
違うよ

select * from fooは、「fooテーブルの全カラム」という意味

count()の方は、
count(column_name)とカラム名を指定したときは、column_nameがnullではない行数が取得される
count(*)だとnullとか関係なしに全行数
000522017/07/20(木) 20:03:27.83ID:fM45JSSS
>>3 >>4
ありがとう。なんとなく違う感じでうまく説明できなかったけど、>>4の通りだわ
0008デフォルトの名無しさん2017/08/26(土) 19:24:02.61ID:DSilAr/A
foo_id, bar_id_list
"1", "1,2,3"
"2", "4,5"
"3", "6,7,8"

これを

foo_id, bar_id
"1", "1"
"1", "2"
"1", "3"
"2", "4"
"2", "5"
"3", "6"
"3", "7"
"3", "8"

こう変換するクエリって書ける?
なるべく標準がいいけどポスグレ依存でも可
0009デフォルトの名無しさん2017/08/30(水) 07:14:19.33ID:FYBJnXXr
>>8
お前は秘密の合言葉を言ってない。
「お願いします。どうか教えて下さい」
001082017/08/30(水) 08:02:42.85ID:ItMe6Tvy
再帰クエリでできました

SQLは業務で使うことも多いのにSQLスレに人がいないのは寂しいですね
0012デフォルトの名無しさん2017/11/03(金) 20:07:37.65ID:N8t7Jq3a
SQL初心者です。
複数のrowを一度に取りたいのですがどう書けばいいのでしょうか。
後述の(C)より効率のよい記述を探しています。
(なおRock54回避の為シングルクオートを全角に、またselectをカタカナに変更しています)

用途は掲示板で、以下のような「先頭と最近の5投稿」の取得が目的です。
https://mevius.5ch.net/tech/
環境はSQLiteです。SQLite依存で構いません。
単純には以下2クエリになりますが、

select * from thread order by no limit 1; // (A)
select * from thread order by no desc limit 5; // (B)

A-B間で更新されたときに過渡状態のデータが返ることを避けるため、一つに纏めたいのです。
SQLiteでは読み込みにはトランザクションが使えず、BEGIN/COMMITで囲んでブロック出来ません。
試行錯誤して一応以下のクエリは通るようですが、サブクエリが効率が悪く見えるのでもっと良い書き方を探しています。

セレクト from ’1234’ where no in (values(’1234’) union セレクト no from ’1234’ order by rowid desc limit 6); // (C)

ここで1234はスレッド名=スレッド最初の投稿Noです。
4chanのように板毎にNoが打たれており、スレ内のNoは飛び飛びになっています。
なお前側values部分もサブクエリにして先頭番号を取得する limit 1のサブクエリも書き方があれば教えてください。
(デバッグ時に使う)
これも出来ません。例えば、以下は通りません。

セレクト * from ’1234’ where no in ((セレクト no from ’1234’ limit 1) union セレクト no from ’1234’ order by rowid desc limit 6); // (D)
// limitはunionの後に、とエラーが出る

(A)+(B)は同時にデータも取得する為、(C)より効率がいいと考えています。
(データの順序が異なるが、簡単にカバー出来る範囲なので問題ない)
ただし(A)+(B)だと場合によっては中途半端なデータが返る時があり、これは避けたいのです。
なお初心者の為上記前提がいろいろ間違っているかもしれませんが、その辺はご指摘下さい。
0013デフォルトの名無しさん2017/11/03(金) 22:59:45.82ID:ATL1IZSq
SQLiteがreadでトランザクション使えないって、そうだっけ?
デフォルトがrepeatable readじゃないから勘違いしてるとかじゃなくて?
0014デフォルトの名無しさん2017/11/03(金) 23:25:25.83ID:N8t7Jq3a
>>13
そうなのかもしれませんが、それを変える方法が分かりません。
SQL自体はSQL92準拠らしいです。
http://www.sqlite.org/fullsql.html

ちなみにトランザクションのページはこちら。
http://www.sqlite.org/lang_transaction.html

なお、select自体は一つのトランザクションらしく、例えば上記(A)(B)を繋いで begin; commit;で囲むと、
「トランザクション中でトランザクションを開始出来ません」というエラーになります。
// Error: cannot start a transaction within a transaction
0015デフォルトの名無しさん2017/11/03(金) 23:38:29.19ID:N8t7Jq3a
ああすいません、これですかね?
PRAGMA read_uncommitted;
http://www.sqlite.org/pragma.html#pragma_read_uncommitted

ここの書き方だとよく分からないのですが、
デフォはSERIALIZABLEで、これをREAD UNCOMMITTED(true)にして、
さらに書き込み側をBEGIN EXCLUSIVEにしろってことですかね?

> After a BEGIN IMMEDIATE,
> no other database connection will be able to write to the database or do a BEGIN IMMEDIATE or BEGIN EXCLUSIVE.
> Other processes can continue to read from the database, however.
> An exclusive transaction causes EXCLUSIVE locks to be acquired on all databases.
> After a BEGIN EXCLUSIVE,
> no other database connection except for read_uncommitted connections will be able to read the database
> and no other connection without exception will be able to write the database until the transaction is complete.
> http://www.sqlite.org/lang_transaction.html
0016デフォルトの名無しさん2017/11/03(金) 23:58:59.47ID:N8t7Jq3a
あ、いや、違いましたね。
read_uncomitted は制限を緩和する方向でした。
まだ全貌を把握しておらず、ここら辺はすみません。

SQLiteはseriarizableを実装しているとは書いてありますが、デフォが何かはよく分かりません。
> SQLite implements serializable transactions
> http://www.sqlite.org/transactional.html

ただまあ、今のところ複数selectをトランザクションに指定する方法が分かりません。
多分単発のselectなら自動的にトランザクション化してます。
0019デフォルトの名無しさん2017/11/13(月) 20:26:57.15ID:612lbeAQ
このスレはデータベース板にいるやつのネタスレだな。

count(*)は慣習上、このように書いているだけ。
0020デフォルトの名無しさん2017/12/15(金) 21:10:52.36ID:Tb0OcKpN
SQLは重いというイメージが頭から離れない
またとってくればいいだけなんだが
どうしても一度取得してきたデータを使いまわしたくてプログラムがぐしゃぐしゃになる
0022デフォルトの名無しさん2017/12/16(土) 21:34:31.55ID:Bt/T1sYp
スコープの長い変数をずっと持ってないといけないから
メソッドの引数がふえて
だから作ったメソッドが使いづらい
0023デフォルトの名無しさん2017/12/17(日) 11:36:00.81ID:5FGxeo64
何の言語か知らんけど、構造体とかクラスで使えば良いのでは?
取り敢えず一度取得してきたデータは使いまわすのが基本
その都度発行とか有り得んから、使いまわせるように工夫すべき
0024デフォルトの名無しさん2017/12/17(日) 13:31:30.67ID:qopiqGcR
えー
せっかくDB側でSQLキャッシュしてくれる機能もってんのに
プログラムでもまたキャッシュの仕組みつくるん?
0026デフォルトの名無しさん2017/12/21(木) 21:57:46.42ID:URpfxR/O
そんなの使い方に依るでしょ
SQLiteのが遥かに適してるのにネットワーク型拵えてるアンチパターンはかなり見るが
この逆は滅多に見ない、SQLiteは玩具過ぎて使えないと言ってる使えない人間はかなり居る
0028デフォルトの名無しさん2018/01/28(日) 14:32:23.14ID:Erw8GBm0
AccessでのVBAの開発の話なんだが、他言語含めて飽きるほどコード書いてきたという人がSQLで書くようなことはしないと言うんだ。
デザインビューでクエリー作るんだって。
俺とは余りに文化が違うんだが、これって俺がおかしいのかな。
それとも彼がビックマウスなのかどっちだと思う?
0029デフォルトの名無しさん2018/01/28(日) 15:54:33.89ID:BfkgINY1
Accessは知らんが。

これ見る限り、そのやり方もありだろう。
https://www.microsoft.com/japan/office/previous/xp/suminaka/access/sousa/1/sousa1_15_2_honbun.htm
http://www.microsoft-access.net/start/query-2.html

> 俺とは余りに文化が違うんだが、これって俺がおかしいのかな。
> それとも彼がビックマウスなのかどっちだと思う?
お前がおかしいことは確定だが、(ただしお前が言っている意味ではない)
彼がビッグマウスかというのは意味が分からない。(だからお前はおかしい)

そもそも、やり方は一つじゃない。どっちが正しいという考え方がおかしい。
そいつにとって効率がいい方法を使えばいいだけ。
この画面通りに動くのなら、クエリ結果画面を見ながらGUIでプログラミングできる。
手打ちでSQL書いて動かしてデバッグするより早いのは確かだよ。

同様な物に、VSのフォームデザイナがある。
さすがにあれを全部手打ちする奴はいないと思うが、技術的には出来る。
あれは毎回Form1.hをパースして表示しているだけだから。
ただしパーサは自動出力の結果を読み込む前提で全くロバストではないから、
少しでもエラーがあったら止まってしまい、それ以降デザイナが使えなくなる。
だから手打ちは推奨されていない。とはいえ、出来る。
0030デフォルトの名無しさん2018/01/28(日) 15:55:43.16ID:BfkgINY1
以下は推測になるが、、、
おそらくAccessも同様に、自動作成クエリを読み込んで表示するようになっていると思われる。
その場合、手打ちでクエリを作成されると、そこでエラーが発生した場合、クエリデザイナが使えなくなってしまう。
だから、プロジェクトとして、「クエリデザイナしか使うな」みたいな縛りはあり得る。
局所的に手打ちでクエリ書いたとして、そこがデザイナ側に読み込まれないのならエラーにはなりようもないが、
後の人が手打ちでクエリを書けない人ならメンテナンスが出来なくなってしまう。

ただし、デザイナに頼りすぎると後々色々大変になるので、
中にはデザイナは最低限しか使うな、という人もいる。
フォームの場合は「イベントをデザイナで書くな」みたいになるわけだが、
Accessの場合は「クエリをデザイナで書くな」になるんじゃないかな?

だから、そこはやり方の問題だ。
どっちが正しいかではなく、どちらを選ぶかだ。当然、チームの他の人員のスキルも考慮しないといけない。
Accessの場合にどちらが主流派なのかは俺は知らない。

ただな、SQLってのはDB用アセンブラみたいなもので、
実際、そんな物をいちいち手打ちしてたら効率は上がらないだろ。
SQLは未来永劫手で書くものだ、と思っているのならお前がおかしい。
(俺は使ったこと無いが)ORMはそこを完全に隠蔽していて、SQLなんて当然自動生成で、
プログラマがいちいち書くはずもないだろ。(現実にはそうでもないらしいが、少なくともそこを目指しているだろ)
ただし、スキルとしては当然読めた方がいいし、手でも書ける人が手抜きする為にデザイナを使うのが本来は正しい。
だから君の立ち位置は間違ってはいない。
君はデザイナを覚えて、君のプロジェクトではどちらを使うか判断すればいいだけ。
既にあるプロジェクトに参加するなら、そのプロジェクトの流儀に従うしかない。

繰り返すが、俺はAccess知らないから、Accessの文化については他の人を待て。
0032デフォルトの名無しさん2018/05/22(火) 02:42:52.45ID:BxsxaQQf
>>21
サブクエリにして別名つければ
0033デフォルトの名無しさん2018/05/23(水) 11:08:43.69ID:+HKSXK/9
>>32
解決しました。ありがとうございました。
ところでミックさんの本は名著だと思いますが、セルコを読んでみたら、むちゃくちゃわかりやすくて驚きました。
プログラミングの本は洋書に限るという主張はかなり当たっていますね。
0034デフォルトの名無しさん2018/05/24(木) 01:57:22.85ID:UTbVU3sw
日本語でもあれだけの容量を割ければわかりやすく書けるのでは。
日本語の技術書って2000部出ればヒットの部類だって言うし
国産で6000円の本がどれだけ売れるやら(=コストがかけられるか)
楽器の教則とかも似た感じだが
勢い初心者向けの入門書が多くなり、レベルの高い本はページ数が足らなくて
分かる人だけ分かってとか分かってる人が知識の確認に使う本が多い気がする

個人的には洋書(の翻訳)は
「もうxxでxxする必要はないのです!」
みたいな無駄な例えとかジョークが多くてちょっとイラっとする時がある
0035デフォルトの名無しさん2018/05/24(木) 21:00:50.73ID:tj3fGZUH
SQLで超高速スクロールシューティングゲームを作りたいのですがどこから勉強したらいいのかわかりません
0038デフォルトの名無しさん2018/05/31(木) 05:05:26.67ID:iPLFO8dU
SQLの勉強をした後に普通の手続き型言語の勉強をすると楽ちんさに驚く。SQLは難しいわ。
0039デフォルトの名無しさん2018/06/05(火) 09:59:14.61ID:tY+4OZF+
ミック氏の著書にある「WHERE句で分岐させるのは素人、
プロはSELECT句で分岐させる」を職場で実践したら異常
者扱いされて追放されたよ
0041デフォルトの名無しさん2018/06/06(水) 22:27:26.69ID:R4gO35f9
[tbl]
key
-----
A
B
C
D
こんなテーブルがあって、
SELECT key
FROM tbl
ORDER BY CASE WHEN key = 'B' THEN 1
WHEN key = 'A' THEN 2
WHEN key = 'D' THEN 3
WHEN key = 'C' THEN 4
END;
このSQL文で並べ替えができるのはなぜでしょうか?
0044デフォルトの名無しさん2018/06/19(火) 19:15:35.13ID:67yeiw0t
n+1問題ってなんやねん

パフォーマンス低下したら何がいけないの?
0045デフォルトの名無しさん2018/07/04(水) 22:30:30.92ID:gFgZc5FG
KOC
0046デフォルトの名無しさん2018/07/27(金) 09:24:44.45ID:kjOumEVE
文字列を追記するにはどうすると良いのでしょう?
これだと上書きされてしまいます。
どうすると良いのでしょう?

$sql = 'update imglistdb set mcategory = ? where id = ?';
$stmt = $dbh->prepare($sql);
$flag = $stmt->execute(array($w, $id));

if ($flag){
print('データの更新に成功しました<br>');
}else{
print($id.'のデータの更新に失敗しました<br>');
}
0048デフォルトの名無しさん2018/08/10(金) 14:51:46.21ID:Y0WYl7hO
サマータイムが導入されたとしてUTCで時刻が記録されてテーブルで
今日の分の売り上げを集計する場合どうするのが正しいですか?
0050デフォルトの名無しさん2018/08/24(金) 09:10:24.90ID:AhUX2VuR
SQLの構文ってなんであんなクソだらけなものが採用され続けているの?

insertのintoとかupdateのsetとかいらないし
updateでwhereを指定し忘れたら全レコードが更新されるのとか超危険だし
updateはID指定→値指定で更新っていうのが直感的にやりやすいのに
whereを最後に持ってこないといけない仕様のせいでid指定が最後になるし
カラムと値の指定の仕方も一貫性がないし

後方互換性としてあれらのコマンド"も"使えるならまだわかるけど
あれらのコマンド"しか"使えないとかこの業界頭おかしいんじゃないの
0051デフォルトの名無しさん2018/08/24(金) 10:46:30.87ID:h+5y0En0
言いたい事は分かるし別に否定はしないのだが、糞でも広まって使われてる以上それに従わざるを得ないのさ
JSと一緒だよ
0052デフォルトの名無しさん2018/08/24(金) 11:18:46.54ID:Gecec4UJ
フェールセーフの仕組みはインターフェースの実装レベルでなんとかしてねってことなんじゃないの
0053デフォルトの名無しさん2018/09/15(土) 19:10:17.26ID:crViL/AR
データの持たせ方を誤ってしまって、
カラム定義
時間,val1,val2,val3・・・
ってなってるんですが、val1からvalnで最大値を取りたい場合、どのようにアプローチするのがスマートですか?
0054デフォルトの名無しさん2018/09/15(土) 20:19:51.77ID:KIanXBkQ
時間がユニークじゃないどうしようもない状態なら
とりあえずコレでいけるハズ

select
 max(ahox.time_),
 max(ahox.max_val)
from
 (
  select rowid, time_, val1 as max_val from aho
  union all
  select rowid, time_, val2 as max_val from aho
  union all
  select rowid, time_, val3 as max_val from aho
  ...
 ) ahox
group by
 rowid

時間がユニークならrowid(DBMSが内部的にテーブルにもたせてる行の識別値)みたいなもんは使う必要ない
使う必要があるならrowidはDBMSごとに違うからあとは調べなさい
0055デフォルトの名無しさん2018/09/15(土) 20:37:41.73ID:KIanXBkQ
運用方法のアプローチとしては
とりあえず一回全抽出してテーブルを作り直したほうがいい
こんな感じのワークテーブルをマニュアル作業で一旦作る

 id, eventno, 時刻, 項目名, 値

eventnoの部分にはとりあえずrowidつっこんどく
で、idはただのシリアル値

システムがこの形式のテーブルに落とせる運用にすれば
それからはすぐに最大値がとれるようになる
そうなるまで毎回ワークテーブル作って最大値とるようにすればいい

それまではマニュアル作業で自分でテーブルをつくりなおす
失敗したヤツがちゃんと責任もってやるようにな
0056デフォルトの名無しさん2018/09/15(土) 22:24:53.50ID:VdLZkjGs
エクセルの行列を、そのまま表定義にする、馬鹿が多い

列に製品番号があれば、列1・列2・列3 と定義しよる。
それで製品番号が増えるたびに、列を増やしていくw

頭おかしいw
0057デフォルトの名無しさん2018/09/15(土) 22:31:40.71ID:crViL/AR
>>54
>>55
お二人共、ありがとうございます。
テーブル再定義も含め、まずは54さんの手法でこの場は凌いでみます。
0058デフォルトの名無しさん2018/09/15(土) 22:37:05.98ID:crViL/AR
>>57
同一IDだた。いずれにしてもサンキューです。
0060デフォルトの名無しさん2018/09/22(土) 16:25:45.44ID:/Du2bEHB
DBの検索速度ってPC上ではかなり遅いみたいですけど
大手Webサービスはどこも一瞬で結果を返してくれますよね
あれは単にサーバーのスペックが凄いから早いんですか?
0061デフォルトの名無しさん2018/09/22(土) 20:22:55.42ID:U3p59MUv
>>60
「DBの検索速度ってPC上ではかなり遅いみたい」
この前提がまずよくわからんが
オンメモリやらキャッシュやら高速ネットワークやら
みんな色々工夫してるから
0062デフォルトの名無しさん2018/10/23(火) 15:14:05.50ID:IWYLnZUh
初心者です。もしよろしかったら質問させてください。
CASE文

SELECT TAB1,TAB2,
 CASE
  WHEN TAB2<1000 THEN 'SMALL'
  WHEN TAB2>1000 THEN 'BIG'
  ELSE 'ERR'
 END AS SIZE
 FROM TABLE
WHERE TAB2>0

というコードなのですが、TAB1のように、CASE文で使用しないカラムをSELECTするのは何故なのでしょう?
0063デフォルトの名無しさん2018/10/23(火) 23:04:42.87ID:+Sb0MP+K
TAB1の値がほしいから
いらないなら書く必要すらない
0065デフォルトの名無しさん2018/10/24(水) 13:40:18.23ID:AfSv/oYJ
ありがとうございました。
すっきりしました。
SELECT文は新しテーブルを作るのではなくて
見やすいように表型に情報を表示してるだけなのですね
0066デフォルトの名無しさん2018/10/24(水) 22:54:40.93ID:WtQFT3Lb
いや概念的には表を作ってる
表から表を作ってる

そういった理解がないとSQLは理解できない

その表からまた別の表を作るのにも利用できる
0068デフォルトの名無しさん2018/11/03(土) 11:37:09.06ID:3nMVWrto
テーブル名:RUN_TIME

KEY | COL | DEF_TIME | UPD_FLG
AAA | BBB | 2017-01-01 08:54:21 | NULL
AAA | CCC | 2017-01-01 08:58:31 | NULL
AAA | DDD | 2017-01-01 09:04:25 | NULL
CCC | XXX | 2017-01-02 08:57:46 | NULL
CCC | ZZZ | 2017-01-02 08:59:26 | NULL
CCC | BBB | 2017-01-02 09:05:03 | NULL


というデータが毎日朝9時付近何件かあって、
その日の08:58:00〜09:02:00の間に含まれるレコードのUPD_FLGに'Y'を入れたいのですが
どういうUpdate文を書けば良いんでしょうか

update RUN_TIME set UPD_FLG='Y'
where DEF_TIME >= ??? and DEF_TIME <= ????

というようなSQLになるんだと思うのですが…。
0069デフォルトの名無しさん2018/11/03(土) 11:52:19.27ID:3nMVWrto
調べたところ、

where DEF_TIME >= DATE_ADD(DATE(DEF_TIME),INTERVAL 538 MINUTE) and
DEF_TIME <= DATE_ADD(DATE(DEF_TIME),INTERVAL 542 MINUTE);

で行けたのですが、これって一般的なやり方でしょうか?
0070デフォルトの名無しさん2018/11/03(土) 15:38:32.68ID:rSl2Ac3O
オレなら普通に DEF_TIME を時分秒の文字列に変換してから比較する
時分固定でその日に該当する年月日時分をいちいち組み立てようとは思わない
0071デフォルトの名無しさん2018/11/04(日) 13:01:05.98ID:mRQV89co
日付まわりはDBによって違いがあるからなんとも言えんが、こんな可読性も実行効率も悪いSQL書いてたら説教ものだな
0073デフォルトの名無しさん2018/11/27(火) 18:25:45.02ID:2K5MWtLk
他人が書いたSQLでこんなのや
select T1.*
from T1 left outer join ON T1.aaa = T2.aaa

こんなのがあるんだけど
select X2.*
from X1 left outer join ON X1.aaa = X2.aaa


外部結合してるのに片方のテーブルのフィールドしか抽出してない
SQLが散見してるんだけどこれって全く外部結合する意味ないよな
意味不明すぎてイラッとしてきた
0074デフォルトの名無しさん2018/11/27(火) 18:43:21.08ID:DSo9/Qg/
T1.aaa = T2.aaa

これは、両方の表にあるものだけを取り出す。
片方の表だけにあるものは取り出さない
0075デフォルトの名無しさん2018/11/27(火) 18:47:04.05ID:2K5MWtLk
言いたいこともわからんのかw
過疎だしここもレベル低すぎてダメだな
0077デフォルトの名無しさん2018/11/27(火) 19:47:50.54ID:PufIRrup
ID:2K5MWtLk
小さいことにイライラしてるわいきなりキレだすわ気持ち悪っw
0078デフォルトの名無しさん2018/11/27(火) 20:13:38.58ID:2K5MWtLk
0.01_もキレてないけどね
このスレは初めて見て初めて書き込んだけど
こっちの言いたいことも理解できないパープリンしかいないうえに
二言目が人格攻撃とかレベル低すぎて俺にはもう無理だわw
低能
0079デフォルトの名無しさん2018/11/27(火) 20:41:37.76ID:JHhXTC3j
joinしてるテーブルとか書いてないし、ちゃんとSQL全部見て言ってるのかあやしいな

抽出してなくてもwhereとかで使ってれば意味はあるぞ
0080デフォルトの名無しさん2018/11/27(火) 20:44:19.89ID:ysmS7zNS
左外部結合だからT1のレコードは全部取り出される。
で、T1にあるフィールドしか取り出さないからT1そのものと一緒だな。

単に間違いか、以前はT2のフィールドも取り出してたけど編集を繰り返してる内にT2のフィールドが要らなくなってしかもT1そのもので良いことに気付いて無いとかかな。
0081デフォルトの名無しさん2018/11/27(火) 21:08:12.03ID:dtVd+WAB
一緒にはならないよ。T2のaaaが複数あるならそれだけ同じものが出てくるよ。
0084デフォルトの名無しさん2018/11/27(火) 21:44:13.52ID:7ygBETe/
データパターンでわざと増幅させたい場合はありだな

意味がないならきちんとテストして取り除けばいいだけじゃん
0085デフォルトの名無しさん2018/11/27(火) 21:50:57.15ID:dtVd+WAB
>>83だから、>>73に挙げられた情報だけじゃ判断できないよ
例えばT2がT1を色々加工した結果で、既にT2の値を外部に持ってて、それと突き合わせて比較したいためのSQLとか、かもしれない
想像するだけ無駄なので、仕事なら知ってる人を探しに行く方が良い

けど、特に何の効果も無いと結論づけるのだけは間違ってるよ。T2.aaaにunique制約があるかも分からないのだから
0086デフォルトの名無しさん2018/12/11(火) 22:34:22.95ID:0Fe3pinh
抽象化の機能が殆どなくて、クエリのいたるところににコピペが必要な部分が出てきて、アセンブリのような扱いになっているSQLに、未来はあるのでしょうか?
仕事で他人の書いたSQLが読み解けなくて、達人に学ぶ SQL徹底指南書を読んでいるんだけど、
「豪快に GROUP BY句にも SELECT句の CASE式をコピーしてやるのがポイントです」とか身の毛もよだつ文章で既に萎えつつあります
0087デフォルトの名無しさん2018/12/11(火) 23:14:47.15ID:j8P28cRB
>>86
SQL専門家ではなく、プログラマだが。

SQL自体は残ると思うよ。DB弄るのにはあれくらいがいい。
そもそもSQLを「手で打つ」事はあり得ないでしょ。普通はプログラミング言語経由だ。
だから抽象化したければプログラミング言語で出来るし、それで十分だ。

SQL自体に抽象化を持ち込むのは、俺は反対だね。
それはSQLでプログラミングすることに繋がっていくが、
現時点ですでにDB側にロジックを持ち込むのはろくな事にならない、ってことになってるだろ。
ある意味、プログラミング言語はロジックを記述する為に出来ているわけで、当然の話だが。
(ロジックを記述するならSQLよりプログラミング言語の方が断然いい)

それ以前に、そもそも、SQLを手で書く事がなくなりつつあるだろ。
物によってはクエリデザイナもあるし、フレームワーク等を導入した場合、隠蔽されたりする。
この意味で、SQL自体を学ぶ必要があるかは、微妙になりつつあるが。
とはいえ、
> 仕事で他人の書いたSQLが読み解けなくて
なら、リファクタするにしても読み解けるようになるまでは学ぶしかないが。

SQL自体が原始的なのは文句を言ってもしょうがないだろ。
事実として規格は古いし、DB向けのアセンブラなんだし。
0091デフォルトの名無しさん2019/01/22(火) 06:30:06.30ID:PjxX9ixQ
CASE文のみで2番目に高い値を取得する方法はありますか?
groupbyなどは使えない制約下とさせてください。
0094デフォルトの名無しさん2019/02/16(土) 23:27:10.19ID:CD9VXZwW
SOQLってどうですか?
自由にJOIN出来ないってどうなのよって思うんですが。
0095デフォルトの名無しさん2019/04/14(日) 21:36:53.40ID:KKPn+v5/
SQLとMySQLの違いというか、関係ってどういう関係ですか?
MySQLがSQLの拡張?
0096デフォルトの名無しさん2019/04/14(日) 21:53:01.78ID:IovzG98E
C言語とgccの関係
0098デフォルトの名無しさん2019/04/14(日) 23:36:59.84ID:NCCiDrpj
SQLは言語
MySQLは製品名、SQLでデータ操作ができる
0099デフォルトの名無しさん2019/05/17(金) 10:15:36.61ID:nnDIZl0o
PythonでSQLiteのデータを更新中にコミットしないままプログラムが強制終了してしまった事があって
DBファイルが開けなくなったことがあったんですけど(それはバックアップを使って復帰させたんですけど)
もしバックアップを取ってなかった場合、どうやって復帰させればいいんでしょうか
-journalというファイルが残っているのでこれを使うのは予想できるのですが…
0100デフォルトの名無しさん2019/07/11(木) 08:12:00.70ID:4eXCjsM2
Webの情報をSQLiteに書き込む処理は概ね慣れてきたんですけど
書き込んだ情報を見やすく表示したり、表示中の情報をクリックして関連項目を検索したり、
データを手動で書き換えたりするには
phpとhtmlを勉強して1からDB表示・操作システムを作るしかないんでしょうか?
0101デフォルトの名無しさん2019/09/06(金) 01:19:58.95ID:vAzRz7Qo
VScodeでMYSQL使いたいのですが、サーバ名がわかりません。
どなたか教えてください。
0102デフォルトの名無しさん2019/12/03(火) 08:25:14.69ID:OVxjKMFy
SQL初心者向けの書籍は何をまず読めばいいでしょうか?
0103デフォルトの名無しさん2019/12/04(水) 02:33:43.32ID:qrz+g/1U
>>102
朝井淳さん
谷尻かおりさん
ミックさん

この辺の入門書を読んでおけばおk
0104デフォルトの名無しさん2019/12/04(水) 05:09:58.36ID:yxtCj8pw
>>103
イラストで理解 SQLはじめて入門
朝井淳さん
スッキリわかるSQL入門第2版
中山清喬さん、飯田理恵子さん、フレアリンク監修

の2冊買ってきました。

谷尻さんとミックさんの本、後ほど確認してみたいと思います。
0105デフォルトの名無しさん2019/12/04(水) 19:50:18.74ID:teYzVY+x
SQLは大学で習ったが、その時はどんな用途で使うのかさっぱりわからんかったわ。
0106デフォルトの名無しさん2019/12/07(土) 16:20:20.48ID:y8T8hHHg
SQL徹底指南第2版誰かmercariで安くで出品してよー
0107デフォルトの名無しさん2020/12/17(木) 13:35:51.43ID:rhbff53i
MySQLで時間を管理し、一定時間過ぎたら、
レコードをの情報を更新したいのですが、
どの様にすればできるか教えてください。

1. このようなことがMySQL単体で可能なことなのかな?
2. 可能な場合どのようにすれば実現できるの?

イメージとしてはこんな感じです。

開始時のレコード001
ID, 開始 , 終了
001, 13:00 , 13:30 ← 13:00に開始

↓ 30分経過後(同一レコードの動き(自動更新))

終了時のレコード001
ID, 開始 , 終了
001, 0 , 0 ← 13:30になったからクリア
0108デフォルトの名無しさん2020/12/17(木) 15:15:58.94ID:hWtMYtoG
>>107
定期的にスケジュールテーブルをチェックするイベント作ればできるよ
あと開始/終了時刻をクリアするよりもステータスを別のカラムに持たせたほうがいい
https://dev.mysql.com/doc/refman/8.0/en/create-event.html

リファレンス読んで分からないことがあればここじゃなくMySQLスレへどうぞ
https://mevius.5ch.net/test/read.cgi/db/1499949595/
0109デフォルトの名無しさん2020/12/17(木) 15:26:22.80ID:rhbff53i
>>108
ありがとうございます。
定期的にチェックするイベントですね。
試してみます。

今後はMySQLで聞きます。
https://mevius.5ch.net/test/read.cgi/db/1499949595/

(^人^)ありがとうございます。
0110デフォルトの名無しさん2021/01/18(月) 10:34:21.91ID:+C2vxlND
XreaやSAKURAなどのMySQLは、ネットからデータを閲覧したりダウンロード
できるようになっているんだけど、あのコントロールはどのCGIでやってる?
WindowsマシンにMySQLをインストールした場合、同様にデータベースの
中身を見るのはどうしたらいい?
0111デフォルトの名無しさん2021/01/18(月) 11:57:48.25ID:JT9EgKXH
たいていのアプリ・サービスは、サーバー/クライアント方式

Linux のシステム内で動いているものは、サーバーで、
それに、Windows などのパソコンからアクセスするものは、クライアント

例えば、AWS なら、AWS Command Line Interface(AWS CLI)みたいなものを、
Windows パソコンに入れて、それでサーバーにアクセスする

MySQL 用のクライアントも探してみれば?
0112デフォルトの名無しさん2021/01/18(月) 13:17:29.49ID:+C2vxlND
>>111
うーんと、Xreaなどのレンタルサーバーを借りると予めMySQLがインストール
されていて、確か、管理画面などからMySQLのデータベースの中に入っている
データを、普通のパソコンのブラウザからリモートで見られるようになっている。
それは、なんという名前のCGIを使っているか教えて欲しい。
01131112021/01/18(月) 13:48:11.67ID:JT9EgKXH
例えば、AWS なら、AWS Command Line Interface(AWS CLI)みたいなものを、
自分のWindows パソコンに入れて、それでサーバーにアクセスする

たぶん、Xrea, SAKURA でも、
Xrea CLI, SAKURA CLI みたいな同様のツールがあるのじゃないの?

そのサービス事業者に聞いてみれば?
0115デフォルトの名無しさん2021/01/19(火) 00:28:07.43ID:hiZmhE+d
>>114
なるほど。さんくす。
ついでに、Rubyでユーザー登録や認証をした結果をMySQLの中に
データとして貯めるようなサーバーサイドのCGIのライブラリ
みたいなものは有る?
0116デフォルトの名無しさん2021/01/19(火) 00:45:19.71ID:sryyIgAN
>>115
Rubyなんぞ知らんし、何をやりたいのかもよくわからんから、Rubyスレで訊け
認証用のフレームワークに何を選ぶかって話で、SQLは直接関係ない
0117デフォルトの名無しさん2021/01/19(火) 00:47:54.79ID:hiZmhE+d
Ruby on Rails の devise という「gem」が、パスワードを入力したり
メールを送って登録するようなよくある認証パターンをやってくれて、
MySQLも使ってるそうだけど、Ruby on Rails使ったことないし、
登録した MySQL のデータを上手く扱えるか不安。
0118デフォルトの名無しさん2021/02/08(月) 13:32:01.05ID:0mrKmB9v
テーブル名にバインド変数使う事って出来ないの?
"CREATE TABLE IF NOT EXISTS ? (...);"
といった感じでテーブル名は後付けでバインドしたいんだけどsqlite3_prepare_v2が失敗する
0120デフォルトの名無しさん2021/02/08(月) 16:39:30.22ID:KTkq0eI8
SQL ServerとOracleとDb2の3間を変換してくれるアプリとかありませんか?
0121デフォルトの名無しさん2021/02/09(火) 22:59:40.19ID:62IhLHy8
質問スレ過疎ってたからこっちか


専ブラBB2Cでワッチョイを正規表現でNGしたいんだけどうまくいかない
第2オクテット(仮にXXとして)だけ固定でこれじゃダメだろうか
.*XX-.*
0122デフォルトの名無しさん2021/02/10(水) 14:33:47.60ID:n+lQ6bEt
sqlite3_blob_openで得た列ハンドルをsqlite3_reopen_blobで使いまわすとクエリ投げるより5倍近く高速だと判明したが
nullセルやrowが見つからないとハンドル失効しちゃってopenし直さないといけないんだな
open自体はそれなりに重いから失効が多いとパフォーマンス上の利点はほとんど無しか
0123デフォルトの名無しさん2021/02/13(土) 18:50:09.35ID:k+FkZinH
データベース板を忘れないでください
0124デフォルトの名無しさん2021/05/21(金) 10:11:21.48ID:bGYKMPx3
2万レコードのテーブルの全行をそれぞれupdateで値を変更したいんだが、これってforでSELECTを2万回繰り返したりしたらまずいもんなの?

レンタルサーバー使ってるんだが
0127デフォルトの名無しさん2021/07/10(土) 13:35:16.95ID:0S1tAkGn
一個前のidからカラム取ってくることはできますか?
0128デフォルトの名無しさん2021/07/10(土) 14:09:51.57ID:1/iYafxq
前とか後とかいう概念が、、、というのは置いといて
自分のidより小さいidの最大が該当のidだろ
あとはサブクエリなりwindow関数なりでとってこい
0129デフォルトの名無しさん2021/07/13(火) 23:04:11.03ID:oBbbWw6W
出来たわ!ありがとう
0131デフォルトの名無しさん2021/10/15(金) 22:03:31.28ID:atwiHSUT
レコードのデータが
AAA  1
AAA 2
BBB 3
BBB 4
BBB 5
CCC 6
CCC 7
AAA 8
AAA 9
BBB 10
BBB 11
ってなってるデータから
AAA 1
BBB 3
CCC 6
AAA 8
BBB 10
みたいなデータに変換したいのですがやる方法ってありますか
0133デフォルトの名無しさん2021/10/16(土) 08:56:30.04ID:vbkw9O81
どういうルールで変換するのか書かないで丸投げされてもな。
というかそれを自分で考えないからわかんないんだろう。
0134デフォルトの名無しさん2021/10/16(土) 09:46:40.94ID:BnnoSLdm
>>131
因果関係が逆。
それが宿題なら問題が糞だからやらなくていいし、学校を変えるべき。
0136デフォルトの名無しさん2021/10/17(日) 10:18:00.58ID:O7pSNP76
すまん 俺が悪かった。
みんなありがとう


例えば、下記の時系列データがあったときに、nameごとにまとめたものを別のテーブルに入れたいんだよね。
nameがはまとめたときに、IDがもっとも若いものを格納したい。
SQLで一発取れたりするかな?
ロジックを考える必要ある?

ID(PK)  name value
1 AAA 1
2 AAA 3
3 BBB 5
4 BBB 2
5 BBB 4
6 CCC 1
7 CCC 3
8 AAA 1
9 AAA 2
10 CCC 3
11 CCC 4



ID(PK)  name value
1 AAA 1
3 BBB 5
6 CCC 1
8 AAA 1
10 CCC 3
0137デフォルトの名無しさん2021/10/17(日) 10:20:12.93ID:O7pSNP76
>>135
がやってくれたことがまさにやりたいことだわ
くわしくありがと
0138デフォルトの名無しさん2021/10/23(土) 10:22:47.90ID:D86LbS/L
時刻昇順に並んでるデータでstatusが1〜4を一塊として
縦横変換したテーブルが欲しいんですけどSQLだけじゃムリですかね。
欲しいテーブルにあるrep_idは元のテーブルにない(生成したい)です。

元のテーブル
time    status
10/1 0:01  1
10/1 1:34  2
10/1 2:00  4
10/1 22:00 2
10/1 23:32 3
10/2 1:02  4

欲しいテーブル
rep_id| status_1  | status_2   | status_3  | status_4
-----+----------+-----------+----------+--------
1   |10/1 0:01  | 10/1 1:34  | null     | 10/1 2:00
2   |null     | 10/1 23:00 | 10/1 23:32 | 10/2 1:02
0139デフォルトの名無しさん2021/10/23(土) 10:32:24.95ID:D86LbS/L
時刻昇順に並んでるデータでstatusが1〜4を一塊として
縦横変換したテーブルが欲しいんですけどSQLだけじゃムリですかね。
欲しいテーブルにあるrep_idは元のテーブルにない(生成したい)です。

元のテーブル
time    status
10/1 0:01  1
10/1 1:34  2
10/1 2:00  4
10/1 22:00 2
10/1 23:32 3
10/2 1:02  4
10/2 4:05  4
10/3 18:30 2
10/3 20:34 2

欲しいテーブル
rep_id| status_1  | status_2   | status_3  | status_4
-----+----------+-----------+----------+--------
1   |10/1 0:01  | 10/1 1:34  | null     | 10/1 2:00
2   |null     | 10/1 23:00 | 10/1 23:32 | 10/2 1:02
3   |null     | null     | null     | 10/2 4:05
4   |null     | 10/3 18:30 | null     | null
5   |null     | 10/3 20:34 | null     | null
0140デフォルトの名無しさん2021/10/24(日) 00:25:59.14ID:4lHZz/Ub
SQLだけでやってみた
WITH
ブレークチェック AS (
SELECT
CASE WHEN LAG(status,1,NULL) OVER (ORDER BY [time]) < status
THEN 0
ELSE 1
END AS st,
[time]
FROM 元のテーブル),
開始終了 AS (
SELECT
[time],
(SELECT MIN([time]) FROM ブレークチェック WHERE st = 1 AND [time] > t.[time]) AS end_time
FROM ブレークチェック t
WHERE st = 1),
t1 AS (SELECT [time] FROM 元のテーブル WHERE [status] = 1),
t2 AS (SELECT [time] FROM 元のテーブル WHERE [status] = 2),
t3 AS (SELECT [time] FROM 元のテーブル WHERE [status] = 3),
t4 AS (SELECT [time] FROM 元のテーブル WHERE [status] = 4)
SELECT ROW_NUMBER() OVER (ORDER BY 開始終了.[time]) AS rep_id,
t1.[time] AS status_1,
t2.[time] AS status_2,
t3.[time] AS status_3,
t4.[time] AS status_4
FROM 開始終了
LEFT JOIN t1 ON t1.[time] >= 開始終了.[time] AND (t1.[time] < 開始終了.[end_time] OR 開始終了.end_time IS NULL)
LEFT JOIN t2 ON t2.[time] >= 開始終了.[time] AND (t2.[time] < 開始終了.[end_time] OR 開始終了.end_time IS NULL)
LEFT JOIN t3 ON t3.[time] >= 開始終了.[time] AND (t3.[time] < 開始終了.[end_time] OR 開始終了.end_time IS NULL)
LEFT JOIN t4 ON t4.[time] >= 開始終了.[time] AND (t4.[time] < 開始終了.[end_time] OR 開始終了.end_time IS NULL)
素直にループ回すほうがいいな
0141デフォルトの名無しさん2021/10/24(日) 07:39:02.37ID:djVQHxKk
>>140
ありがとうございます。SQLだけでも書けるんですね
足りないstatusを補完できないかとか集計キーを作ってからとか当初の目的と外れたところで発狂してました
0142デフォルトの名無しさん2021/11/06(土) 13:34:50.16ID:ABCltTaS
検索やら削除、CRUDをしたあとに得られるデータの命名に
rowsとかitems、個々はrowやitem
と考えています。
さらに個々rowにはdeleteやupdateのメソッドが使えるよう処理しています
つまり純粋なデータというよりインスタンス化されています
ここで疑問が。
rowという命名がしっくりこない気がします
row.column名やらrow.delete()とかで使う分にはrowで良いと思いますが
rowオブジェクトのクラス名をRowにするのはぴんとこないのです
何かいい命名案はないでしょうか
もうItemでいいかなとも思ってます
0143デフォルトの名無しさん2021/11/06(土) 19:03:36.97ID:zfMx2fqR
Row/Columnは行/列だから表(Table)に対しての名前はフィットしていると思うがな。
気に入らなければRecord/Flieldではどうかな?
0144デフォルトの名無しさん2021/11/07(日) 12:35:47.69ID:X+EdCY7G
ありがとうございます >>143
一括置換しても問題なくいつでも変えられそうなのでとりあえずはRowにしときます
0145デフォルトの名無しさん2021/11/14(日) 11:47:27.97ID:wWg1lz8i
日本全国民テーブルから
年収960万円以下の世帯で、
かつ
18才未満の子供の数。

を抽出するSQLを書いて下さい
0146デフォルトの名無しさん2021/11/14(日) 12:12:19.12ID:DPFsPWqC
>>145
日本人達テーブルには

マイナンバー、世帯主マイナンバー、生年月日、徴収税額

があるものとします。
0147デフォルトの名無しさん2021/11/14(日) 13:47:45.91ID:E00roTgy
電通もしくはぱーそるの人か
0149デフォルトの名無しさん2021/11/14(日) 15:16:56.72ID:mFG9NQD5
>>142
Ruby on Rails のO/R マッパーでは、
命名規約で決まっているから、row みたいな抽象的な名前にならない

テーブル名が複数形のmy_books(snake case)なら、
各行は、単数型のmy_book を使えばよい

クラス名は、MyBooks(Pascal, upper camel)
ファイル名は、my_book.rb
0150デフォルトの名無しさん2021/11/14(日) 16:50:43.91ID:tkHjD9h1
便通はfirewallで5ch禁止してるからな
自宅から業務外で5chに質問描いてたらクビ
0151デフォルトの名無しさん2021/11/25(木) 19:15:00.80ID:zZUF+qfu
selectはそこそこ速いのに(30秒くらいで処理終わる) updateにすると遅くなる(10分以上)要因って何が怪しいかわかる?
抽出条件は全く一緒
0152デフォルトの名無しさん2021/11/25(木) 19:15:06.69ID:zZUF+qfu
selectはそこそこ速いのに(30秒くらいで処理終わる) updateにすると遅くなる(10分以上)要因って何が怪しいかわかる?
抽出条件は全く一緒
0154デフォルトの名無しさん2021/11/25(木) 21:42:40.77ID:rnpiht7q
selectとupdateで経過時間を比較してもあんまり意味ないよ
抽出条件は同じでもupdateは抽出後に1件1件更新処理が必要なんだから
件数が多ければそのくらいの差になっても何も不思議じゃない
0155デフォルトの名無しさん2021/12/24(金) 16:39:20.24ID:unjC7EWw
複数のカラムのどれかに該当文字を含む行を知りたいが、
どのカラムだったかで区別したい時に、一発でやる方法ってある?
具体的には以下(2発)を一発にしたい。

SELECT 0,target FROM sometable WHERE col0 MATCH 'str' UNION SELECT 1,target FROM sometable WHERE col1 MATCH 'str' AND col0 NOT MATCH 'str';

例えば、「どのORに当たったか」を教えてくれるスカラー関数 hitplace() があったとすると、

SELECT hitplace(),target FROM sometable WHERE col0 MATCH 'str' OR col1 MATCH 'str';

に出来るのだけど。
環境はPHP+SQLite。
出力は配列の配列、 [[col0に当たった行],[col1に当たった行]] の形式で、重複はなし。
この形式にサクッと変換出来るのなら、読み出した形式は上記とは違っても可。
0156デフォルトの名無しさん2021/12/24(金) 17:59:49.49ID:cMhJNtck
CASE式使えばできるよ

アプリかDBの設計を見直したほうがいい可能性大
0157デフォルトの名無しさん2021/12/24(金) 19:31:42.64ID:unjC7EWw
お早い回答ありがとう。
もっと色々試すが取り急ぎ。


新案1:
SELECT CASE WHEN col0 LIKE 'str' THEN 0 WHEN col1 LIKE 'str' THEN 1 ELSE -1 END AS col,target FROM sometable WHERE col>=0;
explainでは32、他だと文法エラーらしいがSQLiteだと通る。(参考 https://rainbow-engine.com/sql-howto-caseresult-where/)
explain query plan では
0|0|0|SCAN TABLE tags_bulk VIRTUAL TABLE INDEX 0:

新案2:
SELECT col,target FROM (SELECT CASE WHEN col0 LIKE 'str' THEN 0 WHEN col1 LIKE 'str' THEN 1 ELSE -1 END AS col,* FROM sometable) WHERE col>=0;
他ではこう書けと言われているもの。
explainでは32で、見た目中身も同じ。explain query plan も全く同じ。
0158デフォルトの名無しさん2021/12/24(金) 19:32:06.67ID:unjC7EWw
元:
SELECT 0,target FROM sometable WHERE col0 MATCH 'str' UNION SELECT 1,target FROM sometable WHERE col1 MATCH 'str' AND col0 NOT MATCH 'str';
explainでは同じく32だが、見た目は違う。が、読み方が分からない。
explain query planでは以下。見た目通り2周している。
1|0|0|SCAN TABLE sometable VIRTUAL TABLE INDEX 9:
2|0|0|SCAN TABLE sometable VIRTUAL TABLE INDEX 11:
0|0|0|COMPOUND SUBQUERIES 1 AND 2 USING TEMP B-TREE (UNION)


MATCHはCASEの中では使えないらしくLIKEにしている。
(Error: unable to use function MATCH in the requested contextと出る。)
MATCHだとインデックスが使える分速いはずだが2周する分遅くなるのでどうなるか。

DBやアプリ構造の改善案は今のところ思いつかない。(変更は可能)
カラムはそれぞれ別の管理なので、先に合わせる事は出来ない。
0159デフォルトの名無しさん2021/12/24(金) 21:34:31.41ID:unjC7EWw
新案3: UNION ALL
SELECT 0,target FROM sometable WHERE col0 MATCH 'str' UNION ALL SELECT 1,target FROM sometable WHERE col1 MATCH 'str' AND col0 NOT MATCH 'str';
元はUNIONにB-TREEが必要でこの分無駄だった。
explainは23と軽くなった。explain query plan は以下。
1|0|0|SCAN TABLE sometable VIRTUAL TABLE INDEX 9:
2|0|0|SCAN TABLE sometable VIRTUAL TABLE INDEX 11:
0|0|0|COMPOUND SUBQUERIES 1 AND 2 (UNION ALL)
単発で別々にクエリすればUNION ALL 分も取れるが、単に追加してるだけなのでPHP側で結合するよりは速いはず。


今のところこの辺か。他に何かあればよろしく。
とりあえず実装して試すが、差が出るほどDBの中身が埋まるまでにはだいぶかかるとは思う。
0160デフォルトの名無しさん2021/12/24(金) 21:37:57.02ID:cMhJNtck
>>157
その案はどちらもテーブルスキャンになってインデックス使わない
SELECT句のCASE式とは別にWHERE句に本来の条件を書く

DB構造の話はカラムとして持つべきデータじゃなくて
子テーブルの行として持つべきデータかと思ったんだけど
全文検索でいずれかのカラムに検索キーワードが含まれてる行を
どのカラムかという情報も含めて抽出する用途なんであれば
そのままでいいんじゃないかと思う
0161デフォルトの名無しさん2021/12/24(金) 22:28:50.21ID:unjC7EWw
>>160
> その案はどちらもテーブルスキャンになってインデックス使わない
そうだが、今回はこれで仕様的にも問題ない。


俺が勘違いしてたのもあって言葉が混乱しているが、
SQLiteのFTSは全文検索仕様で、通常のインデックスは作成出来ない。
FTSで「インデックス」と言われてるのは全文検索用のキーワードインデックスで、
つまりMATCHがLIKEに比べて糞速いだけで、常に全row検索する仕様のようだ。
https://sqlite.org/fts3.html
(俺がFTSの「インデックス」をここでもそのままインデックスと表記したのが不味かった。
FTS用のテーブルでは通常のインデックスでの単rowからの検索は出来ない。
《rowidだけは使えるらしいが、使っても explain query plan では scan と表示された》)


> 子テーブルの行として持つべきデータかと思ったんだけど
あーなるほど、勘がいいね。
実は元々そういう構造になっていたのだが、
下部構造のサマリを作ってしまった方が楽だからそうしようとしていて、
col0は上部から与える名前、col1は下部のそれぞれの中身の寄せ集めになってる。
だからcol0を下部構造の各行のcol1相当部分に対して混ぜ込めば、下部構造で一発クエリ出来る。
そして元々そうしていたのだが、他の都合上、管理が面倒なので変更しようとしているところ。
しかしよく分かったね。まあ妙な事をしてるからか?


まあとにかくありがとう。
今回は下部構造のサマリなので、常に全文検索で問題ない。
言葉が混乱しててごめん。
0162デフォルトの名無しさん2021/12/25(土) 19:58:56.64ID:GPUeNtJx
NOT MATCH が使えない。(Error: unable to use function MATCH in the requested context)
ただし動的エラーで、2つ目のクエリでcol1にMATCHの後、col0にNOT MATCHのチェックで落ちるようだ。
CASEの中でも使えないし、やはりMATCHはインデックスのようだ。
ところでMATCH NOTは使える。

新案4: MATCH NOT
SELECT 0,target FROM sometable WHERE col0 MATCH 'str' UNION ALL SELECT 1,target FROM sometable WHERE col1 MATCH 'str -col0:str';
これでexplainは20、explain query plan は以下。
1|0|0|SCAN TABLE sometabke VIRTUAL TABLE INDEX 9:
2|0|0|SCAN TABLE sometable VIRTUAL TABLE INDEX 11:
0|0|0|COMPOUND SUBQUERIES 1 AND 2 (UNION ALL)

当面はこの新案4で行く予定。
0164デフォルトの名無しさん2022/05/28(土) 08:36:34.97ID:2HB62XT0
カーソルって何のために使うの?
0165デフォルトの名無しさん2022/05/28(土) 11:06:08.08ID:81XaDMLN
iteration
0166デフォルトの名無しさん2022/05/28(土) 12:02:17.61ID:WzAPHv6Z
>>164
クライアント側に結果セットを全部抱えなくてもいいのと、クエリが全部終わらなくても出てきたレコードから順に
処理を進められるんで、主に対象のレコードが多いバッチ処理なんかで使う。
0167デフォルトの名無しさん2022/05/28(土) 16:19:02.25ID:63kkWN4T
SQLでDECLARE CURSORと書くサーバーサイドのカーソルと
DBドライバーのAPIが提供するクライアントサイドのカーソルは別のもの

前者はSQLで1行単位の処理をしたい場合に使うものだけどよほど特殊な事情がない限りは使わない

後者はクライアントがクエリの結果セットを塊単位でフェッチするのに使うもので呼び名が違うこともあるが一般的に使われてる

どちらも結果セット内の次の読み込み位置を指し示す抽象オブジェクトとしての役割は同じ
0168デフォルトの名無しさん2022/06/07(火) 20:12:44.49ID:SiB5OW5s
車テーブルがあって
車両番号 走行日 走行距離(出発) 走行距離(到着)  運転手
というカラムがあります。

各車両の現在の走行距離と、今運転手が乗っていれば運転手名が欲しいです。
乗っているという判断は
走行距離(出発)が入ってるけど到着は入ってない、という事になってます。

これってMAX関数で現在の走行距離とるクエリと、運転手データとるクエリとでJOINするしかないですよね?
0170デフォルトの名無しさん2022/06/08(水) 02:38:50.06ID:m+BIRTG0
>>168
普通にCASEで行けそうだけど

現在の走行距離とは何?
運転手が乗ってなければどうしたいの?
0171デフォルトの名無しさん2022/06/08(水) 04:53:57.00ID:8AxfQ9fg
GROUP BYの集計項目以外のカラムの値(運転手等)をサブクエリ使わずに一発でできるかどうかという質問かと思ったが
運転手を表示する場合としない場合の分岐方法の話ならCASE式だね
01721682022/06/08(水) 05:07:53.00ID:reQXGMu0
>>171
そういう意図でした!
caseでもう一度試行錯誤してみます!
01731682022/06/08(水) 05:13:05.52ID:reQXGMu0
>>170
現在の運転手がいなかったらnullにしたいです。
01741682022/06/08(水) 19:01:35.68ID:o/KS6P14
>>168
解決しました!ありがとうございます!
0175デフォルトの名無しさん2022/06/14(火) 14:33:53.86ID:eTPeyH+k
SQL Serverで質問です。

テーブル1
テーブル2
テーブル3
テーブル4

とテーブルはどんどん増えます。

各テーブルにはIDという数値型のフィールドがあるのですが、
テーブル名とIDの最大値の一覧表にしたいです。

INFORMATION_SCHEMAを使ってテーブル名の一覧までは出せたのですが、
それらの各IDの最大値を産出するのはどう書けばいいのでしょうか?
0176デフォルトの名無しさん2022/06/14(火) 15:30:50.28ID:EXjYCut5
>>175
identity columnなら
SELECT IDENT_CURRENT (‘table_name’)かsys.identity_columnsのlast_value
違うなら
SELECT MAX(ID) FROM table_name
0177デフォルトの名無しさん2022/06/14(火) 16:44:05.01ID:eTPeyH+k
>>176 ありがとうございます。

しかしながら

テーブル名 IDの最大値
テーブル1 6
テーブル2 1014
テーブル3 1990
テーブル4 74
テーブル5 1861
テーブル6 136

という感じに表示されてほしいです
0178デフォルトの名無しさん2022/06/15(水) 20:45:45.59ID:W3daPLoz
一つのテーブルに対して、複数のクエリ(参照、更新)が同時に投げられても、テーブルロックされない限り並行して動くものなの?
0179デフォルトの名無しさん2022/06/17(金) 01:53:08.02ID:qX3KJPna
>>178
ロックはテーブルロックだけじゃないし
同時実行できるかはハードやDBMSの機能によるんだが
まあ基本的には複数のコネクションのクエリは並列して動くと考えていいんじゃね
0180デフォルトの名無しさん2022/06/22(水) 21:18:18.43ID:JRkIVgOU
>>177
それなら統計情報を検索すればいい話
0181デフォルトの名無しさん2022/06/29(水) 17:50:51.99ID:EbiKHqB9
全く同じクエリの処理してるのに、時間帯によって波があるのって何が原因かな?
夜中は10秒、朝9時くらいは1時間とかザラにある
しかも、毎日波がある
こんなに気まぐれなの?
0185デフォルトの名無しさん2022/06/29(水) 21:10:29.16ID:RWZIP4V9
10秒と1時間越えで何が原因かあたりもつけられないってかなりヤバない?
0186デフォルトの名無しさん2022/06/29(水) 21:18:34.19ID:zCehF1Jn
マシンのメモリなどの、何かのリソースが少ないのかも

例えばメモリが少ないと、1クリックしてから処理されるまで、1分掛かる。
遅すぎて何もできない
0187デフォルトの名無しさん2022/06/30(木) 16:46:00.43ID:4XQ6AH+7
バラバラな日付が入っているテーブルから、
特定日以前3日間のレコードを取るSQL教えてください

hogeテーブル
id,date
5,2022-06-30
4,2022-06-19
3,2021-12-24
2,2021-06-03
1,2021-01-02

ここから2022-06-19以前の3日間のレコード
2022-06-19
2021-12-24
2021-06-03
を取りたいです
0188デフォルトの名無しさん2022/06/30(木) 17:49:50.05ID:1+oYjPxt
その日付より小さくて、その日付ー3日より大きいっていうwhere条件書くだけだと思うが

日付の扱いはDBMSによって差が大きいからこれ以上はちゃんと環境書け
0189デフォルトの名無しさん2022/06/30(木) 17:56:20.31ID:eK6suSY8
>>187
where date <= ‘2022-06-19’
order by date desc
limit 3;

上から3行取る方法はDBMSによって違うのでマニュアルを読んで
0190デフォルトの名無しさん2022/06/30(木) 18:54:13.55ID:6sehYChL
>>189
ソートしろとは言ってないぞ
0191デフォルトの名無しさん2022/06/30(木) 19:51:26.35ID:4XQ6AH+7
>>188
その日付ー3日は、
日付がバラバラなのでできません

>>189
これでできそうです
ありがとうございます
0192デフォルトの名無しさん2022/06/30(木) 20:18:37.20ID:1+oYjPxt
ああ、三日じゃなくて3件分のデータが欲しいのか
日付にダブりがないなら>>189さんの方法で
ダブりがあるならdistinctなりgroup byなりしてからだな

>>190
ソートしないでできるならぜひその方法を教えてくれ
0193デフォルトの名無しさん2022/06/30(木) 20:29:12.21ID:6sehYChL
>>192
ソートする必要がどこにあるのか?
0194デフォルトの名無しさん2022/06/30(木) 20:31:30.23ID:6sehYChL
3日が3レコードという意味なのかどうかからわからない。
0196デフォルトの名無しさん2022/06/30(木) 22:57:01.80ID:1+oYjPxt
>>195
なるほど。件数がゼロ件になるやつの考慮がいるけど、いけるのはいけそうだな
SELECT * FROM hoge T WHERE
 (SELECT count(*) FROM hoge
  WHERE hoge.[date] >t.date AND hoge.[date]<='2022-06-19'
 ) < 3 AND t.[date]<='2022-06-19'
こんな感じか
これならオフセット取れないとかwindow関数使えないDBとかでも動くな
0197デフォルトの名無しさん2022/06/30(木) 23:12:15.50ID:y+cu0wpZ
>>190
ソートしろと言われているのにソートしないのは問題だが逆に
ソートしろと言われてないのにソートするのは構わんだろ
0198デフォルトの名無しさん2022/07/01(金) 00:36:44.48ID:oYJ8x66X
>>197
無駄なソートはRDBMSによっては致命的な性能問題を引き起こす。
0199デフォルトの名無しさん2022/07/01(金) 03:40:55.11ID:42pyAc9U
>>198
「無駄な」ソートはな
order by 書けば絶対ソートするとでも思ってるんだろうか
つかおまえソートしない方法提示できてないだろ

テーブルスキャン何回もやるぐらいならソート1回のほうがましなことも多いぞ
まあなんにせよインデックス構成とオプティマイザ次第だけどな
0200デフォルトの名無しさん2022/07/01(金) 09:55:27.56ID:g3tdjjPX
TOP/LIMIT/FETCH FIRST + ORDER BY使ったtop-Nクエリが
相関サブクエリ使ったtop-Nクエリより遅くなるようなメジャーなDBMSがあるの?
0201デフォルトの名無しさん2022/07/02(土) 00:59:29.77ID:1zpQKBp2
構文の話をし始めるやつはヤバい
0203デフォルトの名無しさん2022/07/02(土) 19:31:42.58ID:1zpQKBp2
内部の処理の説明をSQLの構文で説明するのは、知識がなさすぎると思うぞ。

少なくとも業務システムでは嫌われる。
0204デフォルトの名無しさん2022/07/02(土) 20:23:17.28ID:MgQFVCuv
構文の話してるヤバい奴ってどれ?

というか、こういうどこに向かって話してるのかわからないようなのもなんかヤバい。
0206デフォルトの名無しさん2022/07/03(日) 12:56:59.34ID:UY7Pdi/e
つかDB板の連中って何でそれが重い処理なのかまるで理解してないよね
しかも呼び出し側含めた全体最適化なんてする気もないようだし、
あいつらはSQLを手打ちでもしてるのだろうか?
0207デフォルトの名無しさん2022/07/03(日) 21:52:19.27ID:3LHO0qyv
まるですでに重いと決まっているかのような物言い。これはヤヴァイ。
0208デフォルトの名無しさん2022/07/03(日) 22:24:10.66ID:UY7Pdi/e
インデックスを張ってる状態での189は間違いなく軽い
DB屋はDBで済ませる傾向があるとは聞くし、
クエリプランナで最高に最適化されてリングバッファ的に動くのなら196も確かに軽いが、
そうならない場合は糞重い

俺はそこまでDBのことは知らないので、
189が第一選択肢で、速度の問題があればインデックスを張る
これで問題がある場合は、自前でカーソルをとってリングバッファを実装する

DB屋なら196がそれぞれのDBで軽いか重いか把握した状態で使うのだとは思う
ただそれは俺らプログラマとはだいぶ視点が違うと感じた
0209デフォルトの名無しさん2022/07/03(日) 23:34:25.47ID:fr0a/itN
ソートの話は相関サブクエリを使えという話じゃなく
指定日以前の任意の3レコードなのか(ソート無し)
指定日以前の直近の3レコードなのか(ソート有り)
という違いを指摘したかったんでしょ
0210デフォルトの名無しさん2022/07/04(月) 01:22:49.55ID:7pHsiooe
それもあるとは思ったが、187だとほぼid通りの順なのだろうし、
191で文句も言ってないので、おそらくログ的な物のラスト3行を取りたいのだろうよ

なら俺は208で言ったとおりにする
(なお俺は189ではない)
それを(実際どうなるのかは知らんが)糞遅くなりそうなSQLを出すのもいかがなものかと

質問者が悪いと言えばそうだが、
質問者のレベル推定も含めての回答にしないと、ここでは成り立たない

「ソートして良い」と勝手に決めるのが問題なら、
「ソートしてはいけない」と勝手に決めるのもまた問題でしかない
なら聞けばいいのに、それもしない
(なお、しても意味は通じず、余計に面倒になるのは見えているので、
今回のようにいきなり189で問題ないとも思うが)
なんというか、この辺の空回り具合は、文化の違いを俺は感じたよ

ただまあ俺らが特殊なのかもしれないけどな
この板では基本的にエスパー出来ないと回答は無理だし
0211デフォルトの名無しさん2022/07/12(火) 22:08:19.53ID:PV1bWVal
SQLで4桁文字列'hhmm'とDatetime型を結合する方法って分かる?

例:
’1234’  char型
’2022/07/12 00:00:000’ datetime型 があったときに、
  ↓
2022/07/12 12:34:000  datetime型 みたいに結合したいんだけど。。
0212デフォルトの名無しさん2022/07/12(火) 23:46:03.19ID:xDQ7ywi9
とりあえず'1234'を12と34の数字にして、元の日付に12時間と34分を足せばいいんじゃねふ

日付まわりはDBMSによって違うから
日付時刻をサポートしてるDBMSなら指定の時間、分を足す関数かなんかがあるだろうからそれ調べて使え
0214デフォルトの名無しさん2022/07/13(水) 16:51:17.49ID:mLEjbAz1
変数設定が抜けておりました
0215デフォルトの名無しさん2022/07/13(水) 20:55:05.36ID:d4+uION0
>>211
関数
0216デフォルトの名無しさん2022/07/15(金) 12:26:52.71ID:GqllWW3Z
>>211
普段、日時の計算をどうやっているのか、むしろ疑問ですね。

古い本でいいから古本を買えよ!
0217デフォルトの名無しさん2022/07/25(月) 21:13:25.51ID:FznTbXtw
複数のselect count(※)を1つのファイルに出力する方法教えてください。。
0218デフォルトの名無しさん2022/07/25(月) 22:10:59.17ID:bIl9FMxT
SQLで急にファイル出力とか言われても何のこっちゃ分からんわ
シェルスクリプトで普通にappendでもしろや
0219デフォルトの名無しさん2022/07/28(木) 20:47:41.93ID:oYIQQ6EM
ネタに反応すんな
0220デフォルトの名無しさん2022/11/10(木) 10:38:00.26ID:5Ugvs3e+
explain analyzeを付けると1秒、付けないと30秒かかるクエリがあるのですが一般的には何が原因なのでしょうか
0221デフォルトの名無しさん2022/11/10(木) 12:15:12.96ID:8Ccihq77
>>220
両方同じようにクエリが実行されてるのなら
結果セットの転送コストがめちゃくちゃ大きいんじゃないの?
0222デフォルトの名無しさん2022/11/17(木) 10:16:58.88ID:gy0rtS5S
SQL Server 2022 正式リリース(米国11/16日)
MSDNダウンロードサイトでDeveloper EditionのISOリリースを確認
0223デフォルトの名無しさん2023/02/12(日) 18:13:43.26ID:fJXtAG7P
phpMyAdmin使ってます。
型が合わないデータの入力があったとき、
拒否するか、無理やりデフォルトの値を登録するか。
それを設定するコンパネとかありますか?
0224デフォルトの名無しさん2023/08/25(金) 10:09:06.20ID:AK+z9ndV
ストアドプロシージャって初心者用解説サイトとかで戻り値のない関数って言われてるけど普通にRETURNできるやん
歴史的な背景でもあるんか
それとも解説者か俺があほなんか
0225デフォルトの名無しさん2023/08/25(金) 14:00:50.18ID:5+gJach+
論理演算が弱すぎる
0226デフォルトの名無しさん2023/08/25(金) 18:18:42.69ID:DhQDvuMa
>>224
一部のDBMSの古いバージョンではOUT/INOUT引数を使わないと値を返せなかったんだよ
0227デフォルトの名無しさん2023/08/30(水) 22:18:57.94ID:+4EyrP3p
>>4
全列nullでも?
0228デフォルトの名無しさん2023/08/31(木) 14:07:47.09ID:nrSGXsFq
>>224
それはファンクション(関数)とストアドプロシージャの違いがあまりないDBMSの場合
0229デフォルトの名無しさん2023/08/31(木) 14:16:19.77ID:nrSGXsFq
ファンクションは戻り値があるプロシージャという意味
0231デフォルトの名無しさん2023/08/31(木) 15:20:59.08ID:nrSGXsFq
元はユーザー定義関数
0232デフォルトの名無しさん2023/08/31(木) 15:26:10.21ID:nrSGXsFq
VBもAda言語もそうだけど、ファンクションプロシージャとサブプロシージャをわけているのは、プログラミング言語ではめずらしくない。

C言語、C言語に影響を受けた言語だと、わざわざ戻り値なしをvoidと書いて明確にする。

ファンクションは戻り値を利用するもの。戻り値を呼び出し側が無視できる仕様かどうかの問題。
0233デフォルトの名無しさん2023/08/31(木) 16:29:25.54ID:JttiXEFt
SQL標準的にはプロシージャに戻り値があるかどうかはimplementation defined
戻り値があったほうが便利なので多くのDBMSベンダーはscalar valueとresult setのどちらも返せるようにしてる
一方(ストアド)ファンクションはSQL標準で戻り値が必須でscalar valueのみと定められている

プログラミング言語でファンクションとプロシージャを区別してたのは太古の昔の話
今ではもうそんな区別に価値はなくなってる
SQL標準で区別されてるのは利用方法や利用する場所が基本的に違うため
0234デフォルトの名無しさん2023/08/31(木) 16:31:16.87ID:nbJL0Jax
MySQL系はファンクションだと、COMMITなどのトランザクション制御ができないので、あまり考えずにファンクションで統一などしてはならない。
0235デフォルトの名無しさん2023/08/31(木) 16:41:03.73ID:nbJL0Jax
>>233
前半と後半で違う説明をしているね。

ファンクションは「関数」だ。

OUTパラメータを参照するのは「手続き」という処理だ。

プロシージャで戻り値とOUTパラメータを返す場合は、ちゃんと仕様書がないとわけのわからないものになる。
0237デフォルトの名無しさん2023/08/31(木) 23:06:43.05ID:smxtGdye
そもそも、DBMSの指定や前提もなく
>ストアドプロシージャって初心者用解説サイトとかで戻り値のない関数
とか書いてあるなら、そのサイトに問題があるだけの話

まあ、ちゃんと前提を読んでないか理解してない読み手の問題の可能性もあるが
0238デフォルトの名無しさん2023/09/01(金) 20:37:48.72ID:5C0TsKNS
関数やプロシージャのことを「メソッド」と書いている書籍もあるくらいだからな。勝手な名前をつけるやつはたくさんいる。
0239デフォルトの名無しさん2023/09/01(金) 23:32:50.20ID:OZcoXz6r
ざっくり言うと
ファンクションは1つのSQL文の中でSELECT句やWHERE句などの一部として繰り返し利用する機能を定義したもの
プロシージャはSQL文を使ったひとまとめの処理をSQL文の一部としてではなく外部から繰り返し呼び出せるように定義したもの
これが最も根本的な違い

ファンクションでトランザクション制御しようと考えてしまったりデータベースを更新しようと考えてしまう人はこの根本的違いを理解してない
0240デフォルトの名無しさん2023/09/02(土) 22:12:45.21ID:9Zs5bzSj
そもそもプロシージャは手続きという処理という意味で、ファンクション(関数)は機能という結果を返す処理の意味。
0242デフォルトの名無しさん2023/09/16(土) 22:45:43.61ID:S29731mD
数学がわからないんだろ
0243デフォルトの名無しさん2023/09/16(土) 22:48:52.44ID:S29731mD
ファンクションプロシージャは結果を戻り値で返す

サブプロシージャはOUTパラメータ(引数)で返す

SQLの関数は関数(ファンクションプロシージャ)で実装しないとSQLの構文が破綻する
0244デフォルトの名無しさん2023/09/16(土) 22:55:55.12ID:S29731mD
>>241
だから、オラクル社はAda言語をそのまま流用しただけだよ。

ANSIはファンクションの方を先に標準SQLに組み込んだだけ。

ファンクションとサブを区別しているかどうかは、Ada言語を踏襲しているかどうかの違い。

C言語のように戻り値を無視する構文がいいのか悪いのかという話だよ。
0245デフォルトの名無しさん2023/09/17(日) 13:55:16.79ID:I/olJ+Ch
perl の戻り値の仕組みは面白いと思ったのは古い思い出
0246デフォルトの名無しさん2023/09/17(日) 23:44:17.06ID:70jB6wMR
noSQLのスレはないの
オブジェクト指向データベースとかはsql使うのかな
0247デフォルトの名無しさん2023/09/18(月) 11:28:48.80ID:+ud3D/1q
noSQLスレは以前はあった
0248デフォルトの名無しさん2023/10/06(金) 19:29:28.75ID:Oy8bZUfG
>>246
データベース板を忘れないでください
レスを投稿する


ニューススポーツなんでも実況