26

次のようなステートメントでmysqlから結果をフェッチできるようにしたいと思います。

SELECT * 
  FROM table 
 WHERE amount > 1000 

しかし、(ユーザーからの入力に基づいて)特定の月と年に制限された結果を取得したい...私は次のように試みていました:

SELECT * 
  FROM table 
 WHERE amount > 1000 
   AND dateStart = MONTH('$m')   

... $m1か月ですが、エラーが発生しました。

その表では、実際には2つの日付が startDateあります。endDateしかし、私はに焦点を当てていstartDateます。入力値は月と年になります。その年のその月に基づいて結果を取得するSQLステートメントをどのように表現しますか?

4

7 に答える 7

44

あなたは近かった - 逆方向の比較を取得しました ( startDateDATETIME または TIMESTAMP データ型であると仮定します):

SELECT * 
  FROM table 
 WHERE amount > 1000 
   AND MONTH(dateStart) = {$m}

警告:


代替案:


列で関数を使用してもインデックスを使用できないため、次BETWEENSTR_TO_DATE関数を使用することをお勧めします。

WHERE startdate BETWEEN STR_TO_DATE([start_date], [format]) 
                    AND STR_TO_DATE([end_date], [format])

フォーマット構文については、ドキュメントを参照してください。

参照:


于 2010-01-11T04:18:43.113 に答える
8

関数を使用しmonth()ます。

select month(now());
于 2010-01-11T04:02:21.720 に答える
3

例えば

$date = sprintf("'%04d-%02d-01'", $year, $month);
$query = "
  SELECT
    x,y,dateStart
  FROM
    tablename
  WHERE
    AND amount > 1000
    AND dateStart >= $date
    AND dateStart < $date+Interval 1 month
";
mysql_query($query, ...

これにより、たとえば次のようなクエリが作成されます

WHERE
  AND amount > 1000
  AND dateStart >= '2010-01-01'
  AND dateStart < '2010-01-01'+Interval 1 month

+ Interval 1 monthdate_add()の代替 です。

SELECT Date('2010-01-01'+Interval 1 month)-> 2010-02-01
SELECT Date('2010-12-01'+Interval 1 month)->2011-01-01
このようにして、常に翌月の初日を取得します。必要なレコードには、その日付より前で、sprintf()に渡した月(および年)の最初の日以降のdateStartが必要です。
'2010-01-01'+Interval 1 month行間で変化しません。MySQLは用語を1回だけ計算し、検索にインデックスを利用できます。

于 2010-01-11T04:09:58.663 に答える
3

これを試して:

SELECT * 
FROM table 
WHERE amount > 1000 AND MONTH(dateStart) = MONTH('$m') AND YEAR(dateStart) = YEAR('$m')
于 2010-01-11T04:18:16.963 に答える
0

これを試して

SELECT * 
      FROM table 
     WHERE amount > 1000 
       AND MONTH(datestart)
    GROUP BY EXTRACT(YEAR_MONTH FROM datestart)
于 2015-11-17T07:58:17.577 に答える
0

これを試してください(日付フィールドがテキストの場合、この文字列を日付に変換します):

SELECT * FROM `table_name` WHERE MONTH(STR_TO_DATE(date,'%d/%m/%Y'))='11'

//This will give month number MONTH(STR_TO_DATE(date,'%d/%m/%Y'))
//If its return 11 then its November
// Change date format with your date string format  %d/%m/%Y
于 2016-12-23T13:53:44.097 に答える
0

対応機種: MySQL 5.7、MySQL 5.6、MySQL 5.5、MySQL 5.1、MySQL 5.0、MySQL 4.1、MySQL 4.0、MySQL 3.23

  • 日:

    SELECT EXTRACT(DAY FROM "2017-06-15");
    
  • 月:

    SELECT EXTRACT(MONTH FROM "2017-06-15");
    
  • 年:

    SELECT EXTRACT(YEAR FROM "2017-06-15");
    
于 2017-08-03T08:36:38.600 に答える