CodeIgniter 3 SQLSRV 数据库查询结果获取指南


CodeIgniter 3 SQLSRV 数据库查询结果获取指南

本教程旨在解决 codeigniter 3 (ci3) 使用 sqlsrv 数据库驱动时,无法正确获取查询结果的常见问题。文章将详细指导如何配置数据库连接、在模型中执行 sql 查询,并重点介绍如何通过 ci3 提供的 `result()` 或 `result_array()` 方法有效提取数据,确保应用程序能够成功与 sql server 交互并展示数据。

在 CodeIgniter 3 (CI3) 框架中与 SQL Server 数据库交互时,开发者常会遇到查询执行成功但无法正确获取数据的问题。这通常不是连接失败,而是对 CI3 数据库结果对象处理不当所致。本文将提供一个详细的教程,指导如何正确配置 SQLSRV 驱动,并在模型中有效获取查询结果。

1. CodeIgniter 3 SQLSRV 数据库配置要点

首先,确保您的 CodeIgniter 3 应用程序已正确配置 SQLSRV 数据库驱动。在 application/config/database.php 文件中,您需要设置相应的数据库参数。

配置示例:

<?php
defined('BASEPATH') OR exit('No direct script access allowed');

$active_group = 'default';
$query_builder = TRUE;

$db['default'] = array(
    'dsn'      => '',
    'hostname' => '10.xxx.xxx.x', // 替换为您的 SQL Server IP 地址或主机名
    'username' => 'username',     // 替换为您的数据库用户名
    'password' => 'password',     // 替换为您的数据库密码
    'database' => 'mydb',         // 替换为您的数据库名称
    'dbdriver' => 'sqlsrv',       // 指定使用 SQLSRV 驱动
    'dbprefix' => '',
    'pconnect' => FALSE,
    'db_debug' => (ENVIRONMENT !== 'production'), // 生产环境建议关闭
    'cache_on' => FALSE,
    'cachedir' => '',
    'char_set' => 'utf8',         // 确保字符集兼容
    'dbcollat' => 'utf8_general_ci',
    'swap_pre' => '',
    'encrypt'  => FALSE,
    'compress' => FALSE,
    'stricton' => FALSE,
    'failover' => array(),
    's*e_queries' => TRUE // 建议在开发环境开启,方便调试
);

注意事项:

  • PHP SQLSRV 扩展: 确保您的 PHP 环境已正确安装并启用了适用于您 PHP 版本的 php_sqlsrv.dll 和 php_pdo_sqlsrv.dll 扩展。这些扩展通常需要从 Microsoft 官方下载。
  • 连接参数: hostname、username、password 和 database 必须与您的 SQL Server 实例和凭据完全匹配。
  • db_debug: 在开发阶段将其设置为 TRUE (或基于 ENVIRONMENT) 可以帮助您捕获数据库错误信息。在生产环境,出于安全考虑应设置为 FALSE。

2. 在模型中执行查询与获取结果

在 CodeIgniter 中,所有的数据库操作通常都在模型(Model)中完成。当您执行一个查询时,$this->db->query() 方法会返回一个数据库结果对象,而不是直接的数据数组。要获取实际的数据行,您需要使用该结果对象提供的方法。

错误示例分析:

初学者常犯的错误是直接 var_dump() 数据库查询返回的结果对象,例如:

// 错误的示例
class Mod_login extends CI_Model {
    function Aplikasi() {
        $sql = "SELECT * FROM aplikasi";
        $data = $this->db->query($sql);
        var_dump($data); // 这里 $data 是一个对象,不是数据数组
        die();
        // ... 后续逻辑
    }
}

上述代码中,var_dump($data) 会输出一个 CI_DB_sqlsrv_result 类型的对象,其中包含了查询元数据、行数等信息,但不是您期望的包含数据行的数组。

正确获取查询结果的方法:

要从结果对象中提取数据,CodeIgniter 提供了多种方法:

Picit AI Picit AI

免费AI图片编辑器、滤镜与设计工具

Picit AI 172 查看详情 Picit AI
  • result_array(): 返回一个包含所有结果行的关联数组。每行是一个关联数组。
  • result(): 返回一个包含所有结果行的对象数组。每行是一个标准对象。
  • row_array(): 返回单行结果的关联数组。适用于预期只返回一行数据的情况。
  • row(): 返回单行结果的标准对象。适用于预期只返回一行数据的情况。

优化后的模型代码示例:

