A. php sql not in什麼意思
sql里 not in意思是不屬於某個集合,比如not in ('a','b','c','d')指的是不屬於'a','b','c','d'這個集合
B. php連接MySQL可以通過select語句的limit來實現分頁,但是MS SQL2000不支持limit這個屬性如何實現分頁
include("conn_mssql.php");
$a=$pagesize*($page-1);
$b=$pagesize;
ok=mssql_query(" select top $b ID from TABLE where ID not in(select top $a ID from TABLE order by ID) order by UserID ", $conn);
可以用這個語句 去實現:「select top $b ID from TABLE where ID not in(select top $a ID from TABLE order by ID) order by UserID」
C. 在PHP中使用SQL語句 怎麼取出查詢出來的最後一個數據
在PHP中使用SQL語句可以通過倒序排列記錄取出第一條的記錄取到最後一條數據。
一般,php調用mysql的介面查詢,查詢語句如下:
select * from table order by id DESC limit 1
這樣就取出記錄的最後一條記錄。
D. php sql語句刪除重復並保存一條
意思是說,不能先select出同一表中的某些值,再update這個表(在同一語句中)。
改寫成下面就行了:
delete from tbl where id in
(
select a.id from
(
select max(id) id from tbl a where EXISTS
(
select 1 from tbl b where a.tac=b.tac group by tac HAVING count(1)>1
)
group by tac
) a
)
將select出的結果再通過中間表select一遍,這樣就規避了錯誤。注意,這個問題只出現於mysql,mssql和oracle不會出現此問題。
E. 如何利用PHP執行.SQL文件
以下代碼來自PHPBB的SQL文件解析類,原理就是逐行的解釋SQL文件,並進行刪除等操作,可以參照修改。希望能幫到你。
<?php
ini_set('memory_limit','5120M');
set_time_limit(0);
/***************************************************************************
*sql_parse.php
*-------------------
*begin:ThuMay31,2001
*right:(C)2001ThephpBBGroup
*email:[email protected]
*
*$Id:sql_parse.php,v1.82002/03/1823:53:12psotfxExp$
*
****************************************************************************/
/***************************************************************************
*
*Thisprogramisfreesoftware;youcanredistributeitand/ormodify
*
*theFreeSoftwareFoundation;eitherversion2oftheLicense,or
*(atyouroption)anylaterversion.
*
***************************************************************************/
/***************************************************************************
*
*_utilitiesundertheadmin
*,specifically
*
*functionsintothisfile.JLH
*
***************************************************************************/
//
//remove_
//....
//
functionremove_comments(&$output)
{
$lines=explode(" ",$output);
$output="";
//trytokeepmem.usedown
$linecount=count($lines);
$in_comment=false;
for($i=0;$i<$linecount;$i++)
{
if(preg_match("/^/*/",preg_quote($lines[$i])))
{
$in_comment=true;
}
if(!$in_comment)
{
$output.=$lines[$i]." ";
}
if(preg_match("/*/$/",preg_quote($lines[$i])))
{
$in_comment=false;
}
}
unset($lines);
return$output;
}
//
//remove_
//
functionremove_remarks($sql)
{
$lines=explode(" ",$sql);
//trytokeepmem.usedown
$sql="";
$linecount=count($lines);
$output="";
for($i=0;$i<$linecount;$i++)
{
if(($i!=($linecount-1))||(strlen($lines[$i])>0))
{
if(isset($lines[$i][0])&&$lines[$i][0]!="#")
{
$output.=$lines[$i]." ";
}
else
{
$output.=" ";
}
//Tradingabitofspeedforlowermem.usehere.
$lines[$i]="";
}
}
return$output;
}
//
//split_sql_.
//Note:expectstrim()tohavealreadybeenrunon$sql.
//
functionsplit_sql_file($sql,$delimiter)
{
//Splitupourstringinto"possible"SQLstatements.
$tokens=explode($delimiter,$sql);
//trytosavemem.
$sql="";
$output=array();
//wedon'.
$matches=array();
//thisisfasterthancallingcount($oktens)everytimethrutheloop.
$token_count=count($tokens);
for($i=0;$i<$token_count;$i++)
{
//Don'.
if(($i!=($token_count-1))||(strlen($tokens[$i]>0)))
{
//.
$total_quotes=preg_match_all("/'/",$tokens[$i],$matches);
//,
//whichmeansthey'reescapedquotes.
$escaped_quotes=preg_match_all("/(?<!\\)(\\\\)*\\'/",$tokens[$i],$matches);
$unescaped_quotes=$total_quotes-$escaped_quotes;
//,.
if(($unescaped_quotes%2)==0)
{
//It'sacompletesqlstatement.
$output[]=$tokens[$i];
//savememory.
$tokens[$i]="";
}
else
{
//incompletesqlstatement..
//$tempwillholdwhatwehavesofar.
$temp=$tokens[$i].$delimiter;
//savememory..
$tokens[$i]="";
//Dowehaveacompletestatementyet?
$complete_stmt=false;
for($j=$i+1;(!$complete_stmt&&($j<$token_count));$j++)
{
//.
$total_quotes=preg_match_all("/'/",$tokens[$j],$matches);
//,
//whichmeansthey'reescapedquotes.
$escaped_quotes=preg_match_all("/(?<!\\)(\\\\)*\\'/",$tokens[$j],$matches);
$unescaped_quotes=$total_quotes-$escaped_quotes;
if(($unescaped_quotes%2)==1)
{
//oddnumberofunescapedquotes.
//statement(s),wenowhaveacompletestatement.(2oddsalwaysmakeaneven)
$output[]=$temp.$tokens[$j];
//savememory.
$tokens[$j]="";
$temp="";
//exittheloop.
$complete_stmt=true;
//.
$i=$j;
}
else
{
//evennumberofunescapedquotes.Westilldon'thaveacompletestatement.
//(1oddand1evenalwaysmakeanodd)
$temp.=$tokens[$j].$delimiter;
//savememory.
$tokens[$j]="";
}
}//for..
}//else
}
}
return$output;
}
$dbms_schema='yourfile.sql';
$sql_query=@fread(@fopen($dbms_schema,'r'),@filesize($dbms_schema))ordie('problem');
$sql_query=remove_remarks($sql_query);
$sql_query=split_sql_file($sql_query,';');
$host='localhost';
$user='user';
$pass='pass';
$db='database_name';
mysql_connect($host,$user,$pass)ordie('errorconnection');
mysql_select_db($db)ordie('errordatabaseselection');
$i=1;
foreach($sql_queryas$sql){
echo$i++;
echo"
";
mysql_query($sql)ordie('errorinquery');
}
?>
F. 有關PHP中的SQL語句問題
可能是主鍵沖突了,AUTO_INCREMENT = 5 改為 AUTO_INCREMENT = 1
另外,趙六的id應該是4,不是3.
G. 在thinkphp中想用not in和子查詢組合一個sql,這個該怎麼寫
$model=M("b");
$subQuery=$model->field('id')->where($map)->buildSql();
$modle2=M("a");
$List=$model2->where('idnotin'.$subQuery)->select();
這是thinkphp3.0的新特性貌似
H. php SQL語句
COUNT 和 (*) 之間不能有空格。
如果以下變數的設置正確:
$mysql_server_name,$mysql_username,$mysql_password
$mysql_database
程序應該能出結果。
為了讓程序不出錯誤,可以這樣:
$result=mysql_db_query($mysql_database,$sql,$conn);
if($result) {
$row=mysql_fetch_row($result);
print_r($row); // 調試
}