① Thinkphp怎么批量添加数据
ThinkPHP,Model类有定义addAll()来实现批量添加数据
从2.1版开始恢复了批量插入数据的addAll方法(仅针对Mysql数据库)
假设数据:(批量添加数据都是二维数组)
$data[0]=array('name'=>'张三','sex'=>'1');
$data[1]=array('name'=>'李四','sex'=>'2');
$data[2]=array('name'=>'王五','sex'=>'1');
比如像User表写入批量数据
D('User')->addAll($data);
此操作后,数据库内就生成三条数据
② ThinkPHP volist怎么使用函数设定数据集
thinkPHP中的volist标签通常用于查询数据集(select方法)的结果输出,通常模型的select方法返回的结果是一个二维数组,可以直接使用volist标签进行输出。
在控制器中首先对模版赋值:
$User=M('User');
$list=$User->limit(10)->select();
$this->assign('list',$list);
在模版定义如下,循环输出用户的编号和姓名:
<volistname="list"id="vo">
{$vo.id}:{$vo.name}<br/>
</volist>
Volist标签的name属性表示模板赋值的变量名称,因此不可随意在模板文件中改变。id表示当前的循环变量,可以随意指定,但确保不要和name属性冲突,例如:
<volistname="list"id="data">
{$data.id}:{$data.name}<br/>
</volist>
支持输出查询结果中的部分数据,例如输出其中的第5~15条记录
<volistname="list"id="vo"offset="5"length='10'>
{$vo.name}
</volist>
③ thinkphp 二维数组怎么插入数据库
$data = array(
216 => array(
'a' => 1,
'b' => 3456,
'c' => '广州天河',
'd' => 98765
),
217 => array(
'a' => 1,
'b' => 3456,
'c' => '广州天河',
'd' => 98765
),
218 => array(
'a' => 1,
'b' => 3456,
'c' => '广州天河',
'd' => 98765
),
219 => array(
'a' => 1,
'b' => 3456,
'c' => '广州天河',
'd' => 98765
)
);
foreach ($data as $k => $v) { // 循环保存每一条值
$map = array();
$map['k'] = $k; // 保存216 这个键名
$map['a'] = $v['a'];
$map['b'] = $v['b'];
$map['c'] = $v['c'];
$map['d'] = $v['d'];
M('')->table('table_name')->add($map);
}