class Mod_login extends CI_Model {
    function Aplikasi() {
        $sql = "SELECT * FROM aplikasi";
        $query = $this->db->query($sql); // 执行查询,返回结果对象

        // 检查查询是否成功且有结果
        if ($query && $query->num_rows() > 0) {
            // 获取所有结果行作为关联数组
            $data = $query->result_array();
            // 调试时可以使用 var_dump 检查数据内容
            // var_dump($data);
            // die();
            return $data;
        } else {
            // 查询失败或没有结果
            return array(); // 返回空数组或 false
        }
    }
}

在这个优化后的模型中,我们首先检查 $query 是否有效,然后使用 $query->result_array() 来获取包含实际数据行的关联数组。

3. 控制器与视图的数据传递

在控制器中,您调用模型方法获取数据,并将数据传递给视图进行展示。

控制器代码示例:

<?php
defined('BASEPATH') OR exit('No direct script access allowed');

class Dashboard extends CI_Controller {

    public function __construct() {
        parent::__construct();
        $this->load->model('Mod_login'); // 加载模型
        $this->load->library('session'); // 加载 session 库
    }

    public function index() {
        $logged_in = $this->session->userdata('logged_in');

        if ($logged_in == TRUE) {
            // 用户已登录,重定向到仪表板主页
            redirect('dashboard/home');
        } else {
            // 用户未登录,加载登录页面并尝试获取应用数据
            $aplikasi_data = $this->Mod_login->Aplikasi(); // 从模型获取数据

            // 将数据传递给视图
            $data['aplikasi'] = $aplikasi_data;
            $this->load->view('admin/login_data', $data);
        }
    }

    // ... 其他方法
}

在视图文件 admin/login_data.php 中,您可以通过 $aplikasi 变量访问传递过来的数据,并使用循环进行展示:

<!DOCTYPE html>
<html>
<head>
    <title>Login</title>
</head>
<body>
    <h1>应用列表</h1>
    <?php if (!empty($aplikasi)): ?>
        <ul>
            <?php foreach ($aplikasi as $item): ?>
                <li>ID: <?php echo $item['id']; ?>, 名称: <?php echo $item['nama']; ?></li>
            <?php endforeach; ?>
        </ul>
    <?php else: ?>
        <p>没有找到应用数据。</p>
    <?php endif; ?>

    <!-- 登录表单等其他内容 -->
</body>
</html>

请注意,视图中的 $item['id'] 和 $item['nama'] 需要根据您数据库 aplikasi 表的实际列名进行调整。

4. 调试与故障排除

  • db_debug: 确保在开发环境中 database.php 中的 'db_debug' 设置为 TRUE。这样,当数据库查询出错时,CodeIgniter 会显示详细的错误信息,帮助您定位问题。
  • var_dump(): 在模型中,当您对 $this->db->query() 的返回结果不确定时,可以使用 var_dump($query) 来查看结果对象的结构。在获取数据后,使用 var_dump($data) 来确认是否成功提取了数组数据。
  • SQL 查询测试: 建议将您的 SQL 查询语句直接在 SQL Server Management Studio (SSMS) 或其他数据库客户端中运行,以确保 SQL 语句本身是正确的,并且数据库用户有权限访问相关表。

总结

正确在 CodeIgniter 3 中使用 SQLSRV 驱动并获取查询结果的关键在于理解 db->query() 返回的是一个结果对象,而不是直接的数据。通过利用 result_array()、result() 等方法,您可以轻松地将查询结果转换为可用的数组或对象集合,从而在应用程序中进行处理和展示。遵循本文的指导,将有助于您避免常见的陷阱,并更高效地开发与 SQL Server 集成的 CI3 应用程序。

以上就是CodeIgniter 3 SQLSRV 数据库查询结果获取指南的详细内容,更多请关注php中文网其它相关文章!


# word  # 营销推广张晨简历  # 常州网站建设工程施工  # 优化seo关键词排名  # wordpress网站速度优化  # 营销推广词语怎么说  # 可以使用  # 加载  # 您可以  # 设置为  # 应用程序  # 适用于  # 数据库查询  # 查询结果  # php  # html  # app  # access  # session  # ai  # microsoft  # 常见问题  # 开发环境  # red  # 您的  # 是一个  # 黄石网站优化推广开发  # 苏州定制网站优化哪家好  # 池州好口碑网站建设  # 开阳网站优化推广价格  # 视频解析网站建设文案 


