PHP读取数据库显示问题

php中文网
发布: 2016-06-23 14:14:20
原创
975人浏览过

数据库 PHP MySQL

请教各位,我的数据库数据如下:-
-- 表的结构 `3g_district`
--

CREATE TABLE IF NOT EXISTS `3g_district` (
  `d_id` mediumint(8) unsigned NOT NULL AUTO_INCREMENT,
  `d_name` char(255) NOT NULL,
  `d_level` tinyint(4) unsigned NOT NULL DEFAULT '0',
  `d_pid` mediumint(8) unsigned NOT NULL DEFAULT '0',
  `d_list` smallint(6) NOT NULL DEFAULT '0',
  PRIMARY KEY (`d_id`),
  KEY `upid` (`d_pid`,`d_list`)
) ENGINE=InnoDB  DEFAULT CHARSET=utf8 AUTO_INCREMENT=45052 ;

--
-- 转存表中的数据 `3g_district`
--

INSERT INTO `3g_district` (`d_id`, `d_name`, `d_level`, `d_pid`, `d_list`) VALUES
(1, '北京市', 1, 0, 0),
(2, '天津市', 1, 0, 0),
(3, '河北省', 1, 0, 0),
(4, '山西省', 1, 0, 0),
(5, '内蒙古自治区', 1, 0, 0),
(6, '辽宁省', 1, 0, 0),
(7, '吉林省', 1, 0, 0),
(8, '黑龙江省', 1, 0, 0),
(9, '上海市', 1, 0, 0),
(10, '江苏省', 1, 0, 0),
(11, '浙江省', 1, 0, 0),
(12, '安徽省', 1, 0, 0),
(13, '福建省', 1, 0, 0),
(14, '江西省', 1, 0, 0),
(15, '山东省', 1, 0, 0),
(16, '河南省', 1, 0, 0),
(17, '湖北省', 1, 0, 0),
(18, '湖南省', 1, 0, 0),
(19, '广东省', 1, 0, 0),
(20, '广西壮族自治区', 1, 0, 0),
(21, '海南省', 1, 0, 0),
(22, '重庆市', 1, 0, 0),
(23, '四川省', 1, 0, 0),


我的conn.php文件如下:

    
    $mysql_server_name="localhost"; //数据库服务器名称
    $mysql_username="root"; //连接数据库用户名
    $mysql_password="";  //连接数据库密码
    $mysql_database="teafea";  //数据库的名字

    //连接到数据库
    $conn=mysql_connect($mysql_server_name,$mysql_username,$mysql_password);

    //使用utf8编码
    mysql_query("set names 'utf8'");

    //从表中提取信息的sql语句
    $str="select d_id,d_name from 3g_district";

    //执行sql查询
    mysql_select_db($mysql_database,$conn);
    $res=mysql_query($str,$conn);

    //获取查询结果
    $row=mysql_fetch_row($res);

    //定位到第一条记录
    mysql_data_seek($res,0);

    //循环取出记录
    while($row=mysql_fetch_row($res)){

        for($i=0;$i
          echo  json_encode("$row[$i]");
        }
    }

我想要的效果是从数据库里取出来显示效果:
d_id:d_name,d_id:d_name,
即是1:北京市,2:天津市,3:河北省
这样一种效果
请教各位这样的效果conn.php文件怎么写呢?中间的冒号: 和单引号, 怎样加上去呢?

回复讨论(解决方案)

 //循环取出记录
 $res = array();
 while($row=mysql_fetch_row($res)){
   $res[] = join(':', $row);
 }
 echo join(',', $res);

经测试出现以下错误:
Warning: mysql_fetch_row() expects parameter 1 to be resource, array given in E:\wamp\www\20\conn.php on line 29

29行就是 while($row=mysql_fetch_row($res)){这一行,

请问怎么解决呢?

 $conn=mysql_connect('localhost','root','写上你的数据库密码');
 $str="select d_name from 3g_district";直接搜索name,id是自增长的,在显示的时候你把id加上就能显示出来了。
 mysql_select_db($tr,$conn);

Warning: mysql_fetch_row() expects parameter 1 to be resource, array given in E
说 $res 是一个数组,怎么可能。你确定你贴的代码是最新的吗?

PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号