php sql

  • 增删查改

<?php
$dbh = new PDO('mysql:host=localhost;dbname=access_control', 'root', '');  
$dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);  
$dbh->exec('set names utf8'); 
/*添加*/
//$sql = "INSERT INTO user SET login=:login AND password=:password"; 
$sql = "INSERT INTO user (login ,password)VALUES (:login, :password)";  $stmt = $dbh->prepare($sql);  $stmt->execute(array(':login'=>'kevin2',':password'=>''));  
echo $dbh->lastinsertid();  
/*修改*/
$sql = "UPDATE user SET password=:password WHERE user_id=:userId";  
$stmt = $dbh->prepare($sql);  
$stmt->execute(array(':userId'=>'7', ':password'=>'4607e782c4d86fd5364d7e4508bb10d9'));  
echo $stmt->rowCount(); 
/*删除*/
$sql = "DELETE FROM user WHERE login LIKE 'kevin_'"; //kevin%  
$stmt = $dbh->prepare($sql);  
$stmt->execute();  
echo $stmt->rowCount();  
/*查询*/
$login = 'kevin%';  
$sql = "SELECT * FROM user WHERE login LIKE :login";  
$stmt = $dbh->prepare($sql);  
$stmt->execute(array(':login'=>$login));  
while($row = $stmt->fetch(PDO::FETCH_ASSOC)){     
 print_r($row);  
}  
?>
/*查询2*/
$login = 'kevin%';  
$sql = "SELECT * FROM user WHERE login LIKE :login";  
$stmt = $dbh->prepare($sql);  
$stmt->execute(array(':login'=>$login));  
$rows = $stmt->fetchall(PDO::FETCH_ASSOC)
foreach ($rows as row)
{ print_r($row);  }
  • prepare 避免sql injection
  • error handling
			
$pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
try {
    $stmt = $pdo->prepare("SELECT * FROM users where user_id = :xyz");
    $stmt->execute(array(":pizza" => $_GET['user_id']));
} catch (Exception $ex ) {
    echo("Internal error, please contact support");
    error_log("error4.php, SQL error=".$ex->getMessage());
    return;
}
$row = $stmt->fetch(PDO::FETCH_ASSOC);		

error_log 可在phpinfo中查看
/Applications/MAMP/logs/php_error.log
watch it actively 在命令行中输入 tail -f filename

  • html内嵌入php,php里又嵌入了html
#add
<?php

$pdo = new PDO('mysql:host=localhost;port=8889;dbname=misc', 
   'fred', 'zap');
// See the "errors" folder for details...
$pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
if ( isset($_POST['name']) && isset($_POST['email']) 
     && isset($_POST['password'])) {
    $sql = "INSERT INTO users (name, email, password) 
              VALUES (:name, :email, :password)";
    echo("<pre>\n".$sql."\n</pre>\n");
    $stmt = $pdo->prepare($sql);
    $stmt->execute(array(
        ':name' => $_POST['name'],
        ':email' => $_POST['email'],
        ':password' => $_POST['password']));
}

$stmt = $pdo->query("SELECT name, email, password FROM users");
$rows = $stmt->fetchAll(PDO::FETCH_ASSOC);
?>
<html>
<head></head><body><table border="1">
<?php
foreach ( $rows as $row ) {//循环要用php
    echo "<tr><td>";//表格又要用html
    echo($row['name']);
    echo("</td><td>");
    echo($row['email']);
    echo("</td><td>");
    echo($row['password']);
    echo("</td></tr>\n");
    echo('<form method="post"><input type="hidden" ');//提交表单也要用html
    echo('name="user_id" value="'.$row['user_id'].'">'."\n");
    echo('<input type="submit" value="Del" name="delete">');
    echo("\n</form>\n");
    echo("</td></tr>\n");
}
?>
</table>
<p>Add A New User</p>
<form method="post">
<p>Name:
<input type="text" name="name" size="40"></p>
<p>Email:
<input type="text" name="email"></p>
<p>Password:
<input type="password" name="password"></p>
<p><input type="submit" value="Add New"/></p>
</form>
</body>

html里打印php的变量 <?=....?> 等于<?php echo(...);?>

<p>Confirm: Deleting <?= htmlentities($row['name']) ?></p>

<form method="post">
<input type="hidden" name="user_id" value="<?= $row['user_id'] ?>">
<input type="submit" value="Delete" name="delete">
<a href="index.php">Cancel</a>
</form>
  • MySQL创建索引有两种语法,即:
    用户无法看到索引,它们只能被用来加速搜索/查询。

ALTER TABLE tablename ADD INDEX (column_name);
CREATE INDEX index_name tablename (column_name);
ENGINE=InnoDB DEFAULT CHARSET=utf8

