
日付をDBから取り出す際、
例
9999-99-99 99:99:99
↑を取り出すのは
AND substr(dat_sales.date,1,4)="2023"
AND substr(dat_sales.date,6,2)="02"
AND substr(dat_sales.date,9,2)="15"
と記述すると本に載っており実際、この記述でデータを取り出せました。
が、取り出す文字の数え方が疑問です。
最初の頭の数は1ではなく0ではないのでしょうか?
substr('abcde', 0, 2) --> ab
の様にaが0から始まると思うのですが今回のですと
substr(dat_sales.date,1,4)だと
999-が取り出されると思ったのですが。
何故、上手く日付が取り出せたのでしょうか?
教えて下さい。
No.4ベストアンサー
- 回答日時:
こんにちは
SQLですよね?
PHPのカテでご質問なさっているので、PHPと混同していませんか?
SQLでは先頭の文字位置は「1」です。
(0を指定した場合、1として処理されます)
https://itsakura.com/oracle-substr
https://docs.oracle.com/cd/E16338_01/server.112/ …
ありがとうございます!
すみません、質問するカテを間違えていました。
SQLでは頭が1になるのですね。
助かりました。
ずっと考えていたので教えて頂けて本当に嬉しいです。
ありがとうございました!
No.3
- 回答日時:
環境や言語系によって関数のパラメータ解釈に差があるのかもしれません
そもそもこの話題は、どの環境での話でしょうか?
カテゴリからPHP上ということでしょうか?
こちらのPHPマニュアルを参照すると
https://www.php.net/manual/ja/function.substr.php
offset値は、0~とい事になっていますね
とは言え、実機では1~ということなのであれば
そういう環境だと解釈してくしか無いのでは?
仮に0を指定した場合にはどういう結果が得られるのかで仕様を推定できそうですね
No.1
- 回答日時:
>の様にaが0から始まると思う
なんでそう思ったのですか?
別の文字列の取り出しなら、0からになった、、、など
異なる実例が発生したんですか?
してないなら、単なるあなたの思い込みでしょ?
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
ファイル名に日付の挿入
-
開始と終了を指定して、その間...
-
現在時刻をyyyymmddhhmmss形式...
-
Accessコンボボックス
-
昨日の日付を取得するVBscript
-
改行されないカレンダー(PHP)
-
プルダウンメニューの値をDBに...
-
strtotime 前月・前々月の表示
-
PHP date関数を変数に代入
-
PHPで以下のような占いプログラ...
-
PHP 指定した期間だけ表示した...
-
PHPでn日後を計算したい
-
【C#】DataGridViewの最大列数...
-
Dosブロンプトでtabを出力したい
-
「取得先」という表現について
-
switch()文で値の大小比較
-
findstrのerrorlevel
-
VB6でDBからクリップボード経由...
-
どういうプログラムを関数化を...
-
コンビニで住民票を取得した場...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
開始と終了を指定して、その間...
-
ファイル名に日付の挿入
-
日付データを比較して出力したい!
-
日付の比較
-
子ノードの出力について
-
"0412" を "04" と "12" で区切る
-
「20100101」を「2010/01/01」...
-
AND検索のスクリプト記述方法(...
-
アップロードしたファイル名に...
-
timestamp(14)のフォーマットに...
-
PHP に詳しい方教えてください
-
現在時刻をyyyymmddhhmmss形式...
-
2011-08-18>2011年 8月18日(木)
-
date関数の漢字フォーマット
-
DBから昨日以前の日付のデータ...
-
前月の取得について
-
WP 日時で分岐して表示を変えたい
-
日付の比較方法
-
C言語を使って、ある特定の日の...
-
MS-DOSコマンドのリダイ...
おすすめ情報
はい。カラムの間違えがあり、その旨を教えて頂き正常に動きました。
今回、substr自体の使い方が疑問だったので質問をしました。
例えば何ですが、
2023-02-15 99:99:99 という日付のデータを取り出したい場合、
2023は左から0123と数えるのではないかと疑問に思いました。
2023は左から1234と1から始まるのでしょうか?だとすると、
2023-02-15は1234が2023で-02が56となるのでしょうか?