這個應(yīng)該可以使用字符串拼接,你是不是這樣寫存儲過程:
我們提供的服務(wù)有:成都網(wǎng)站建設(shè)、網(wǎng)站制作、微信公眾號開發(fā)、網(wǎng)站優(yōu)化、網(wǎng)站認證、錦屏ssl等。為上千多家企事業(yè)單位解決了網(wǎng)站和推廣的問題。提供周到的售前咨詢和貼心的售后服務(wù),是有科學管理、有技術(shù)的錦屏網(wǎng)站制作公司
create procedure p_proc(var_in int)
begin
delete from [tableName] where [colName] in (var_in);
end
然后又這樣調(diào)用:
call p_proc(1, 2, 3);
這樣肯定不行,那么你可以這樣:
create procedure p_proc(var_in varchar(5000))
begin
set @sql = concat("delete from [tableName] where [colName] in (", var_in, ")");
prepare stmt_exe_sql from @sql;
execute stmt_exe_sql;
deallocate prepare stmt_exe_sql;
end
這樣就相當于把(1, 2, 3)拼接成語句"delete from [tableName] where [colName] in (1, 2, 3)", 然后執(zhí)行,就可以刪除了。
select?*?from??mytable?where??name??like?'張%'?limit???3,5;
#查詢?姓名為張??并且取?第三條到第5條的數(shù)據(jù),
#我一般叫做分頁查詢??就是截取從第幾條到第幾條
Mysql操作
創(chuàng)建數(shù)據(jù)庫
新建數(shù)據(jù)庫命令:Createdatabase 數(shù)據(jù)庫
查看所有數(shù)據(jù)庫
命令:Show databases
打開數(shù)據(jù)庫
命令:use? 數(shù)據(jù)庫名
刪除數(shù)據(jù)庫
命令:drop? database 數(shù)據(jù)庫名
創(chuàng)建表
命令:create table 表名(列名? 數(shù)據(jù)類型,列名? 數(shù)據(jù)類型,。。。。。。。)
查看當前數(shù)據(jù)庫下所有表
命令:show tables
查看當前表結(jié)構(gòu)
命令:desc 表名
刪除表
命令:drop table 表名
插入數(shù)據(jù)insert
命令:Insert? into? 表名(字段1,字段2,字段3……)values(值1,值2,值3……)
查看數(shù)據(jù)select
命令:Select 字段1,字段2,……from? 表名。字段之間用“,”隔開,如果查詢所有的字段用“*”來代替。
修改數(shù)據(jù)update
命令:update? 表名?? set 字段名1=‘新值1’,字段名2=‘新值2’ where='條件'? 如果不加where條件那么將會把所有的記錄的值都修改掉。
刪除數(shù)據(jù)delete
命令:delete? from?? 表名?? where?? 條件。如果不加where條件那么將會把所有的記錄都刪除掉。
mysql中的運算符
算術(shù)運算符:
大于:
小于:
等于: =
不等于: !=
大于等于: =
小于等于: =
邏輯運算符:
且: and
或者: or
between.....and.....
Between.....and.....:代表在什么什么之間,通常用于范圍的查詢
in查詢
Delete from 學生表 where id in=10 orid=12 or id=13)
例子 Delete from 學生表 where id in(10,12,13)
排序的order by
Order by為排序的意思,格式為:order by 排序列 desc(指的是降序)?????????????????asc(指的是升序) 默認為升序
例子:Select * from table order by id desc
模糊查詢
模糊查詢通常用于關(guān)鍵字查詢,使用like來代表
% 代表任意多個字符 _ 代表任意一個字符
例如:查詢出姓張的學生姓名
Select * from 學生表 where name like ‘張%’
查詢出學生姓名中包含’大‘的學生信息
Select * from 學生表 where name like’%張%
查詢出電話號的第二位是5的學生信息
elect * from 學生表 where name like’_5%’
limit限制記錄條數(shù)(limit可以減輕mysql壓力,主要用截取和分頁)
偏移量 (分頁時用的) :(當前頁減1)*每頁條數(shù)
偏移量就是 limit 偏移量,每頁條數(shù)
Limit用于限制結(jié)果集,限制查詢出的條數(shù),可以有一個參數(shù)也可以有兩個參數(shù),一個參數(shù)的時候代表從第一條數(shù)據(jù)查詢?nèi)《嗌贄l,兩個參數(shù)的時候,第一個參數(shù)代表從哪條記錄開始,但不包括該條記錄,第二個參數(shù)代表取多少條。
例如:查詢出學生信息前三條
Select * from 學生表 limit 3
Select * from 學生表 limit 0,3
例如:按照學生年齡排序查詢出年齡最大的學生,從第三條開始取5條(排序加截?。?/p>
Select * from 學生表 order by age desclimit 2,5
偏移量就是 limit 偏移量,每頁條數(shù)
給表起別名 as
起別名用關(guān)鍵字 as
給表起別名:select * from 表名別名
給列起別名:select name as 用戶名,sex as 性別 from 表名
關(guān)聯(lián)查詢
內(nèi)連接查詢數(shù)據(jù)
內(nèi)連接又稱全鏈接,用關(guān)鍵字inner? join表示,內(nèi)連接查詢兩張表中的數(shù)據(jù),如果關(guān)聯(lián)的條件相等,也就是兩張表中同時存在的數(shù)據(jù)才會被查詢出來
例如: Select * from 新聞表 inner join 分類表 on 新聞表.分類id=分類表.id
左外連接
左外連接用關(guān)鍵字left join 表示,以from后面的表為主表,去left join后面的表中匹配數(shù)據(jù),如果匹配的不到則顯示null
例如: Select * from 新聞表 left join 分類表 on 新聞表.分類id=分類表.id
右外連接
右外連接用關(guān)鍵字right join 表示,以from后面的表為主表,去right join后面的表中匹配數(shù)據(jù),如果匹配的不到則顯示null
例如: Select * from 新聞表 right join 分類表 on 新聞表.分類id=分類表.id
注意:where什么時候用什么時候不用
(inner join連接)(where條件)(like模糊查詢)(limit限制條數(shù))(desc排序)
例子:
Select * from table where id=1
Select * from table where id in (n....) like %%
Select * from table right join ... on...=... where id=1
Select * from table limit 1
Select * from table limit 30 desc id
Select * from table where id=1
select * from `res_students`
inner join `res_class` on `res_class`.`class_id`= `res_students`.`class_id` inner join `res_grade` on `res_sgrade`.`sid` =`res_students`.`sid`
where `res_students`.`class_id`= 1 and `g_add_date` = 2016-08-07
order by `res_grade`.`sid` asc
表名.鍵名 這樣可以防止表里的鍵名相同導(dǎo)致報錯
表名和鍵名注意關(guān)鍵字 鍵盤上esc按鍵下(橫向數(shù)字1左邊的按鍵)面的符號
` 可以防止關(guān)鍵字
php操作mysql的步驟
Php操作mysql必須讓php打開mysql擴展:
打開php.ini文件,找到:;extension=php_mysql.dll將前面的分號去掉,重啟apache即可讓php支持mysql擴展
編寫程序調(diào)試php是否真正能夠連接mysql:
① 連接數(shù)據(jù)庫:mysql_connect(“數(shù)據(jù)庫地址”,’管理員名稱’,’管理員密碼’)
② 選擇數(shù)據(jù)庫:mysql_select_db(“庫名”,第一步返回的連接標識)
③ 設(shè)置字符集:mysql_query(‘set names utf8’);
④ 拼寫sql語句執(zhí)行,mysql_query(‘增刪改查都可以’)
Php操作mysql常用函數(shù):
mysql_connect():打開一個數(shù)據(jù)庫連接,三個參數(shù),第一個參數(shù)是數(shù)據(jù)庫的地址,第二個參數(shù)是管理員名,第三個參數(shù)是密碼? 返回一個數(shù)據(jù)庫連接標識
mysql_select_db():選擇數(shù)據(jù)庫,有兩個參數(shù) 第一個參數(shù)是數(shù)據(jù)庫名稱,第二個參數(shù),mysql_connect返回的數(shù)據(jù)庫標識
mysql_query():執(zhí)行sql語句? 對select返回的是資源?對于其它類型的 SQL 語句,mysql_query() 在執(zhí)行成功時返回 TRUE,出錯時返回 FALSE。
mysql_fetch_array():從結(jié)果集中取得一行作為關(guān)聯(lián)數(shù)組,或數(shù)字數(shù)組,或二者兼有
mysql_fetch_array($res,MYSQL_NUM)這將是索引數(shù)組
mysql_fetch_array($res,MYSQL_ASSOC)這將是關(guān)聯(lián)數(shù)組
mysql_fetch_assoc():從結(jié)果集中取得一行作為關(guān)聯(lián)數(shù)組
mysql_fetch_row():從結(jié)果集中取得一行作為索引數(shù)組
mysql_insert_id():取得剛剛插入自動增長的id?不需要寫任何參數(shù)
例子:
?php
//注意 php版本要 小于等于 5.3
header("content-type:text/html;charset=utf-8");
$link=mysql_connect("127.0.0.1",'root','root') or die('連接數(shù)據(jù)庫錯誤');
mysql_select_db("test",$link) or die('選擇數(shù)據(jù)庫錯誤');
//mysql_select_db 第二個參數(shù)可要可不要 就近原則
mysql_query("set names utf8");
$sql='select * from bumen';
$res=mysql_query($sql);
?
?php
//服務(wù)器端文件代碼:
//header頭前不能有輸出
header("content-type:text/html;charset=utf-8");
//接受用戶注冊的信息
$name=$_POST['username'];
$pwd=$_POST['pwd'];
$sex=$_POST['sex'];
$bumen=$_POST['bumen'];
$jianjie=$_POST['jianjie'];
//① 連接數(shù)據(jù)庫 mysql_connect('數(shù)據(jù)庫的ip','管理員名稱','密碼'); 返回一個數(shù)據(jù)庫連接標識是個資源
$link=mysql_connect('127.0.0.1','root','root')or die("數(shù)據(jù)庫連接失敗");
//② 選擇數(shù)據(jù)庫 mysql_select_db('庫名',數(shù)據(jù)庫的連接標識)
mysql_select_db('tt',$link);
echo mysql_error();
die;
//③ 設(shè)置數(shù)據(jù)庫的字符集 mysql_query('set namesutf8')
mysql_query('set names utf8');
//④ 寫sql語句進行執(zhí)行,增、刪、改、查都可以的 用mysql_query()來執(zhí)行
//注意:mysql_query()對于select返回的是一個資源,其他的也就是delete、insert、update返回的都是布爾也就是真或者假
$sql="insert into yuangong (name,pwd,sex,bumen,jianjie)values('$name','$pwd','$sex','$bumen','$jianjie')";
if(mysql_query($sql)){
echo "添加成功!";
}else{
echo "添加失??!";
}
?
數(shù)據(jù)庫可視化操作工具
navicat (window安裝收費)
phpmyadmin(免費跨平臺,不用安裝 php)
mysql中有4類運算符,它們是:
算術(shù)運算符
比較運算符
邏輯運算符
位操作運算符
算術(shù)操作符
算術(shù)操作符是SQL中最基本的操作運算符,主要有一下幾種運算符:
+(加)、 -(減)、 *(乘)、 /(除)、 %(求余或者模)
比較運算符
一個比較運算符的結(jié)果總是1,0或者是NULL。MySQL中的比較運算符有:
=、=、 (!=)、=、=、、IS NULL、IS NOT NULL、LEAST、GREATEST、BETWEEN . . . AND. . . 、ISNULL、IN、NOT IN、LIKE、REGEXP
邏輯運算符
邏輯運算符的求值所得結(jié)果均為TRUE、FALSE或NULL。
邏輯運算符有:
NOT 或者 !
AND 或者
OR 或者 ||
XOR(異或)
位運算符
位運算符是用來對二進制字節(jié)中的位進行測試、移位或者測試處理。位運算符有:
位或(|)
位與()
位異或(^ )
位左移()
位右移()
位取反(~)