189 8069 5689

mysql怎么去赋多个值 mysql自增字段赋值

MySql中如何给变量赋值(多个)

DECLARE PRIMARY_KEY VARCHAR(100);

成都创新互联公司长期为上千余家客户提供的网站建设服务,团队从业经验10年,关注不同地域、不同群体,并针对不同对象提供差异化的产品和服务;打造开放共赢平台,与合作伙伴共同营造健康的互联网生态环境。为天津企业提供专业的网站设计、成都网站建设天津网站改版等技术服务。拥有10余年丰富建站经验和众多成功案例,为您定制开发。

SET PRIMARY_KEY = group_concat(NEW.USER_ID,NEW.ROLE_NAME);

查询语句是这样写的:

select group_concat(NEW.USER_ID,NEW.ROLE_NAME)from NEW where 条件;

SELECT group_concat(NEW.USER_ID,NEW.ROLE_NAME separator '连接字符') FROM NEW where 条件;

mysql怎么一个字段设置多个值

关系型数据库第一范式就说明了:

数据表中的每一列(字段),必须是不可拆分的最小单元,也就是确保每一列的原子性。

所以一个字段存多个值是不可能的。

当然可以把多个值序列化成一个字符串或者二进制保存到一个字段,比如字符串"作者1,作者2,作者3",但这样做也不是第一范式中所谓的多个值,只算一个值,并且对以后的细划查询也不方便,比如查作者信息,肯定不只是一个作者名啊。

所以一般设计上会有明细表,外键关系关联。

有一个book表,记录书的信息;

再有一个author表,记录作者信息,此表中有一个字段作外键引用book表的书id。

这样查询书有什么作者的时候只需要两个表外键join就行了。

如何把mysql查询结果赋值给多个变量

打开结果集 用游标循环取值,

1

2

3

4

5

6

7

8

9

10

11

12

$sql_str='select * from DEPARTMENTS where SUPDEPTID='.$SUPDEPTID.' order by DEPTID ';

$rs=$conn-Execute($sql_str);

echo "ok";

while(!$rs-eof){

$row_arr=array();

$row_arr['id']=$rs-fields["DEPTID"]-value;

$row_arr['text']=iconv( "gb2312", "UTF-8//IGNORE" , $rs-Fields['DEPTNAME']-value);

$row_arr['DEPTID']=$rs-fields["DEPTID"]-value;

$row_arr['DEPTNAME']=iconv( "gb2312", "UTF-8//IGNORE" , $rs-Fields['DEPTNAME']-value);

$row_arr['SUPDEPTID']=$rs-fields["SUPDEPTID"]-value;

$row_arr['UPDEPTNAME']=$UPDEPTNAME;

}

mysql 存储过程中变量的定义与赋值操作

一、变量的定义

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。


当前文章:mysql怎么去赋多个值 mysql自增字段赋值
标题路径:http://cdxtjz.cn/article/hgpeed.html

其他资讯