求教一个 php 问题 - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
Sign Up Now
For Existing Member  Sign In
请不要在回答技术问题时复制粘贴 AI 生成的内容
b7898585

求教一个 php 问题

  •  
  •   b7898585 Dec 28, 2014 3290 views
    This topic created in 4138 days ago, the information mentioned may be changed or developed.
    要做一个报名页面,要求如下:

    序号 姓名 性别 年龄
    1 aaa 男 18
    2 bbb 女 19
    3 ccc 女 22
    .................

    行数不固定,可能1组,也可能很多组,怎样做到同时提交?
    程序是php+mysql
    8 replies    2014-12-29 00:07:06 +08:00
    raincious
        1
    raincious  
       Dec 28, 2014
    你可以做一个固定同时提交多组数据的页面。

    当提交一条结果时,执行INSERT以及一个VALUES,当提交多个时,添加多个VALUES就行了。
    mchl
        2
    mchl  
       Dec 28, 2014
    试试Transaction和foreach
    jianghu52
        3
    jianghu52  
       Dec 28, 2014
    sql的事务,多次保存,一次commit。
    Tr0y
        4
    Tr0y  
       Dec 28, 2014
    表单用多维
    例如<input type="text" name="name[]" />

    接收到数据用foreach迭代。生成insert sql,然后执行就行了。
    doushiyinweini
        5
    doushiyinweini  
       Dec 28, 2014
    楼上正解
    lincanbin
        6
    lincanbin  
       Dec 28, 2014
    这个主要是Javascript,难点在于创建对应数量的DOM节点。
    你只要在客户端生成指定数量的
    <input type="text" name="Tag[]" value="" />
    https://github.com/lincanbin/Carbon-Forum/blob/master/static/js/new.function.js#L172
    在服务端直接用
    $TagsArray = $_POST['Tag'];
    就直接获得这多个同名文本框的数据数组了
    https://github.com/lincanbin/Carbon-Forum/blob/master/new.php#L18
    Kilerd
        7
    Kilerd  
       Dec 28, 2014 via Android
    如果你前端录入信息都没问题,还会卡在录入mysql?
    很好奇你前端是怎么做的。
    mhycy
        8
    mhycy  
       Dec 29, 2014
    某些前端防火墙会拦截数组请求
    建议最佳做法也是最合适安全的做法是利用JS生成表单,并且遍历产生JSON数据
    然后把数据base64一次编码后传入后端,后端程序再解包入库
    这是最稳妥的做法,避免了请求数据异常带来的数据不一致问题,也避免了某些奇葩防火墙的问题~

    后端入库json_decode 以后用 foreach直接遍历insert就好了,为了维护方便包装一下写入代码做个类或者做个函数都行~
    About     Help     Advertise     Blog     API     FAQ     Solana     954 Online   Highest 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 53ms UTC 21:14 PVG 05:14 LAX 14:14 JFK 17:14
    Do have faith in what you're doing.
    ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86