php public function,public_function.php

本文档介绍了使用mysqli_connect进行数据库连接,包括设置字符集、使用数据库,以及函数query、fetchAll和fetchRow的使用方法。重点讲解了如何安全处理输入数据以防SQL注入。

function dbInit(){

$link=mysqli_connect('localhost','root','','itcast');

if(!$link){

die('Connect Error (' . mysqli_connect_errno() . ') '

. mysqli_connect_error());

}

mysqli_query($link,'set names utf8');

mysqli_query($link,'use `itcast`');

}

function query($sql) {

$link=mysqli_connect('localhost','root','','itcast');

if ($result = mysqli_query($link,$sql)) {

//执行成功

return $result;

} else {

//执行失败

echo 'SQL执行失败:
';

echo '错误的SQL为:', $sql, '
';

echo die('Connect Error (' . mysqli_connect_errno() . ') '

. mysqli_connect_error());

}

}

function fetchAll($sql) {

//执行query()函数

if ($result = query($sql)) {

//执行成功

//遍历结果集

$rows = array();

while( $row = mysqli_fetch_array($result, MYSQLI_ASSOC)) {

$rows[] = $row;

}

//释放结果集资源

mysqli_free_result($result);

return $rows;

} else {

//执行失败

return false;

}

}

function fetchRow($sql) {

//执行query()函数

if ($result = query($sql)) {

//从结果集取得一次数据即可

$row = mysqli_fetch_array($result, MYSQLI_ASSOC);

return $row;

} else {

return false;

}

}

function safeHandle($data){

//转义字符串中的HTML标签

$data = htmlspecialchars($data);

//转义字符串中的特殊字符

$data = mysqli_real_escape_string($data);

return $data;

}

一键复制

编辑

Web IDE

原始数据

按行查看

历史

### 语法正确性 该 SQL 语句的语法基本正确,不过在标准的 PostgreSQL 语法里,`EXECUTE FUNCTION` 这种写法并不准确,正确的应该是 `EXECUTE PROCEDURE`。所以,正确的语句如下: ```sql CREATE TRIGGER update_time_category BEFORE UPDATE ON public.t_category FOR EACH ROW EXECUTE PROCEDURE public.update_time(); ``` ### 功能解释 - **触发器名称**:`update_time_category` 是这个触发器的名字,用于唯一标识该触发器。 - **触发时机**:`BEFORE UPDATE` 表明这个触发器会在对 `public.t_category` 表执行 `UPDATE` 操作之前触发。 - **触发范围**:`FOR EACH ROW` 意味着触发器会针对每一行受 `UPDATE` 操作影响的记录都执行一次。 - **执行函数**:`EXECUTE PROCEDURE public.update_time()` 表示触发器触发时会调用 `public` 模式下的 `update_time` 函数。 ### 优化建议 - **错误处理**:要保证 `public.update_time` 函数内部有合适的错误处理机制,防止因为函数执行出错而导致整个 `UPDATE` 操作失败。 - **性能考量**:检查 `public.update_time` 函数的实现,防止在函数内部进行大量的计算或者复杂的查询,从而影响性能。 - **权限检查**:确保执行创建触发器操作的用户具备在 `public.t_category` 表上创建触发器的权限,同时也有调用 `public.update_time` 函数的权限。 ### 示例优化后的函数 假设 `update_time` 函数的作用是更新记录的 `updated_at` 字段为当前时间,下面是一个示例函数: ```sql CREATE OR REPLACE FUNCTION public.update_time() RETURNS TRIGGER AS $$ BEGIN NEW.updated_at := NOW(); RETURN NEW; END; $$ LANGUAGE plpgsql; ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值