如何在mysql数据表中显示当前时间

如何在mysql数据表中显示当前时间,第1张

1.1 获得当前日期+时间(date + time)函数:now()

除了 now() 函数能获得当前的日期时间外,MySQL 中还有下面的函数:

current_timestamp() current_timestamp

localtime() localtime

localtimestamp() localtimestamp

这些日期时间函数,都等同于 now()。鉴于 now() 函数简短易记,建议总是使用 now() 来替代上面列出的函数。

1.2 获得当前日期+时间(date + time)函数:sysdate()

sysdate() 日期时间函数跟 now() 类似,不同之处在于:now() 在执行开始时值就得到了, sysdate() 在函数执行时动态得到值。

2. 获得当前日期(date)函数:curdate()

其中,下面的两个日期函数等同于 curdate(): current_date(),current_date

3. 获得当前时间(time)函数:curtime()

其中,下面的两个时间函数等同于 curtime():current_time(),current_time

4. 获得当前 UTC 日期时间函数:utc_date(), utc_time(), utc_timestamp()

0

先理解下格式问题

要理解两种格式,一是mysql内部使用和存储时使用的格式,另一个是用户显示的格式;

存储格式:mysql保存日期时间值时使用的CCYY-MM-DD格式遵循ISO

8601标准;

显示格式:显示在输出界面上的格式,可以使用DATA_FORMAT()或TIME_FORMAT()函数来设置和转换;

1

转换和处理

1)提交数据,一是使用标准格式让其自动识别,二是对输入值进行格式指定和转换

insert

into

t

(d)

values('2012-01-01')

#使用默认ansi标准格式,让数据库自动识别字串为日期;

insert

into

t

(d)

values(

STR_TO_DATE('2012/February/01',

'%Y/%M/%d')

)

#使用字符转换为日期的函数来处理自定义格式的输入值;

2)查询数据,一是不使用格式(即使用默认的CCYY-MM-DD格式),二是指定输出格式

select

current_date()

#默认格式

select

date_format(current_date(),

''%Y/%M/%d'')

#使用自定义格式,具体参考下date_format的帮助,主要是格式控制符的使用。

2

格式化参数

DATE_FORMAT(),

TIME_FORMAT(),

STR_TO_DATE()这三个函数都接受格式化串作为参数来格式化日期时间

常用的格式化字符:

%Y

4位数字年份

2012

%y

2位数字年份

12

%M

完整英文月份名称,January

-

December

%b

月份名称前三个字母,Jan

-

Dec

%m

2位数字月份

01-12

%c

最小位数字月份

1-12

%d

2位数字日期

01-31

%e

最小位数字日期

1-31

%W

工作日名称

Sunday

-

Saturday

%r

12小时制时间,以AM或PM结尾

%T

24小时制时间

%H

24小时制小时

00-23

%i

2位数字分钟

00-59

%s

2位数字秒数

00-59

%%

%文字字符

一、变量的定义

mysql中变量定义用declare来定义一局部变量,该变量的使用范围只能在begin...end

块中使用,变量必须定义在复合语句的开头,并且是在其它语句之前,也可以同时申明多个变量,如果需要,可以使用default赋默认值。

定义一个变量语法如下:

declare

var_name[,...]

type[default

value]看一个变量定义实例

declare

last

date二、mysql存储过程变量赋值

变量的赋值可直接赋值与查询赋值来 *** 作,直接赋值可以用set来 *** 作,可以是常量或表达式如果下

复制代码

代码如下:

set

var_name=

[,var_name

expr]...给上面的last变量赋值方法如下

set

last

=

date_sub(

current_date(),interval

1

month)下面看通过查询给变量赋值,要求查询返回的结果必须为一行,具体 *** 作如下

select

col

into

var_name[,...]

table_expr我们来通过查询给v_pay赋值。

create

function

get

_cost(p_custid

int,p_eff

datetime)

return

decimal(5,2)

deterministic

reads

sql

data

begin

declare

v_pay

decimail(5,2)

select

ifnull(

sum(pay.amount),0)

into

vpay

from

payment

where

pay.payd<=p_eff

and

pay.custid=pid

reutrn

v_rent

+

v_over

-

v_pay

end

$$

好了,这篇简单的存储过程中变量的定义赋值教程就到这里了,下面我们会接着讲关于myql存储过程的条件的定义与处理。

以下是其它网友的补充

在MySQL的存储过程中,可以使用变量,它用于保存处理过程中的值。

定义变量使用DECLARE语句,语法格式如下:

DECLARE

var_name[,...]

type

[DEFAULT

value]

其中,var_name为变量名称,type为MySQL支持的任何数据类型,可选项[DEFAULT

value]为变量指定默认值。一次可以定义多个同类型的变量,各变量名称之间以逗号“,”隔开。

定义与使用变量时需要注意以下几点:

DECLARE语句必须用在DEGIN…END语句块中,并且必须出现在DEGIN…END语句块的最前面,即出现在其他语句之前。

DECLARE定义的变量的作用范围仅限于DECLARE语句所在的DEGIN…END块内及嵌套在该块内的其他DEGIN…END块。

存储过程中的变量名不区分大小写。

定义后的变量采用SET语句进行赋值,语法格式如下:

SET

var_name

=

expr

[,var_name

=

expr]

...

其中,var_name为变量名,expr为值或者返回值的表达式,可以使任何MySQL支持的返回值的表达式。一次可以为多个变量赋值,多个“变量名=值”对之间以逗号“,”隔开。

例如:

复制代码

代码如下:

begin

declare

no

varchar(20)

declare

title

varchar(30)

set

no='101010',title='存储过程中定义变量与赋值'

end

提示:存储过程中所有的关键字也是不区分大小写的,如BEGIN可以写出begin。


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/zaji/8588494.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-04-18
下一篇2023-04-18

发表评论

登录后才能评论

评论列表(0条)

    保存