給你一個(gè)稍微復(fù)雜一點(diǎn)的查詢,我設(shè)計(jì)的
創(chuàng)新互聯(lián)專注于東莞企業(yè)網(wǎng)站建設(shè),響應(yīng)式網(wǎng)站設(shè)計(jì),成都商城網(wǎng)站開發(fā)。東莞網(wǎng)站建設(shè)公司,為東莞等地區(qū)提供建站服務(wù)。全流程定制網(wǎng)站,專業(yè)設(shè)計(jì),全程項(xiàng)目跟蹤,創(chuàng)新互聯(lián)專業(yè)和態(tài)度為您提供的服務(wù)
看上圖我把第一列標(biāo)簽后面的控件命名有規(guī)律,比如計(jì)劃工廠后面文本框是"計(jì)劃工廠t",Exapt命名為"計(jì)劃工廠c",后面還隱藏一個(gè)listbox,命名為"計(jì)劃工廠l"。
計(jì)劃工廠 ?這個(gè)名稱本身就是我要查詢的表里面包含的字段。
利用這種界面,我要完成一些復(fù)雜點(diǎn)的查詢:點(diǎn)文本框里的小圖標(biāo)按鈕,彈出工具,可以輸入多條件,條件可以成立為模糊條件(用*代替不認(rèn)識部分),也可以成立為否決條件。
選中Exapt全部否定所成立條件;點(diǎn)擊執(zhí)行按鈕,有條件的成立條件,無條件的不成立。
所以這種東西貫穿軟件我就不能每個(gè)都去做,就只能寫一個(gè)類文件:
public?class?conditionset
{
public?void?load_condit(Panel?p)
{
foreach?(Control?ctl?in?p.Controls)
{
if?(ctl?is?SkinTextBox)
{
SkinTextBox?sktxt?=?(SkinTextBox)p.Controls[ctl.Name];
ListBox?list?=?(ListBox)p.Controls[sktxt.Name.Substring(0,?sktxt.Name.Length?-?1)?+?"l"];
sktxt.IconClick?+=?(Object?sen,?EventArgs?ed)?=
{
ctl.condition?toolform?=?new?ctl.condition();
if?(list.Items.Count??0)
{
sktxt.Text?=?"┅";
sktxt.ReadOnly?=?true;
}
foreach?(var?sm?in?list.Items)
{
toolform.dv.Rows.Add(sm.ToString());
}
toolform.Show();
toolform.cleari?+=?(Object?send,?EventArgs?er)?=
{
sktxt.Text?=?"";
sktxt.ReadOnly?=?false;
};
toolform.subm?+=?(Object?send,?EventArgs?er)?=
{
list.Items.Clear();
foreach?(DataGridViewRow?dvr?in?toolform.dv.Rows)
{
if?(Convert.ToString(dvr.Cells[0].Value)?!=?"")
{
list.Items.Add(Convert.ToString(dvr.Cells[0].Value));
}
}
sktxt.Text?=?"┅";
sktxt.ReadOnly?=?true;
};
};
}
}
}
public?string?condit(Panel?p)
{
string?master_condition?=?"";
foreach?(Control?ctl?in?p.Controls)
{
//遍歷panel查找條件
#region?
string?condition?=?"";
if?(ctl?is?SkinTextBox)
{
//文本框條件組合
#region
SkinTextBox?sktxt?=?(SkinTextBox)p.Controls[ctl.Name];
string?ziduan_name?=?sktxt.Name.Substring(0,?sktxt.Name.Length?-?1);
SkinCheckBox?skck?=?(SkinCheckBox)p.Controls[ctl.Name.Substring(0,?ctl.Name.Length?-?1)?+?"c"];
ListBox?list?=?(ListBox)p.Controls[ctl.Name.Substring(0,?ctl.Name.Length?-?1)?+?"l"];
if?(sktxt.Text?!=?"")
{
if?(sktxt.Text?==?"┅")
{
string?blur_str?=?"",?blur?=?"";
foreach?(var?itm?in?list.Items)
{
if?(itm.ToString().Contains("*"))
{
if?(skck.Checked?==?true)
{
blur?+=?"?and?"?+?ziduan_name?+?"?not?like?'"?+?itm.ToString().Replace("*",?"%")?+?"'";
}
else
{
blur?+=?"?or?"?+?ziduan_name?+?"?like?'"?+?itm.ToString().Replace("*",?"%")?+?"'";
}
}
else
{
blur_str?+=?"'"?+?Convert.ToString(itm)?+?"',";
}
}
string?blur_sql?=?(blur?==?"")???""?:?blur.Substring(4,?blur.Length?-?4).Trim();
string?in_condition?=?"",?like_condition?=?"";
if?(skck.Checked?==?true)
{
in_condition?=?ziduan_name?+?"?not?in?";
like_condition?=?"?and?";
}
else
{
in_condition?=?ziduan_name?+?"?in?";
like_condition?=?"?or?";
}
string?contains_sql?=?(blur_str?==?"")???""?:?in_condition?+?"("?+?blur_str.Substring(0,?blur_str.Length?-?1)?+?")";
condition?=?contains_sql?+?blur_sql;
if?(blur_sql?!=?""??contains_sql?!=?"")
{
condition?=?contains_sql?+?like_condition?+?blur_sql;
}
else
{
condition?=?contains_sql?+?blur_sql;
}
}
else
{
if?(!sktxt.Text.Contains("*"))
{
if?(skck.Checked?==?true)
{
condition?=?ziduan_name?+?"'"?+?sktxt.Text?+?"'";
}
else
{
condition?=?ziduan_name?+?"='"?+?sktxt.Text?+?"'";
}
}
else
{
if?(skck.Checked?==?true)
{
condition?=?ziduan_name?+?"?not?like?'"?+?sktxt.Text.Replace("*",?"%")?+?"'";
}
else
{
condition?=?ziduan_name?+?"?like?'"?+?sktxt.Text.Replace("*",?"%")?+?"'";
}
}
}
}
#endregion
}
if?(ctl?is?SkinDateTimePicker)
{
//日期條件組合
#region
if?(ctl.Name.Substring(ctl.Name.Length?-?1,?1)?!=?"t")
{
SkinDateTimePicker?skdate_sta?=?(SkinDateTimePicker)p.Controls[ctl.Name];
SkinDateTimePicker?skdate_end?=?(SkinDateTimePicker)p.Controls[ctl.Name?+?"t"];
if?(skdate_sta.text?!=?"")
{
if?(skdate_end.text?==?"")
{
condition?=?skdate_sta.Name?+?"='"?+?skdate_sta.text?+?"'";
}
else
{
condition?=?skdate_sta.Name?+?"='"?+?skdate_sta.text?+?"'?and?"?+?skdate_sta.Name?+?"='"?+?skdate_end.text?+?"'";
}
}
}
#endregion
}
master_condition?+=?(condition?==?"")???""?:?"("?+?condition?+?")?and?";
#endregion?//遍歷panel查找條件
}
string?condition_sql?=?(master_condition?==?"")???""?:?master_condition.Substring(0,?master_condition.Length?-?5);
return?condition_sql;
}
}
工具用一個(gè)窗體代替:
public?partial?class?condition?:?Form
{
public?condition()
{
InitializeComponent();
}
public?event?EventHandler?subm;
public?event?EventHandler?cleari;
private?void?submit_Click(object?sender,?EventArgs?e)
{
subm(sender,?e);
this.Dispose();
}
private?void?clearit_Click(object?sender,?EventArgs?e)
{
this.Dispose();
dv.Rows.Clear();
cleari(sender,?e);
}
}
當(dāng)我們執(zhí)行多條件的時(shí)候就等于拼接條件
處理“我想查 IF中同時(shí)滿足這兩個(gè)條件的總數(shù)”
我的理解是:
SELECT?COUNT(*)?FROM?tougao_record?WHERE?accept_company_id=100?AND?channel_type=1?AND?check_status=6
下面是if語句里面多個(gè)條件的使用。
IF語句的標(biāo)準(zhǔn)形式IF(expr1,expr2,expr3)
expr1可以是單個(gè)表達(dá)式也可以是多個(gè)表達(dá)式,且,或||,非!
上面的語句可以這樣寫
select COUNT(IF(channel_type=1 check_status=6),1,0) FROM tougao_record WHERE accept_company_id=100
但是就我的理解,mysql在統(tǒng)計(jì)count的時(shí)候,不管count括號里面的內(nèi)容,只管是否為空,查詢的結(jié)果不為空就計(jì)數(shù)。
我是處理下面的問題用到了,可以直接跑一下我給的sql語句。
SET?@destval:='0.63';
SET?@valforcomp='0.62';
SELECT?
IF(@destval?REGEXP?'^[\-\+.]?([0-9.]+)$'??@valforcomp?REGEXP?'^[\-\+.]?([0-9.]+)$',
IF(ABS(@destval-@valforcomp)0.02,1,0),NULL)?result
上面的REGEXP只是簡單的用來判斷是否是數(shù)字,通過這個(gè)我還發(fā)現(xiàn)了另一個(gè)問題,
SELECT?ABS(@destval-@valforcomp);
這個(gè)查詢出來不是等于0.01而是0.010000000000000009
不知道有沒有幫到你。
SELECT
t.file_id
FROM
app_polly_file_labels t
WHERE
t.style = '清新'
or t.style = '甜美'
or t.style = '韓潮來襲'
GROUP BY t.file_id
HAVING count(t.file_id)=3
或者
SELECT
a.file_id
FROM
app_polly_file_labels a
INNER JOIN app_polly_file_labels b ON a.file_id = b.file_id
INNER JOIN app_polly_file_labels c? ON a.file_id = c.file_id
WHERE
a.style ='清新'
AND b.style ='甜美'
AND c.style ='韓潮來襲'
擴(kuò)展資料:
sql常用的復(fù)雜查詢語句
一、選擇指定的列
select Sno as 學(xué)號,Sname as 姓名 from student
select Sno,Sname from student
二、查詢?nèi)苛?/p>
select * from student
三、對查詢后的指定列進(jìn)行命名
select Sname as 姓名,(2014-Sage) as 出生年 from student
select Sname ,(2014-Sage) from student
四、消除取值重復(fù)的行
select distinct Sno as 選修了課程的學(xué)生學(xué)號 from SC
select distinct Sno from SC
五、選擇表中若干元組,滿足條件的
select Sname as 學(xué)生姓名 from student where Sdept='IS'
參考鏈接:SQL語句大全
分享題目:mysql怎么多條件 mysql多條件篩選
分享地址:http://vcdvsql.cn/article40/doiecho.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供小程序開發(fā)、服務(wù)器托管、品牌網(wǎng)站建設(shè)、域名注冊、ChatGPT、做網(wǎng)站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)