insert() 增加数据、delete()删除指定条件数据、listinfo()读取支持翻页的多条数据、select()读取多条数据、update()更新数据.
当然,还有很多方法,以及各方法的传参各代表什么意义都有详细的注释看看就会明白的.
那么我们在控制器中应该如何引入一个数据表的model并对其进行数据操作呢,例如我在首页控制器中获取最近注册的10个会员账号信息,可以这么写:
$member_db?=?pc_base::load_model("members_model");
$member_list?=?$member_db-select(array('islock'=0),"*",10,"id?desc");
!--使用对应的方法获取数据--
就演示到这里吧,如果有mvc架构基础应该一看就懂的,更多的关于phpcms的二次开发深入可以参考官方开发手册、代码中的注释说明以及iphpcms里的二次开发视频教程.
举例如下:
创建userinfo_update.php页面用于查询用户信息,先显示信息,在修改:
先通过GET获取用户编号查询用户信息:
$sql = "select * from user_info where user_id='".$_GET['userId']."'";
$result = mysql_query($sql,$con);
if($row = mysql_fetch_array($result)){
}
页面效果:
创建update.php文件,用于修改用户信息:
使用到了mysql_affected_rows() 函数返回前一次 MySQL 操作所影响的记录行数.
//通过post获取页面提交数据信息
$userId = $_POST[userId];
$userName = $_POST[userName];
$userAge = $_POST[userAge];
$sql = "update user_info set user_name='".$userName."',user_age=".$userAge." where user_id='".$userId."'";
mysql_query($sql,$conn);//执行SQL
$mark? = mysql_affected_rows();//返回影响行数
$url = "userinf_select.php";
运行结果
创建delete.php文件,完成删除用户信息功能:
$userId = $_GET['userId'];
include 'connection.php';
$sql = "delete from user_info where user_id='".$userId."'";
mysql_query($sql,$con);
if($mark0){
echo "删除成功";
}else{
echo? "删除失败";
mysql_close($con);
运行结果:
class sqlHelper{
public $conn;
public $dbname="数据库名称";
public $username="数据库用户名";
public $password="数据库密码";
public $host="localhost";
//连接数据库
public function __construct(){
$this-conn=mysql_connect($this-host,$this-username,$this-password);
if(!$this-conn){
die("连接失败".mysql_error());
mysql_select_db($this-dbname,$this-conn);
//执行查询语句
public function execute_dql($sql){
$res=mysql_query($sql,$this-conn);
return $res;
//执行增填改语句
public function execute_dml($sql){
$b=mysql_query($sql,$this-conn);
if(!$b){
if(mysql_affected_rows($this-conn)){
return 1;//表示OK
php
if (!$con) {
die('Could not connect: ' . mysql_error());
mysql_select_db("test", $con);
$result = mysql_query("SELECT * FROM user");
echo "table border='1'
tr
thUsername/th
thPassword/th
/tr";
while($row = mysql_fetch_array($result)) {
echo "tr";
echo "td" . $row['username'] . "/td";
echo "td" . $row['password'] . "/td";
echo "/tr";
echo "/table";
从服务器中获取用户所有信息(SQL SELECT语句)并以表格形式出现
$con = mysql_connect("localhost","root","");
mysql_query("DELETE FROM user WHERE username = '$_POST[username]'");
删除该用户所有信息delete.php
$sql = "INSERT INTO user (username,password)
VALUES
('$_POST[username]','$_POST[password]')";
if (!mysql_query($sql,$con)) {
die('Error: ' . mysql_error());
echo "1 record added";
注册一个新用户insert.php
mysql_query("UPDATE user SET password = '$_POST[password]' WHERE username = '$_POST[username]'");
修改一个用户密码update.php
html
head
titleFORM/title
/head
body
br /
h1Insert:/h1
form action="insert.php" method="post"
username:input type="name" name="username"/
password:input type="password" name="password"/
input type="submit" value="submit"/
/form
br /hr /br /
br /hr /br /
br /hr /br /
h1Delete/h1
form action="delete.php" method="post"
username:input type="name" name="username" /
Are you sure?input type="submit" value="sure" /
br /hr /br /
h1Update/h1
form action="update.php" method="post"
You want to change your password into:input type="password" name="password"/
br /hr /br /
/body
/html
以上三个功能的提交源Operate.html
第一段:PHP操作MySql数据库
新增数据
$query
=
"INSERT
INTO
grade
(name,email,point,regdate)
VALUE
('
;
@mysql_query($query)
or
die(
'添加数据出错:'
.mysql_error());
修改数据
"UPDATE
SET
name='小可爱'
WHERE
'修改出错:'
删除数据
"DELETE
FROM
'删除错误:'
显示数据
"SELECT
id,name,email,point
grade";
$result
'查询语句出错:'
while
(!!
$row
mysql_fetch_array($result))
{
echo
$row[
'id'
].
'----'
.$row['name'
].'----'
.$row
['email'
.$row['point'
];
'br
/
';
第二段:其他常用函数
mysql_f
etch_row()
:从结果集中取得一行作为枚举数组
etch_assoc()
:
从结果集中取得一行作为关联数组
etch_array()
从结果集中取得一行作为关联数组,或数字数组,或二者兼有
etch_lengths
()
取得结果集中每个输出的长度
ield_name():
取得结果中指定字段的字段名
mysql_num_rows():
取得结果集中行的数目
mysql_num_f
ields():取得结果集中字段的数目
mysql_get_client_inf
o()
取得
MySQL
mysql_get_host_info():
主机信息
mysql_get_proto_info():
协议信息
mysql_get_server_inf
服务器信息