
日付を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ランキング
-
コマンドプロンプト 日時を用...
-
Dosブロンプトでtabを出力したい
-
バッチファイルでPCのモデル名...
-
VBで他アプリの「syslistview32...
-
C# ASP.NET でIPアドレスからア...
-
findstrのerrorlevel
-
小数点以下0の非表示
-
C#で特定LANアダプタの状態を取...
-
Access グループごとのページ...
-
(Win32)ファイルパスから物理ド...
-
表を表示するコントロールについて
-
PHP declare文について、ticks...
-
URLのパラメータをGETのままで...
-
長い1枚ページを無限スクロール...
-
asp.netでのセッションを使用し...
-
「取得先」という表現について
-
IPアドレス変更方法
-
vb作成したらでbeep音が鳴りま...
-
Cookieを利用したユーザ管理
-
初歩的な質問だと思います。IF...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
開始と終了を指定して、その間...
-
ファイル名に日付の挿入
-
現在時刻をyyyymmddhhmmss形式...
-
C言語でシステム日付との差を...
-
strtotime 前月・前々月の表示
-
C言語を使って、ある特定の日の...
-
昨日の日付を取得するVBscript
-
PHPでn日後を計算したい
-
プルダウンで今日以降の日付を...
-
Accessコンボボックス
-
改行されないカレンダー(PHP)
-
Accessで、DAOでAddnew
-
6ヶ月前の日付を取得するにはど...
-
VBAでのDATEについて
-
日付を米国式から日本式に変換...
-
substrの使い方について教えて...
-
昨日の日付名でファイルを作成...
-
日付の比較方法
-
MS-DOSコマンドのリダイ...
-
MYSQLの日付から現在までの年数...
おすすめ情報
はい。カラムの間違えがあり、その旨を教えて頂き正常に動きました。
今回、substr自体の使い方が疑問だったので質問をしました。
例えば何ですが、
2023-02-15 99:99:99 という日付のデータを取り出したい場合、
2023は左から0123と数えるのではないかと疑問に思いました。
2023は左から1234と1から始まるのでしょうか?だとすると、
2023-02-15は1234が2023で-02が56となるのでしょうか?