我们假设数据库中有三张表。
a,b,c,每个表有几个字段,也有很多数据,
那么你的问题到底是如下哪种
1:删除掉该数据库中的所有表,a,b,c
2:把所有表的数据都清空,表结构保留
3:把表中所有的数据都变为整形数值0?
补充1:
如果你是3的问题的话,实现起来比较繁琐,并且我也不是很理解为什么要这样做,感觉挺没什么意义的,如果方便的话可以告诉我你的目的是什么,为什么要把所有的数据都变成0,或许可以换些办法
补充2:
听你的描述你可能是只有一个表,表中有很多的字段,每个字段都代表一个投票项目,而表中的数据记录,其实只有一条?
你可以通过pg_num_fields获得字段数量,在通过pg_field_name获得字段名称,依次运行update
$dbconn = pg_connect("host=localhost")
$res = pg_query($dbconn, "select * from your_talbe_name")
$i = pg_num_fields($res)
for ($j = 0$j <$i$j++) {
$fieldname = pg_field_name($res, $j)
pg_query($dbconn, "update your_talbe_name set $fieldname=0")
}
另外,我个人认为你这样实现投票的管理不是很好,投票项目一多很难管理,建议
create table xxx
(
id serial primary key,
name text,
num int
)
把投票项目的名字也就是你原来列的名称放到name字段中,num则为投票数,这样以后再有这种问题,一个update xxx set num=0就OK了,管理起来也方便些。
你好,删除命令如下:-bash-3.2$ createdb abc -O playboy
CREATE DATABASE
-bash-3.2$ dropdb abc //dropdb删除数据库
DROP DATABASE
-bash-3.2$ createdb abc -O playboy
CREATE DATABASE
-bash-3.2$ psql -U playboy -d playboy
Welcome to psql 8.1.23, the PostgreSQL interactive terminal.
type: copyright for distribution terms
h for help with SQL commands
? for help with psql commands
g or terminate with semicolon to execute query
q to quit
playboy=>drop database abc//登录后的删除数据库,注意,不能删除当前登录的数据库
DROP DATABASE
删除 *** 作的前提是,你是超级用户,或者是该数据库的拥有者才行。表也一样,pgsql有一点很特别,就是库是你的,表不一定是你的。这个有点搞。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)