- 深入理解汇编语言子程序设计与系统调用
网安spinage
汇编语言开发语言汇编算法
本文将全面解析汇编语言中子程序设计的核心技术以及系统调用的实现方法,涵盖参数传递的多种方式、堆栈管理、API调用等关键知识点,并提供实际案例演示。一、子程序设计:参数传递的艺术1.寄存器传参:高效简洁.386.modelflat,stdcalloptioncasemap:none.dataxdd5;定义变量ydd6sumdd?.code;函数定义:addxy1addxy1procpushebpmo
- md5加密
落地成佛
using(MD5md5=MD5.Create()){byte[]byteHash=md5.ComputeHash(System.Text.Encoding.Default.GetBytes(s));stringstrRes=BitConverter.ToString(byteHash).Replace("-","");returnstrRes.ToUpper();}
- Makefile if语句用法
java叶新东老师
c++makefile
文章目录语法1.BasicExpressions:2.LogicOperators:3.ExistenceChecks4.FileOperations5.Comparisons示例1、判断两个字符串是否相等2、判断文件路径是否目录完语法CMake中的if命令用于有条件地执行一组命令,其格式如下:if()elseif()#optionalblock,canberepeatedelse()#optio
- 如何在Power Query中对不同行,列名排序一致进行转置?
Data_Skill
之前的案例都是列数及行数相同,那如果是不同的情况下,该如何处理呢?原表:同行不同列原表目标表:同行不同列目标表此时我们可以通过另外一个分组函数来进行处理。Table.GroupTable.Group(tableastable,keyasany,aggregatedColumnsaslist,optionalgroupKindasnullablenumber,optionalcomparerasnu
- openssl-1.1.1w-win64
创想未来CTF
QtC++https
下载地址:ICSDownload-Overbyte解压后添加环境变量或放在目录“C:\Windows\System32”下其他版本下载GitGodeOpenSSL1.1.1g安装包
- Java 基本数据类型
froginwe11
开发语言
Java基本数据类型引言Java作为一种广泛使用的编程语言,其数据类型是构成程序的基础。Java的基本数据类型是编程语言的核心组成部分,它们定义了变量可以存储的数据类型。在本文中,我们将深入探讨Java的基本数据类型,包括它们的用途、特点以及在实际编程中的应用。Java基本数据类型概述Java语言提供了以下8种基本数据类型:byte:字节型,用于表示整数,范围从-128到127。short:短整型
- 前端基础知识Vue3系列 - 04(Vue3.0 所采用的 Composition Api 与 Vue2.x 使用的 Options Api 有什么不同)
开始之前CompositionAPI可以说是Vue3的最大特点,那么为什么要推出CompositionApi,解决了什么问题?通常使用Vue2开发的项目,普遍会存在以下问题:代码的可读性随着组件变大而变差每一种代码复用的方式,都存在缺点TypeScript支持有限以上通过使用CompositionApi都能迎刃而解正文一、OptionsApiOptionsAPI,即大家常说的选项API,即以vue
- android开发-bug记录
TUZILE
android开发androidjavaandroidstudiobug
2022.01.10正式接触android开发刚三四个月,记录一下三个第一次遇到的bug自定义的圆角控件加载图片导致OOMjava.lang.OutOfMemoryError:Failedtoallocatea373980byteallocationwith288904freebytesand282KBuntilOOM//atdalvik.system.VMRuntime.newNonMovabl
- webpack 配置 style-loader时出现错误:Module build failed (from ../node_modules/style-loader/dist/cjs.js)
.ToString()°
webpackjavascriptes6/es7webpack前端node.js
webpack配置style-loader时出现错误,Modulebuildfailed(from…/node_modules/style-loader/dist/cjs.js):TypeError:this.getOptionsisnotafunctionatObject.loader1.确保loader配置中的顺序,loader的执行顺序是从右到左,从下到上的,这里要注意style-loade
- Linux(Centos 7.6)命令详解:sz
豆是浪个
linuxcentos运维
1.命令作用使用ZMODEM/YMODEM/XMODEM协议发送文件(Sendfile(s)withZMODEM/YMODEM/XMODEMprotocol)注意:需要yuminstalllrzsz(yumprovidessz可以查看rz命令是什么rpm包提供的)2.命令语法Usage:sz[options]file...or:sz[options]-{c|i}COMMAND3.参数详解OPTIO
- ByteBuf
码农崛起
jdk自带ByteBuffer,看名字就知道作用差不多,区别是ByteBuffer读写都用一个指针,ByteBuf读写各有一个指针。都分为基于javaheap的headbuffer和基于DirectBuffer的buffer。DirectBuffer是不能被gc的,用完需要手动释放,虽然麻烦但是效率高,看吧,谁都有优点和缺点。加上一大堆看名字就知道干嘛的方法。ByteBuf是个抽象类,源代码里的文
- selenium 反爬虫识别特征处理
因为业务中发现网站对selenium特征识别为爬虫了,因此在搜索引擎中搜索进行处理方式一#实例化一个浏览器对象options=webdriver.ChromeOptions()options.add_experimental_option('excludeSwitches',['enable-automation'])ifsys.platform=="win32":browser=webdrive
- Windbg 命令列表
flyingleo1981
18)MemoryCmdVariants/ParamsDescriptiond*d[a|u|b|w|W|d|c|q|f|D][/c#][Addr]dy[b|d]..Displaymemory[#columnstodisplay]a=asciicharsu=Unicodecharsb=byte+asciiw=word(2b)W=word(2b)+asciid=dword(4b)c=dword(4b)
- LockscreenCredential 类方法详解
始于足下 方能行更远
8_SystemUiandroid
LockscreenCredential是Android系统中用于表示锁屏凭证(如PIN、密码、图案等)的类,它封装了用户设置的解锁凭据,并提供安全的方式来处理和验证这些凭据。这个类主要用于系统锁屏、设备加密以及用户认证等场景。LockscreenCredential类方法详解构造函数和创建方法私有构造函数privateLockscreenCredential(inttype,byte[]cred
- 【JVM篇06】:JVM的直接内存及其与nio提升io效率的联系详解
文章目录一、什么是JVM直接内存(DirectMemory)?二、效率提升的核心:剖析NIO数据拷贝路径的本质区别场景设定:从网络读取数据到Java程序中1.传统方式:使用堆内存(`HeapByteBuffer`)2.优化方式:使用直接内存(`DirectByteBuffer`)三、直接内存的“零拷贝”到底是什么?四、总结本文将深入探讨下一个JVM关键概念——直接内存,并详细剖析它究竟是如何通过“
- vue + uniapp + 高德地图实现微信小程序地图polyline、marker展示
1.使用uniapp提供的map组件作为承载页面data(){return{mapCtx:null}}mounted(){this.mapCtx=uni.createMapContext('store-order-map',this)},获取路径方法fetchRoutePolyline(options){const{start,end,waypoints}=optionsconstdefaultO
- 小程序onShow获取options的参数
是曹不是蔡
onShow()不接受参数,但是可以通过小程序页面栈获取optins参数1.获取当前小程序的页面栈—数组长度最大是10个页面。2.数组中索引最大的页面就是当前页面,其中可以获取到options属性。onShow(){//获取当前小程序的页面栈letpages=getCurrentPages();//数组中索引最大的页面--当前页面letcurrentPage=pages[pages.length-
- 【vue-8】Vue3 Options API 生命周期函数全面解析
AllenBright
#Vuevue.js前端javascript
在Vue.js开发中,理解组件的生命周期是构建健壮应用程序的关键。虽然Vue3引入了CompositionAPI,但OptionsAPI仍然是许多开发者的首选,特别是对于从Vue2迁移的项目或更喜欢基于选项的代码组织的团队。本文将深入探讨Vue3中OptionsAPI的生命周期函数,帮助您掌握组件从创建到销毁的完整过程。1.生命周期概览Vue3的生命周期与Vue2相比有一些变化,主要是为了更好的支
- 【Tora3踩坑日记】npx tailwindcss init报错:SyntaxError: Unexpected token ‘?‘
前端程序媛-Tian
Taro踩坑日记tailwindcss
详细报错信息如下:}=getOptions(name,options??{},false);^SyntaxError:Unexpectedtoken'?'atwrapSafe(internal/modules/cjs/loader.js:915:16)atModule._compile(internal/modules/cjs/loader.js:963:27)atObject.Module._e
- echarts实现两个饼图嵌套
js_user
echarts前端javascriptcsshtmlvue.js
效果展示需求:内层饼图为一级分类,外层饼图为二级分类。内外层一级分类和多属的二级分类颜色一样,且悬浮二级分类,一级分类同样有高亮效果。一级分类和二级分类悬浮有释义说明(解释这个分类的含义)由于二级分类只展示其中一部分,所以一级分类和二级分类所占角度不一样。关键代码展示**定义option**constcolors=["#fc8251","#5470c6","#91cd77","#ef6567","
- C语言基础(自学第一天)
#includeintmain(){ return0;}注:main函数是程序的入口一个工程中有且仅有一个mian函数数据类型char//字符数据类型大小:1byteshort//短整型大小:2byteint//整型大小:4bytelong//长整型大小:4/8bytelonglong//更长的整型大小:8bytefloat//单精度浮点数大小:4bytedouble//双精度浮点数大小
- AWS CAF:企业云转型的战略指南
在数字化转型的大潮中,企业正面临前所未有的变革压力。如何利用云计算驱动业务创新、提升IT敏捷性、优化成本结构,已成为众多企业迫切需要解决的关键课题。然而,云迁移并不是简单地将本地应用“复制”到云上,它是一项牵涉企业组织架构、流程治理、人员能力与技术堆栈的系统性工程。为了帮助企业有序、安全、可持续地推进云上转型,AmazonWebServices(AWS)推出了CloudAdoptionFramew
- mysql5.1 innodb page size_mysq5.7.28配置innodb_page_size错误引起ERROR 1071 (42000)
李首良
mysql5.1innodbpagesize
帮客户部署一套mysql并导入数据时出现ERROR1071(42000):Specifiedkeywastoolong;maxkeylengthis1536bytes错误;环境:数据库版本:mysql5.7.28操作系统:centos6.8CREATETABLE`QRTZ_BLOB_TRIGGERS`(->`SCHED_NAME`varchar(120)CHARACTERSETutf8COLLAT
- 学习014-03-01-03 Miscellaneous Customizations of the Audit Trail System (EF Core)(审计跟踪系统(EF Core)的其他自定
汤姆•猫
XAF学习.netc#DevSecurityAudit
MiscellaneousCustomizationsoftheAuditTrailSystem(EFCore)(审计跟踪系统(EFCore)的其他自定义设置)TrackChangesinObjectsofSpecificTypes(跟踪特定类型对象的变化)TheAuditTrailOptions.AuditedTypePolicypropertyallowsyoutoauditchangeson
- Java 内存操作流深度解析
tsxchen
I/O文件流java算法开发语言
内存操作流是JavaI/O中处理内存数据的核心工具,它允许直接在内存中读写数据,避免了磁盘I/O的开销。这类流特别适合处理临时数据、数据转换和内存缓存等场景。一、内存操作流体系概览内存操作流主要分为两类:字节内存流:处理原始字节数据字符内存流:处理文本数据二、字节内存操作流详解1.ByteArrayInputStream在内存中读取字节数组的输入流核心特性:数据源:字节数组(byte[])支持标记
- oracle数据库表空间碎片整理
GottdesKrieges
Oracle实践篇(二)数据库oracle
oracle数据库表空间碎片整理表空间碎片情况检查表空间碎片问题处理收缩表表空间手动整理exp/imp导出再导入移动表到新的表空间表空间碎片情况检查对比表实际使用空间和数据文件占用空间:--实际数据占用空间selecttablespace_name,round(sum(bytes/1024/1024/1024),2
- 微信小程序动态设置顶部的title
效果图:这里需要到js文件中操作,在获取到歌曲数据的时候,就需要通过wx.setNavigationBarTitle修改title标题,然后进入这个歌曲详情页面的时候就需要修改完成title/***生命周期函数--监听页面加载*/onLoad(options){//获取音乐idletmusicId=options.musicIdthis.setData({musicId})this.getMusi
- android 图片去色,android图片圆角、图片去色处理示例
packagecom.zhanggeng.contact.tools;importjava.io.ByteArrayOutputStream;importjava.io.File;importjava.io.FileNotFoundException;importjava.io.FileOutputStream;importjava.io.IOException;importandroid.gra
- c++ primer plus 知识点总结(更新中)
豫鹿deer
c++算法vscode
c++笔记第三章变量变量名只能使用数字、字母和下划线数字不能开头尽量不以下划线开头不要使用关键字比如double整型术语宽度表示存储整数时使用的内存量1byte=8bit1kb=1024byte1mb=1024kbsizeof()返回类型或变量的长度,单位为字节。注意对类型名使用时,要将类型名加上括号例如sizeof(int),对变量使用时可以不加括号sizeofn-int整型溢出规则:[外链图片
- C#(数据类型)
慢慢沉
C#c#
C#数据类型详解C#的数据类型分为值类型和引用类型两大类,系统还提供了指针类型(需在unsafe上下文使用)。以下是详细分类和说明:一、值类型(直接存储数据)简单类型整数类型:sbyte:8位有符号整数,范围:$-128$到$127$byte:8位无符号整数,范围:$0$到$255$short:16位有符号整数,范围:$-32,768$到$32,767$ushort:16位无符号整数,范围:$0$
- Spring的注解积累
yijiesuifeng
spring注解
用注解来向Spring容器注册Bean。
需要在applicationContext.xml中注册:
<context:component-scan base-package=”pagkage1[,pagkage2,…,pagkageN]”/>。
如:在base-package指明一个包
<context:component-sc
- 传感器
百合不是茶
android传感器
android传感器的作用主要就是来获取数据,根据得到的数据来触发某种事件
下面就以重力传感器为例;
1,在onCreate中获得传感器服务
private SensorManager sm;// 获得系统的服务
private Sensor sensor;// 创建传感器实例
@Override
protected void
- [光磁与探测]金吕玉衣的意义
comsci
这是一个古代人的秘密:现在告诉大家
信不信由你们:
穿上金律玉衣的人,如果处于灵魂出窍的状态,可以飞到宇宙中去看星星
这就是为什么古代
- 精简的反序打印某个数
沐刃青蛟
打印
以前看到一些让求反序打印某个数的程序。
比如:输入123,输出321。
记得以前是告诉你是几位数的,当时就抓耳挠腮,完全没有思路。
似乎最后是用到%和/方法解决的。
而今突然想到一个简短的方法,就可以实现任意位数的反序打印(但是如果是首位数或者尾位数为0时就没有打印出来了)
代码如下:
long num, num1=0;
- PHP:6种方法获取文件的扩展名
IT独行者
PHP扩展名
PHP:6种方法获取文件的扩展名
1、字符串查找和截取的方法
1
$extension
=
substr
(
strrchr
(
$file
,
'.'
), 1);
2、字符串查找和截取的方法二
1
$extension
=
substr
- 面试111
文强chu
面试
1事务隔离级别有那些 ,事务特性是什么(问到一次)
2 spring aop 如何管理事务的,如何实现的。动态代理如何实现,jdk怎么实现动态代理的,ioc是怎么实现的,spring是单例还是多例,有那些初始化bean的方式,各有什么区别(经常问)
3 struts默认提供了那些拦截器 (一次)
4 过滤器和拦截器的区别 (频率也挺高)
5 final,finally final
- XML的四种解析方式
小桔子
domjdomdom4jsax
在平时工作中,难免会遇到把 XML 作为数据存储格式。面对目前种类繁多的解决方案,哪个最适合我们呢?在这篇文章中,我对这四种主流方案做一个不完全评测,仅仅针对遍历 XML 这块来测试,因为遍历 XML 是工作中使用最多的(至少我认为)。 预 备 测试环境: AMD 毒龙1.4G OC 1.5G、256M DDR333、Windows2000 Server
- wordpress中常见的操作
aichenglong
中文注册wordpress移除菜单
1 wordpress中使用中文名注册解决办法
1)使用插件
2)修改wp源代码
进入到wp-include/formatting.php文件中找到
function sanitize_user( $username, $strict = false
- 小飞飞学管理-1
alafqq
管理
项目管理的下午题,其实就在提出问题(挑刺),分析问题,解决问题。
今天我随意看下10年上半年的第一题。主要就是项目经理的提拨和培养。
结合我自己经历写下心得
对于公司选拔和培养项目经理的制度有什么毛病呢?
1,公司考察,选拔项目经理,只关注技术能力,而很少或没有关注管理方面的经验,能力。
2,公司对项目经理缺乏必要的项目管理知识和技能方面的培训。
3,公司对项目经理的工作缺乏进行指
- IO输入输出部分探讨
百合不是茶
IO
//文件处理 在处理文件输入输出时要引入java.IO这个包;
/*
1,运用File类对文件目录和属性进行操作
2,理解流,理解输入输出流的概念
3,使用字节/符流对文件进行读/写操作
4,了解标准的I/O
5,了解对象序列化
*/
//1,运用File类对文件目录和属性进行操作
//在工程中线创建一个text.txt
- getElementById的用法
bijian1013
element
getElementById是通过Id来设置/返回HTML标签的属性及调用其事件与方法。用这个方法基本上可以控制页面所有标签,条件很简单,就是给每个标签分配一个ID号。
返回具有指定ID属性值的第一个对象的一个引用。
语法:
&n
- 励志经典语录
bijian1013
励志人生
经典语录1:
哈佛有一个著名的理论:人的差别在于业余时间,而一个人的命运决定于晚上8点到10点之间。每晚抽出2个小时的时间用来阅读、进修、思考或参加有意的演讲、讨论,你会发现,你的人生正在发生改变,坚持数年之后,成功会向你招手。不要每天抱着QQ/MSN/游戏/电影/肥皂剧……奋斗到12点都舍不得休息,看就看一些励志的影视或者文章,不要当作消遣;学会思考人生,学会感悟人生
- [MongoDB学习笔记三]MongoDB分片
bit1129
mongodb
MongoDB的副本集(Replica Set)一方面解决了数据的备份和数据的可靠性问题,另一方面也提升了数据的读写性能。MongoDB分片(Sharding)则解决了数据的扩容问题,MongoDB作为云计算时代的分布式数据库,大容量数据存储,高效并发的数据存取,自动容错等是MongoDB的关键指标。
本篇介绍MongoDB的切片(Sharding)
1.何时需要分片
&nbs
- 【Spark八十三】BlockManager在Spark中的使用场景
bit1129
manager
1. Broadcast变量的存储,在HttpBroadcast类中可以知道
2. RDD通过CacheManager存储RDD中的数据,CacheManager也是通过BlockManager进行存储的
3. ShuffleMapTask得到的结果数据,是通过FileShuffleBlockManager进行管理的,而FileShuffleBlockManager最终也是使用BlockMan
- yum方式部署zabbix
ronin47
yum方式部署zabbix
安装网络yum库#rpm -ivh http://repo.zabbix.com/zabbix/2.4/rhel/6/x86_64/zabbix-release-2.4-1.el6.noarch.rpm 通过yum装mysql和zabbix调用的插件还有agent代理#yum install zabbix-server-mysql zabbix-web-mysql mysql-
- Hibernate4和MySQL5.5自动创建表失败问题解决方法
byalias
J2EEHibernate4
今天初学Hibernate4,了解了使用Hibernate的过程。大体分为4个步骤:
①创建hibernate.cfg.xml文件
②创建持久化对象
③创建*.hbm.xml映射文件
④编写hibernate相应代码
在第四步中,进行了单元测试,测试预期结果是hibernate自动帮助在数据库中创建数据表,结果JUnit单元测试没有问题,在控制台打印了创建数据表的SQL语句,但在数据库中
- Netty源码学习-FrameDecoder
bylijinnan
javanetty
Netty 3.x的user guide里FrameDecoder的例子,有几个疑问:
1.文档说:FrameDecoder calls decode method with an internally maintained cumulative buffer whenever new data is received.
为什么每次有新数据到达时,都会调用decode方法?
2.Dec
- SQL行列转换方法
chicony
行列转换
create table tb(终端名称 varchar(10) , CEI分值 varchar(10) , 终端数量 int)
insert into tb values('三星' , '0-5' , 74)
insert into tb values('三星' , '10-15' , 83)
insert into tb values('苹果' , '0-5' , 93)
- 中文编码测试
ctrain
编码
循环打印转换编码
String[] codes = {
"iso-8859-1",
"utf-8",
"gbk",
"unicode"
};
for (int i = 0; i < codes.length; i++) {
for (int j
- hive 客户端查询报堆内存溢出解决方法
daizj
hive堆内存溢出
hive> select * from t_test where ds=20150323 limit 2;
OK
Exception in thread "main" java.lang.OutOfMemoryError: Java heap space
问题原因: hive堆内存默认为256M
这个问题的解决方法为:
修改/us
- 人有多大懒,才有多大闲 (评论『卓有成效的程序员』)
dcj3sjt126com
程序员
卓有成效的程序员给我的震撼很大,程序员作为特殊的群体,有的人可以这么懒, 懒到事情都交给机器去做 ,而有的人又可以那么勤奋,每天都孜孜不倦得做着重复单调的工作。
在看这本书之前,我属于勤奋的人,而看完这本书以后,我要努力变成懒惰的人。
不要在去庞大的开始菜单里面一项一项搜索自己的应用程序,也不要在自己的桌面上放置眼花缭乱的快捷图标
- Eclipse简单有用的配置
dcj3sjt126com
eclipse
1、显示行号 Window -- Prefences -- General -- Editors -- Text Editors -- show line numbers
2、代码提示字符 Window ->Perferences,并依次展开 Java -> Editor -> Content Assist,最下面一栏 auto-Activation
- 在tomcat上面安装solr4.8.0全过程
eksliang
Solrsolr4.0后的版本安装solr4.8.0安装
转载请出自出处:
http://eksliang.iteye.com/blog/2096478
首先solr是一个基于java的web的应用,所以安装solr之前必须先安装JDK和tomcat,我这里就先省略安装tomcat和jdk了
第一步:当然是下载去官网上下载最新的solr版本,下载地址
- Android APP通用型拒绝服务、漏洞分析报告
gg163
漏洞androidAPP分析
点评:记得曾经有段时间很多SRC平台被刷了大量APP本地拒绝服务漏洞,移动安全团队爱内测(ineice.com)发现了一个安卓客户端的通用型拒绝服务漏洞,来看看他们的详细分析吧。
0xr0ot和Xbalien交流所有可能导致应用拒绝服务的异常类型时,发现了一处通用的本地拒绝服务漏洞。该通用型本地拒绝服务可以造成大面积的app拒绝服务。
针对序列化对象而出现的拒绝服务主要
- HoverTree项目已经实现分层
hvt
编程.netWebC#ASP.ENT
HoverTree项目已经初步实现分层,源代码已经上传到 http://hovertree.codeplex.com请到SOURCE CODE查看。在本地用SQL Server 2008 数据库测试成功。数据库和表请参考:http://keleyi.com/a/bjae/ue6stb42.htmHoverTree是一个ASP.NET 开源项目,希望对你学习ASP.NET或者C#语言有帮助,如果你对
- Google Maps API v3: Remove Markers 移除标记
天梯梦
google maps api
Simply do the following:
I. Declare a global variable:
var markersArray = [];
II. Define a function:
function clearOverlays() {
for (var i = 0; i < markersArray.length; i++ )
- jQuery选择器总结
lq38366
jquery选择器
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40
- 基础数据结构和算法六:Quick sort
sunwinner
AlgorithmQuicksort
Quick sort is probably used more widely than any other. It is popular because it is not difficult to implement, works well for a variety of different kinds of input data, and is substantially faster t
- 如何让Flash不遮挡HTML div元素的技巧_HTML/Xhtml_网页制作
刘星宇
htmlWeb
今天在写一个flash广告代码的时候,因为flash自带的链接,容易被当成弹出广告,所以做了一个div层放到flash上面,这样链接都是a触发的不会被拦截,但发现flash一直处于div层上面,原来flash需要加个参数才可以。
让flash置于DIV层之下的方法,让flash不挡住飘浮层或下拉菜单,让Flash不档住浮动对象或层的关键参数:wmode=opaque。
方法如下:
- Mybatis实用Mapper SQL汇总示例
wdmcygah
sqlmysqlmybatis实用
Mybatis作为一个非常好用的持久层框架,相关资料真的是少得可怜,所幸的是官方文档还算详细。本博文主要列举一些个人感觉比较常用的场景及相应的Mapper SQL写法,希望能够对大家有所帮助。
不少持久层框架对动态SQL的支持不足,在SQL需要动态拼接时非常苦恼,而Mybatis很好地解决了这个问题,算是框架的一大亮点。对于常见的场景,例如:批量插入/更新/删除,模糊查询,多条件查询,联表查询,