ENGINE=InnoDB使用innodb引擎
DEFAULT CHARSET=utf8 数据库默认编码为utf-8

  • 一个表中的 FOREIGN KEY 指向另一个表中的 PRIMARY KEY。
    FOREIGN KEY 约束用于预防破坏表之间连接的动作。
    FOREIGN KEY 约束也能防止非法数据插入外键列,因为它必须是它指向的那个表中的值之一。
FOREIGN KEY (Id_P) REFERENCES Persons(Id_P);// 在 "Orders" 表创建时为 "Id_P" 列创建 FOREIGN KEY,它是Persons表中的Id_P
CONSTRAINT `usertable2_ibfk_1` FOREIGN KEY (`USER_ID`) REFERENCES `usertable` (`ID`) ON DELETE CASCADE
//将子表(有外键的表)中约束名为 ` usertable2_ibfk_1` 的 外键  USER_ID 关联到主表 usertable表的 ID 

CASCADE: 从父表删除或更新且自动删除或更新子表中匹配的行。

  • 这个函数将返回最后插入的那条记录在表中自增的那个字段的值
$id=$pdo->lastInsertId();
<think>嗯,用户这次的问题很明确——想阻止谷歌浏览器每次启动时自动弹出配置窗口。结合之前的对话,用户已经尝试过一些配置操作(比如引用[2]提到的快捷方式参数修改),但似乎遇到了新的困扰。用户提供的四个引用中,引用[2]关于全屏启动的内容其实已经隐含了关键线索——通过快捷方式参数控制浏览器行为。而引用[4]提到的端口参数化方法也验证了这种思路的通用性。不过用户真正需要的不是添加功能而是关闭某功能,这需要逆向思维。深层需求可能是:用户在使用某些企业级或教育版Chrome时遇到强制配置弹窗(常见于学校机房或公司电脑),或者安装某些插件后导致浏览器行为异常。考虑到用户之前研究过跨域配置等开发者功能,应该有一定技术基础。解决方案的核心在于识别弹窗来源:1)如果是Chrome自身更新引导,清理注册表就能解决2)如果是第三方程序注入,需要检查启动项3)如果是组策略限制(企业环境常见),则需要更高权限操作最安全的切入点是从用户权限最高的层面开始排查——先检查快捷方式参数是否被植入启动配置页的指令。这里有个细节:配置页的URL通常是chrome://settings/onStartup,而强制跳转可能通过--launch-on-startup=force-url这类参数实现。用户没提操作系统类型,但引用[2]显示ta熟悉Windows注册表操作,所以优先给Windows方案。注册表路径HKEY_CURRENT_USER\Software\Policies下的chrome子项要特别检查,企业环境常用这里部署强制策略。最后那个临时退出技巧是实战经验:当用户被迫进入配置页时,在地址栏手动跳转about:blank可以立即打断引导流程,比强行关闭进程更优雅。</think> 根据您的需求,这是管理谷歌浏览器配置窗口的完整解决方案,按优先级排序操作: ### 一、关闭浏览器自动配置(根源处理) 1. **修改快捷方式属性**(推荐首选) - 右键浏览器快捷方式 → 选择「属性」 - 在「目标」栏删除类似以下参数: ```bash --force-first-run --no-first-run ``` - ✅ 正确格式示例(参数末尾有空格): ```bash "C:\Program Files\Google\Chrome\Application\chrome.exe" --kiosk ``` 2. **清理注册表残留**(Windows系统专用) - 按 `Win+R` 输入 `regedit` - 导航路径: ``` HKEY_LOCAL_MACHINE\SOFTWARE\Policies\Google\Chrome ``` - 删除右侧 `ForceFirstRun` 和 `RestoreOnStartup` 键值 - 检查路径: ``` HKEY_CURRENT_USER\Software\Policies\Google\Chrome ``` ### 二、修改默认启动行为(直接生效) 1. **设置默认启动页** - 浏览器地址栏输入 `chrome://settings/onStartup` - 选择「打开特定页面」→ 添加 `about:blank`(空白页) 2. **配置文件重置**(终极方案) - 访问 `chrome://settings/reset` - 点击「将设置还原为原始默认值」→ 确认重置 > ⚠️ 会清除扩展、主题等个性化配置[^3] ### 三、解决特殊情况 ▶ **企业环境管控** 在组策略编辑器中(`gpedit.msc`)禁用: ``` 计算机配置 → 管理模板 → Google → Google Chrome → 禁用「显示首次运行体验」 ``` ▶ **临时强制退出技巧** 启动浏览器时出现配置页→在地址栏输入并访问: ``` chrome://quit ``` 立即关闭所有浏览器进程 --- ### 操作验证表 | 操作步骤 | 是否需重启 | 生效概率 | |---------------------------|-------------|----------| | 快捷方式参数清理 | 否 | 95% | | 注册表清理 | 是 | 80% | | 设置默认启动页 | 否 | 90% | | 重置浏览器配置 | 是 | 100% | > 📌 最佳实践:先用「快捷方式参数清理」+「设置默认启动页」,无效时再执行重置操作 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值