相关栏目: 【 Google疑问12 】 【 Facebook疑问10 】 【 优化推广96088 】 【 技术知识133117 】 【 IDC资讯59369 】 【 网络运营7196 】 【 IT资讯61894


相关推荐: 《绝区零》2.3前瞻|直播|内容介绍  使用TinyButStrong生成HTML并结合Dompdf创建PDF教程  CodeIgniter 3 连接 SQL Server:正确获取查询结果的教程  J*aScript包管理器_Npm与Yarn对比  VBA Outlook邮件自动化:高效集成Excel数据与列标题的策略  哈尔滨城市通昵称修改方法  PHP实现等比数列:构建数组元素基于前一个值递增的方法  CSS过渡如何实现按钮悬停效果_transition属性控制背景颜色变化  c++如何掌握指针的核心用法_c++指针入门到精通指南  Lar*el如何创建自定义的辅助函数(Helpers)_Lar*el全局函数定义与加载方法  TikTok搜索结果不显示怎么办 TikTok搜索刷新与优化方法  《edge浏览器》关闭翻译功能方法  睡觉时心跳快是什么原因 夜间心悸如何应对  外媒评《燕云十六声》DIY载具新玩法:很像《塞尔达传说王国之泪》!  Go Goroutine调度与并发执行深度解析  Lar*el 关联查询:同时筛选父表与子表数据的高效策略  windows10怎么关闭自动安装应用_windows10禁止推广应用下载  C++ switch case字符串_C++如何实现字符串switch匹配  创建您的便携版VS Code:让配置随身携带  热血江湖归来医师加点攻略  智慧职教mooc平台登录网址 智慧职教mooc官网直达  英国搜索:多数英国人认为语言搜索是未来搜索  AngularJS动态内容中DOM元素查找的时序问题及$timeout解决方案  J*a中导出MySQL表为SQL脚本的两种方法  Flexbox布局:实现粘性导航与底部页脚的完美结合  Final Cut Pro视频加EQ教程  《U校园》学生登录入口2025  哔哩哔哩黑名单怎么查看  优化Leaflet弹出层图片显示:条件渲染策略  excel怎么制作考勤表 excel考勤模板与函数公式讲解  ExcelSCAN与LAMBDA如何创建自定义移动平均函数_SCAN实现任意窗口期移动平均计算  解决Pandas DataFrame高度碎片化警告:高效创建多列的策略  快递查询,一键速查  网易云音乐闹钟铃声设置教程  深入理解随机递归函数的确定性:内部节点、叶节点与时间复杂度分析  TikTok视频播放不流畅怎么办 TikTok视频播放优化方法  微信注销后银行卡解绑了吗_微信注销后银行卡解绑状态  FullCalendar自定义按钮样式定制指南  邮编号码查询app有哪些_邮编号码查询推荐app及使用体验  《杖剑传说》食谱大全  cad加载的线型看不见怎么办_cad线型不可见问题解决方法  钉钉任务无法提醒如何处理 钉钉任务提醒优化方法  重返未来:1999卡戎全方位攻略  优酷下载视频的清晰度怎么选_优酷缓存清晰度设置与选择指南  《雷电模拟器》截图方法介绍  邮政快递寄件查询入口 邮政快递收件查询入口  小米手机截图后如何查看历史_小米手机截图历史记录查看方法  Win10如何关闭操作中心通知 Win10免打扰设置全攻略【清爽】  B站怎么开|直播| B站|直播|申请需要什么条件【新手必看】  多闪电脑版下载_多闪PC端模拟器使用 

 2025-11-28

了解您产品搜索量及市场趋势,制定营销计划

同行竞争及网站分析保障您的广告效果

点击免费数据支持

提交您的需求,1小时内享受我们的专业解答。

运城市盐湖区信雨科技有限公司


运城市盐湖区信雨科技有限公司

运城市盐湖区信雨科技有限公司是一家深耕海外推广领域十年的专业服务商,作为谷歌推广与Facebook广告全球合作伙伴,聚焦外贸企业出海痛点,以数字化营销为核心,提供一站式海外营销解决方案。公司凭借十年行业沉淀与平台官方资源加持,打破传统外贸获客壁垒,助力企业高效开拓全球市场,成为中小企业出海的可靠合作伙伴。

 8156699

 13765294890

 8156699@qq.com

Notice

We and selected third parties use cookies or similar technologies for technical purposes and, with your consent, for other purposes as specified in the cookie policy.
You can consent to the use of such technologies by closing this notice, by interacting with any link or button outside of this notice or by continuing to browse otherwise.