select2 ajax 获取数据后 搜索功能 无效了 回答接近就有c币 20C

之前用本地下拉框数据 搜索框正常使用 ajax就不行了

图片说明

js代码

 /* 执行select2方法初始化 */
function select2Execute() {



    $(function() {
/*1-本地注入方式*/
    /*  $(".downList2").select2({
//      $("select[name='xuewei_id']").select2({
            // $('select[id="xuewei_id"]').select2({
            // $('#xuewei_id').select2({
            // $("#selectSection").find("select.combox").select2({
            // $(".select2-selection__choice").select2();
            // $(".combox").select2({

            placeholder : "请至少选择一个人名",
            tags : true,
            createTag : function(decorated, params) {
                return null;
            },
            width : '256px',


        });*/


        //2- AJAX获取数据方式

        $(".downList2").select2({
        ajax: {
            url: 'http://localhost:8080/erzhentang/manage/forAjax.do?requestType=12.5_1',
            dataType: 'json',
            delay: 250,
            data: function (params) {
              return {
                q: params.term,
              };
            },
            processResults: function (data) {
              return {
                results: data
              };
            },
            cache: true
          },
          escapeMarkup: function (markup) { return markup; }, // 自定义格式化防止xss注入
          minimumInputLength: 0,
          formatResult: function formatRepo(repo){return repo.text;}, // 函数用来渲染结果
          formatSelection: function formatRepoSelection(repo){return repo.text;} // 函数用于呈现当前的选择





        });

select标签 拼接在js里了

var str = "";
 str +="<select name=\"xuewei_id\" class=\"form-control input-sm downList2\" multiple>";
                        str +="<option></option>";
                       "</select>";

8个回答

你在浏览器里请求 http://localhost:8080/erzhentang/manage/forAjax.do?requestType=12.5_1 返回的是什么
之前让你抓包,你抓了么?把结果贴出来啊。

processResults: function (data) {
return {
results: data
};
这个里面data对应的json是不是列表

weixin_42175212
weixin_42175212 回复bulidfer:我现在是ajax请求回来数据拿到了, 但是没有显示在下拉框里, 请问你怎么显示在下拉框里的
9 个月之前 回复
u012503756
bulidfer 我说的是 就是无法实现 搜索的功能了
一年多之前 回复
u012503756
bulidfer 数据 已经没问题了
一年多之前 回复
u012503756
bulidfer 都不行
一年多之前 回复
u012503756
bulidfer [{"id":"68","text":"平和质"},{"id":"104","text":"特禀质"}]
一年多之前 回复
u012503756
bulidfer 下拉框 已经正常显示数据了
一年多之前 回复

图片说明

u012503756
bulidfer 不是这个
一年多之前 回复

谷歌浏览器,有开发者工具,可以使用开发者工具查看,火狐也有,主要是看看具体问题

u012503756
bulidfer 无法解决
一年多之前 回复

看下forAjax.do是不是只接收post请求,如果那样,加上method:"post"
如果服务器没有返回或者返回不对,你在服务器上直接返回你之前静态的json试试看

图片说明

而且 选中的项目 无法 回显

楼主好 不知道你问题解决没有 我不是很擅长这个前端 我有个解决方案 你可以参考一下 你说本地数据可以使用 你是否可以先用ajax请求数据 然后在ajax回调中在渲染select2
这种方式不就相当于用本地数据了 这样应该是可以的吧 你要不试试先

你说的回显是提交到后台回到这个页面时默认选中?如果是的话,你页面是否还有个选中的东西?

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
求一个select2 ajax请求后台数据搜索下拉框功能 并回显选中项的demo
软件后台是java编写的 求一个select2 ajax请求后台数据搜索下拉框功能 并回显选中项的demo https://www.cnblogs.com/-mrl/p/7650156.html 这个帖子我已经试过了 搜索功能失效 不要在推荐了 强调一下 是用ajax请求的数据 而不是用本地的方式注入
select2 ajax 获取java后台数据 提示params is not defined
下拉框没有任何选项内容 ![图片说明](https://img-ask.csdn.net/upload/201808/05/1533410857_939033.png) js代码 ``` /* 执行select2方法初始化 */ function select2Execute() { var dataList = [ { id: 0, text: 'enhancement' }, { id: 1, text: 'bug' }, { id: 2, text: 'duplicate' }, { id: 3, text: 'invalid' }, { id: 4, text: 'wontfix' } ]; var dataList1=[{'id':"1","text":"enhancement"}]; $(function() { /*本地注入方式*/ /*$("select[name='xuewei_id']").select2({ // $('select[id="xuewei_id"]').select2({ // $('#xuewei_id').select2({ // $("#selectSection").find("select.combox").select2({ // $(".select2-selection__choice").select2(); // $(".combox").select2({ placeholder : "请至少选择一个人名", tags : true, createTag : function(decorated, params) { return null; }, width : '256px', });*/ //two AJAX获取数据方式 //$("select[name='xuewei_id']").select2({ $(".downList2").select2({ ajax: { type:'GET', // url: '/erzhentang/manage/forAjax.do?requestType=12.1', url: dataList1, dataType: 'json', delay: 250, data: function (params) { return { q: params.term, // search term 请求参数 page: params.page }; }, processResults: function (data, params) { params.page = params.page || 1; /*var itemList = []; var arr = data.result.list for(item in arr){ itemList.push({id: item, text: arr[item]}) }*/ return { results: data.items,//itemList pagination: { more: (params.page * 2) < data.total_count } }; }, cache: true }, placeholder:'请选择',//默认文字提示 language: "zh-CN", tags: true,//允许手动添加 allowClear: true,//允许清空 escapeMarkup: function (markup) { return markup; }, // 自定义格式化防止xss注入 minimumInputLength: 0, formatResult: function formatRepo(repo){return repo.text;}, // 函数用来渲染结果 formatSelection: function formatRepoSelection(repo){return repo.text;} // 函数用于呈现当前的选择 }); function formatState(state) { if (!state.id) { return state.text; } var $state = $('<span>' + state.text + '</span>'); return $state; } ; $('#sel_recommender').select2({ placeholder : "请选择一个人名", templateResult : formatState, width : '256px' }); // 通过id获取select2的text值,这里的text值可能有空格,需注意 function getSelect2Text(obj) { var select2Obj = $("select[name='xuewei_id']").select2(); return select2Obj.find("option:selected").text(); } /* 获取每一个name对应的值 */ var strXueweiId = ""; $("[name=xuewei_id]").each(function() { alert("this值:" + $(this).val()); /* 拼接每一项name的值 组合成和其它项目类似 gender那样的数组 */ strXueweiId += $(this).val() + "-"; }); alert("strXueweiId:" + strXueweiId) $("#strXueweiId").val(strXueweiId) }); } ```
select2 ajax获取java后台下拉框数据 并回显选中的值
用ajax 请求后台值后 发现 下拉框没有搜索功能了 ![图片说明](https://img-ask.csdn.net/upload/201808/05/1533440496_530669.png) ``` * 执行select2方法初始化 */ function select2Execute() { var dataList = [ { id: 0, text: 'enhancement' }, { id: 1, text: 'bug' }, { id: 2, text: 'duplicate' }, { id: 3, text: 'invalid' }, { id: 4, text: 'wontfix' } ]; var dataList1=[{'id':"1","text":"enhancement"}]; $(function() { /*本地注入方式*/ $(".downList2").select2({ // $("select[name='xuewei_id']").select2({ // $('select[id="xuewei_id"]').select2({ // $('#xuewei_id').select2({ // $("#selectSection").find("select.combox").select2({ // $(".select2-selection__choice").select2(); // $(".combox").select2({ placeholder : "请至少选择一个人名", tags : true, createTag : function(decorated, params) { return null; }, width : '256px', ajax: { url: '/erzhentang/manage/forAjax.do?requestType=12.5_1', dataType: 'json', data: function (params) { var query = { //请求的参数, 关键字和搜索条件之类的 search: params.term //select搜索框里面的value } // Query paramters will be ?search=[term]&page=[page] return query; }, delay: 250, processResults: function (data, params) { //返回的选项必须处理成以下格式 var results = [{ id: 0, text: 'enhancement' }, { id: 1, text: 'bug' }, { id: 2, text: 'duplicate' }, { id: 3, text: 'invalid' }, { id: 4, text: 'wontfix' }]; return { results: results //必须赋值给results并且必须返回一个obj }; } }, allowClear: true,//允许清空 escapeMarkup: function (markup) { return markup; }, // 自定义格式化防止xss注入 minimumInputLength: 0, formatResult: function formatRepo(repo){return repo.text;}, // 函数用来渲染结果 formatSelection: function formatRepoSelection(repo){return repo.text;} // 函数用于呈现当前的选择 }); //two AJAX获取数据方式 //$("select[name='xuewei_id']").select2({ /*$(".downList2").select2({ ajax: { type:'GET', url: '/erzhentang/manage/forAjax.do?requestType=12.5_1', // url: dataList1, dataType: 'json', delay: 250, data: function (params) { return { q: params.term, // search term 请求参数 page: params.page }; }, processResults: function (data, params) { params.page = params.page || 1; var itemList = []; var arr = data.result.list for(item in arr){ itemList.push({id: item, text: arr[item]}) } var itemList = []; var results = [{ id: 0, text: 'enhancement' }, { id: 1, text: 'bug' }, { id: 2, text: 'duplicate' }, { id: 3, text: 'invalid' }, { id: 4, text: 'wontfix' }]; var arr = result.list for(item in arr){ itemList.push({id: item, text: arr[item]}) } var results = [{ id: 0, text: 'enhancement' }, { id: 1, text: 'bug' }, { id: 2, text: 'duplicate' }, { id: 3, text: 'invalid' }, { id: 4, text: 'wontfix' }]; // var results=[{"id":"68","text":"平和质"},{"id":"104","text":"特禀质"}] return { // results: data.items,//itemList results: results , //必须赋值给results并且必须返回一个obj // results: data,//itemList pagination: { more: (params.page * 2) < data.total_count } }; }, cache: true }, placeholder:'请选择',//默认文字提示 language: "zh-CN", tags: true,//允许手动添加 allowClear: true,//允许清空 escapeMarkup: function (markup) { return markup; }, // 自定义格式化防止xss注入 minimumInputLength: 0, formatResult: function formatRepo(repo){return repo.text;}, // 函数用来渲染结果 formatSelection: function formatRepoSelection(repo){return repo.text;} // 函数用于呈现当前的选择 });*/ function formatState(state) { if (!state.id) { return state.text; } var $state = $('<span>' + state.text + '</span>'); return $state; } ; $('#sel_recommender').select2({ placeholder : "请选择一个人名", templateResult : formatState, width : '256px' }); // 通过id获取select2的text值,这里的text值可能有空格,需注意 function getSelect2Text(obj) { var select2Obj = $("select[name='xuewei_id']").select2(); return select2Obj.find("option:selected").text(); } /* 获取每一个name对应的值 */ var strXueweiId = ""; $("[name=xuewei_id]").each(function() { alert("this值:" + $(this).val()); /* 拼接每一项name的值 组合成和其它项目类似 gender那样的数组 */ strXueweiId += $(this).val() + "-"; }); alert("strXueweiId:" + strXueweiId) $("#strXueweiId").val(strXueweiId) }); } ```
select2插件:使用input标签并采用ajax请求后台数据,搜索框无效
代码如下: <input id="countyCd" type="hidden"> $("#countyCd").select2({ placeholder: "请选择县名称", allowClear: true, //minimumInputLength: 2, ajax: { url: getContentPath() + "xxx", dataType: 'json', data: function (term, page) { return { 'searchCondition.cityCd': $('#cityCd').val() }; }, results: function (data, page) { return {results: data}; }, cache: true }, formatResult: resultFormatResult, // omitted for brevity, see the source of this page id: function (item) { return item.adCd; }, formatSelection: resultFormatSelection, // omitted for brevity, see the source of this page initSelection: function (element, callback) { var id = $(element).val(); if (id !== "") { $.ajax(getContentPath() + "xxx?countyCd=" + id, { dataType: "json" }).done(function (data) { callback(data); }); } } }); 无法在返回结果中使用查询框进行筛选查询![图片说明](https://img-ask.csdn.net/upload/201502/27/1425024026_967647.jpg)
jQuery ajax获取数据问题
程序片段如下: var data_1; $.post("getdata.php",function(string_1){ data_1 = string_1; }); _为什么string__1的内容无法被获取呢?_ 要想获取其内容,应该如何做呢?麻烦指点下! getdata.php: <?php_ $con = mysql_connect('localhost','root'); mysql_select_db('my_db',$con); $sql = 'SELECT * FROM data'; $result = mysql_query($sql); //将数据存入数组 $sql_data = array(); while($row = mysql_fetch_array($result)){ $sql_data[] = $row['data']; } echo json_encode($sql_data); ?>
用jquery ajax从数据库获取数据实现二级联动
我的思路就是一级那里搞个select,然后利用ajax返回action。然后利用ajax那里不懂。哪位大神教我怎么做? 1、这是select, function select(){ var xitong=document.getElementById("xitong").value; $.ajax({ url:'/netbank/budiao/testaj', type:'post', dataType:'json', data:{"xitong.xitongname":xitong}, error: function(){ alert("服务器没有返回数据,可能服务器忙,请重试"); }, success:createshebeiname2 }); 2、这是/netbank/budiao/testaj', public String testaj(){ System.out.println("testaj"); String name=xitong.getXitongname(); System.out.println(name); shebeilist=budiaoBiz.getShebeibyname(xitong.getXitongname()); request.put("shebeilist", shebeilist); return "testaj"; } 3、这是struts.xml的一部分 <package name="budiao" namespace="/budiao" extends="json-default" > <action name="*" class="budiao" method="{1}"> <result name="testaj" type="json"></result> 结果:select选择的时候,能够打印出testaj和xitongname的值,还有alert("服务器没有返回数据,可能服务器忙,请重试");
ajax返回数据给select标签添加问题
通过ajax从数据库把数据返回到页面,并添加到select标签中,然后通过选择器选出option值为指定的值被默认选中![图片说明](https://img-ask.csdn.net/upload/201901/04/1546596968_636191.png)
ajax获取不到php从数据库里面读取到的数据,(php读取到的数据已经成功转换成了json数据)
javascript代码: ```javascript // 初始化两个数组,盛装从数据库中获取到的数据 var dates = new Array(), moneys = new Array(); //调用ajax来实现异步的加载数据 function getusers() { $.ajax({ type: "post", async: false, data:{}, url: "dataDemo/dataIndex.php", data: {}, dataType: "json", success: function(result){ if(result){ for(var i = 0; i < result.length; i++){ dates.push(result[i].sum); moneys.push(result[i].money); } } }, error: function(errmsg) { alert("Ajax获取服务器数据出错了!"+ errmsg); } }); return dates, moneys; } //执行异步请求 getusers(); ``` public_function.php代码: ```php <?php function dbInit(){ global $con; $dsn = "mysql:dbname=info;localhost=127.0.0.1"; $user = "root"; $password = "644066YanMin&&!+"; try{ $con = new PDO($dsn,$user,$password); }catch(PDOExcepetion $e){ die ("Error!: " . $e->getMessage() . "<br/>"); } } /* 处理结果集中有多条数据的函数; */ function fetchAll($sql){ global $con; class user{ public $times; public $money; } if($result = $con->query($sql)){ //声明数组,用于接收结果集; $data = array(); //遍历结果集; while($row = $result->fetch(PDO::FETCH_ASSOC)){ $user = new User(); $user->times = $row['times']; $user->money = $row['sum']; $data[] = $user; } return $data; }else{ //执行失败; return false; } } ``` dataIndex.php代码 ```php <?php require "public_function.php"; dbInit(); $sql = 'select times,sum from date'; $datas = fetchAll($sql); // 返回JSON类型的数据 echo json_encode($datas); //$con = null; require "dataIndex.html"; ```
ajax如何获取servlet的数据
servlet已经取出了数据,显示在html上 servlet: public void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { Connection conn = DBConnectUtils.getConnection(); PreparedStatement pstmt = null; ResultSet rs = null; try { String sql = "select id,username from User"; pstmt = conn.prepareStatement(sql); rs = pstmt.executeQuery(); if (rs != null) { while (rs.next()) { req.setAttribute("id", rs.getInt("id")); req.setAttribute("username", rs.getString("username")); req.getRequestDispatcher("showUser.html").forward(req, resp); } } } catch (Exception e) { e.printStackTrace(); } finally { DBCloseUtils.closeCSR(conn, pstmt, rs); } } ajax应该怎么写
select2 怎么样做到具备筛选功能。
如下,ajax调用的时候,通过返回的是json数据,用select2展现,但是我现在输入一个字,想要得到 那种动态筛选的功能,可是一直没有办法实现,请问下这种应该怎么做?下方是我自己的代码 ``` <div class="form-group has-feedback select-par" style="margin-top: 15px;"> <label style="text-align: right;">志愿服务区域:</label> <select id="map_search" class="form-control" name="volunteerRegion" data-tag="" data-operator="" v-required="" value=""></select> </div> ``` 下方是select2的相关代码: ``` <script> function formatRepo(data){ return "<p><label>地址:</label>"+ data.adreess+"_"+data.name+"_"+data.code+"</p>"; } function formatName(data){ console.log(data) return data.name || data.text; } $("#map_search").select2({ placeholder: "请选择志愿服务区域", language: 'zh-CN', ajax: { url: "${ctx}/map/pgis", dataType: 'json', delay: 50, data: function (params) { return { q: params.term, // search term }; }, success: function(){ console.log('success'); }, fail: function(){ console.log('success'); }, processResults: function (data, params) { console.log(data); return { results:data.items }; }, cache: true }, escapeMarkup: function (markup) { return markup; }, // let our custom formatter work minimumInputLength: 0, //至少输入多少个字符后才会去调用ajax maximumInputLength: 20, //最多能输入多少个字符后才会去调用ajax minimumResultsForSearch: 1 , templateResult: formatRepo, templateSelection: formatName }); ``` 请问如何才能够做到动态筛选的功能?谢谢。
Mybatis select 没有获取更新数据 (缓存 ?)
写了一个简单的mybatis demo,没有集成其他事务管理,对接mysql数据库。 在表file_resources的mapper里面定义了一个这样的嵌套sql , 里面用到了 postinfo 、 poststatus两个表 ``` </select> <select id="selectPendingPostItemCount" resultType="java.lang.Integer" flushCache="true" useCache="false"> select count(*) from file_resources where objectName in (SELECT PostID FROM postinfo where PostLink not in (select PostLink from poststatus) group by postid having count(1) = 1) </select> ``` 我有另外一个线程去跑一些处理,是做完一条就commit一条的,poststatus的数据会不断增多,这样上面sql获取的count是不断减少的,我在mysql workbench控制台跑这条sql,count是不断会减少的。 但是当我开一个新线程在程序里跑count那条sql时,发觉无法获取到更新的数据,只有第一次跑时返回正确的count,之后这个count都没有改变(但在mysql workbench控制台跑,是不断减少的) 最开始的版本是这样的,sqlsession是用单例获取重用的open session,一开始就取好mapper,然后慢慢循环去跑sql,无法获取到更新count。 ``` SqlSession refreshSession = SessionFactorySingleton.getInstance().getOpenSession(); FileResourcesMapper fileMapper = refreshSession.getMapper(FileResourcesMapper.class); while(true){ int count = fileMapper.selectPendingPostItemCount(); Thread.sleep(50000); } ``` 直觉怀疑是缓存的问题,谷哥度娘之,然后作了几点修改,问题依旧。 1: 没有用单例获取sqlsession,而是重新按SqlSessionFactoryBuilder方法获取新的open session,并每次重新取mapper去跑select,问题依旧。 2:每次run完selection之后跑clearCache() 跟commit,问题依旧。 3:修改mapper ,在selectPendingPostItemCount定义 flushCache跟useCache去控制一二级缓存,问题依旧。 ``` </select> <select id="selectPendingPostItemCount" resultType="java.lang.Integer" flushCache="true" useCache="false"> select count(*) from file_resources where objectName in (SELECT PostID FROM postinfo where PostLink not in (select PostLink from poststatus) group by postid having count(1) = 1) </select> ``` ``` // SqlSession refreshSession = SessionFactorySingleton.getInstance().getOpenSession(); SqlSession refreshSession = getNewOpenSession(); //get new open session from new SqlSessionFactoryBuilder FileResourcesMapper fileMapper = refreshSession.getMapper(FileResourcesMapper.class); while(true){ int count = fileMapper.selectPendingPostItemCount(); refreshSession.clearCache(); refreshSession.commit(); fileMapper = refreshSession.getMapper(ColafileResourcesMapper.class); Thread.sleep(50000); } ``` 这之后,我就去看了看缓存跟sql执行的代码。 CachingExecutor 里面MappedStatement取出来的cache都是null的 , BaseExecutor里面的clearLocalCache()也有被call起来 最后BaseExecutor也involve了SimpleExecutor的doQuery(),里面就是jdbc的基本操作,PreparedStatementHandler的execute方法去执行sql。已经与缓存没有什么关系。 但是返回的值就是旧的。。。。。 打开的debug log可以证实sql已经提交连接数据库,同时我也在后台看到了sql语句的执行,但是从程序那边读取的返回值就是死活没有更新到。(在后台mysql界面直接跑同一条sql是有更新的) 我们现在的方法是每次跑mapper的selectPendingPostItemCount() 方法之后,就去直接把连接关闭掉(refreshSession.close())。下一次查询时重新取过sqlsession去跑select,是可以的。 有这方便经验的童鞋知道是什么问题麽 ?或者 可以给点意见或方向给我们去排查一下,感激不尽。 现在在看是不是namespace的问题,就是里面嵌套了其他file,是postinfo 、 poststatus两个表被缓存了 ? ``` <mapper namespace="com.mybatis.inter.FileResourcesMapper" > <resultMap id="BaseResultMap" type="com.mybatis.model.FileResources" > <id column="objectLink" property="objectlink" jdbcType="VARCHAR" /> 。。。。。。 ```
关于ajax读取后台数据写入select标签问题
目前最棘手的问题是:ajax读取后台省市数据后写入到前台select标签中形成相应的option <br /><span style="color: red">我可以获取任意option的文本值却不能获取option的value值!</span> <br />很是不解! <br />获取select中option-value值的代码肯定没问题! <br />下面是我的代码 <br /><pre name="code" class="java"> &lt;body onload="pro()"&gt; 省市: &lt;select name="province" &lt;option value="1"&gt; 北京市 &lt;/option&gt; &lt;/select&gt;&lt;br&gt; 城市/区县: &lt;select name="city"&gt; &lt;option value="1"&gt; 朝阳区 &lt;/option&gt; &lt;/select&gt; &lt;/body&gt; var req=null; function pro(){ req=new ActiveXObject("Microsoft.XMLHTTP"); req.onreadystatechange = call1; req.open("get","ajax","false"); req.send(null); } function call1(){ var province=document.all("province"); if(req.readystate==4){ var dis=req.responseText; for(var i=province.options.length;i&gt;=0;i--){ province.options.remove(i) } var arr=dis.split(","); for(var i=0;i&lt;arr.length;i++){ var newoption = document.createElement("OPTION"); province.options.add(newoption); newoption.innerText=arr[i]; newoption.Value=i+1; } } } </pre>
ajax获取json怎么写,ajax小白
将resultset转为json,html用ajax获取json数据并显示 完全没有思路 求解答 @Override public void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { Connection conn = DBConnectUtils.getConnection(); PreparedStatement pstmt = null; ResultSet rs = null; // json数组 JSONArray array = new JSONArray(); try { String sql = "select id,username from User"; System.out.println(sql); pstmt = conn.prepareStatement(sql); rs = pstmt.executeQuery(); // 获取列数 ResultSetMetaData metaData = rs.getMetaData(); int columnCount = metaData.getColumnCount(); // 遍历ResultSet中的每条数据 while (rs.next()) { JSONObject jsonObj = new JSONObject(); // 遍历每一列 for (int i = 1; i <= columnCount; i++) { String columnName = metaData.getColumnLabel(i); String value = rs.getString(columnName); jsonObj.put(columnName, value); System.out.println(jsonObj); System.out.println("----------------------------"); } array.add(jsonObj); } } catch (Exception e) { e.printStackTrace(); } finally { DBCloseUtils.closeCSR(conn, pstmt, rs); } }
select的选项是从数据库获取字段
select选择数据哭的字段a,td内为input。 select选择数据库字段b,td内为select,如何实现?主要是<s:if test="这部分不会写">
ajax 从页面中获取元素传递给PHP 进行数据库查询的问题
ajax从界面中获取id为username的文本内容“张三” ``` $.ajax({ type:"POST", url:"getallleads.php", data:"account="+$("#username").text(), success:function(data){showalllead(data);} }) ``` PHP中接收,并查询的语句如下: ``` $account=$_POST["account"]; echo "$account"; echo gettype($account); $result = $conn->query("select * from allsalesleads where 销售人员 like '%".$account."%'"); ``` 结果能够echo出account 内容为‘张三’ 数据类型为string 但没有查询结果 然后我直接在在如下PHP中给account赋值 张三,可以查询出。account前后的数据类型都是string ``` $account=$_POST["account"]; echo "$account"; echo gettype($account); $account='张三'; echo gettype($account); $result = $conn->query("select * from allsalesleads where 销售人员 like '%".$account."%'"); ``` 然后我想难道前后两个account不一样吗? 然后 if ($account=="张三") 来进行判断,结果还真不一样,这是咋回事啊? 有什么解决办法吗?非常感谢!
java,从后台获取了的数据放到了list中,如何在前台页面的select下拉框中显示出来
我将从后台获取到的数据,放到了list中,如何在前台页面的select中显示出来?求代码
我用dropdownlist动态绑定数据,用ajax实现数据获取,第一遍遍历之后,不再刷新
我数据放在returndata.aspx的datatable中,第一次执行是可以的,当选择dropdownlist中不同的option会返回不同的信息,但是当遍历完datatable中的所有rows之后,dropdownlist的onchange事件失效了,获取的内容不再更新。 1. Defalut.aspx <script type="text/javascript" language="javascript"> var xmlhttp = null; function GETXMLHttpRequest() { if (document.XMLHttpRequest) { xmlhttp = new XMLHttpRequest(); } else { xmlhttp = new ActiveXObject("Microsoft.XMLHTTP"); } } function getInfo(value) { GETXMLHttpRequest(); var url = "ReturnData.aspx?id=" + value; xmlhttp.open("GET", url, true); xmlhttp.send(); xmlhttp.onreadystatechange = function () { if (xmlhttp.readyState == 4 && xmlhttp.status == 200) { document.getElementById("content").innerHTML = xmlhttp.responseText; } } } </script> <asp:DropDownList ID="DropDownList1" runat="server" onchange="getInfo(this.value)"> </asp:DropDownList> //dropdownlist的onchange事件调用上面的js Default.aspx的后台代码 private void ShowData() { string sql = "select * from stu"; DataTable dt = SqlHelper.ExecuteQurly(sql); DropDownList1.DataSource = dt; DropDownList1.DataTextField = "sname"; DropDownList1.DataValueField = "sid"; DropDownList1.DataBind(); }//从数据库中绑定dropdownlist的内容 ReturnData.aspx(default.aspx获取数据的页面) 后台代码 private void getData() { if (Request.QueryString["id"] == null) return; string id = Request.QueryString["id"].ToString(); if (id == "") return; string sql = string.Format("select * from stu where sid={0}", id); DataTable dt = SQLHelper.SqlHelper.ExecuteQurly(sql); Response.Write("<table><tr><td>学号</td><td>姓名</td><td>性别</td></tr>"); if (dt.Rows.Count <= 0) return; for (int i = 0; i < dt.Rows.Count; i++) { string sql2 = string.Format("<tr><td>{0}</td><td>{1}</td><td>{2}</td></tr>", dt.Rows[i][0].ToString(), dt.Rows[i][1].ToString(), dt.Rows[i][2].ToString()); Response.Write(sql2); } Response.Write("</table>"); Response.End(); }
oracle数据库select效率
前提:数据库有将近100W条数据。 目的:需要排序后获取前10条。 处理:select * from (select * from table where col1=1 order by col1) where rownum <= 10; 问题:如上的sql语句,如果数据少的话,可以达到要求;但是如果数据量将近100W,效率就不行了。因为为括号里面的sql是提取全部数据,然后对所有数据就行排序,然后才取前10条。效率可想而知。 各位大虾有没有什么高招,可以提高下oracle的select的效率。
怎么用servlet获取oracle数据库信息后传递到jquery的ajax上进行验证
``` package com.ibm.ajax.app1.entity; public class WebUser { private String uname; public WebUser(String uname){ this.uname=uname; } public String getUname() { return uname; } public void setUname(String uname) { this.uname = uname; } } ``` ``` package com.ibm.ajax.app1.dao; import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.Statement; import java.util.List; import java.util.Vector; import com.ibm.ajax.app1.entity.WebUser; public class WebUserDao { public List<WebUser> queryList() throws Exception{ String username="gdx"; String password="wazzh"; String url="jdbc:oracle:thin:@//localhost:1521/orcl"; String driver="oracle.jdbc.driver.OracleDriver"; List<WebUser> lists=new Vector<WebUser>(); Class.forName(driver); Connection conn=DriverManager.getConnection(url, username, password); Statement stmt =conn.createStatement(); ResultSet rs=stmt.executeQuery("select UNAME from webUser"); while(rs.next()){ WebUser webuser=new WebUser(rs.getString("UNAME")); lists.add(webuser); } return lists; } } ``` ``` package com.ibm.ajax.app1.service.impl; import java.util.List; import com.ibm.ajax.app1.dao.WebUserDao; import com.ibm.ajax.app1.entity.WebUser; import com.ibm.ajax.app1.service.IWebUserService; public class WebUserServiceImpl implements IWebUserService { private WebUserDao webuserdao= new WebUserDao(); @Override public List<WebUser> getWebUserList() throws Exception { List<WebUser> lists= webuserdao.queryList(); return lists; } } ``` ``` package com.ibm.ajax.app1.service; import java.util.List; import com.ibm.ajax.app1.entity.WebUser; public interface IWebUserService { //获取我建立的实体对象WebUser的list表 public List<WebUser> getWebUserList() throws Exception; } ``` ``` package com.ibm.ajax.app1.servlet; import java.io.IOException; import java.util.List; import javax.servlet.ServletException; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import com.ibm.ajax.app1.entity.WebUser; import com.ibm.ajax.app1.service.IWebUserService; import com.ibm.ajax.app1.service.impl.WebUserServiceImpl; /** * Servlet implementation class ValiateUserNameServlet */ public class ValiateUserNameServlet extends HttpServlet { private static final long serialVersionUID = 1L; private IWebUserService webuserservice; @Override protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { webuserservice = new WebUserServiceImpl(); try{ List<WebUser> userNames=webuserservice.getWebUserList(); System.out.println(userNames); //这之上的是写的从数据库调取的语句 String userName=request.getParameter("userName"); String result=null; if(userNames.contains(userName) ){ result="<font color='red'>该用户已存在</font>"; } else{ result="<font color='green'>该用户不存在</font>"; } System.out.println("sdf"); response.setContentType("text/html ; charset=UTF-8"); response.setCharacterEncoding("UTF-8"); response.getWriter().print(result); } catch(Exception ex){ System.out.println(ex); } } } ``` ``` <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>Insert title here</title> <script type="text/javascript" src="${pageContext.request.contextPath }/scripts/jquery-1.7.2.js "></script> <script type="text/javascript"> $(function(){ $(":input[name='username']").change(function(){ var val=$(this).val(); val=$.trim(val); if(val!=" "){ var url="${pageContext.request.contextPath }/valiateUserName"; var args={"userName":val,"time":new Date()}; $.post(url,args,function(data){ $("#message").html(data); }); } }); }) </script> </head> <body> <form action="" method="post"> UserName:<input type="text" name="username" /> <div id="message"></div> <input type="submit" value="Submit" /> </form> </body> </html> ```
相见恨晚的超实用网站
搞学习 知乎:www.zhihu.com 简答题:http://www.jiandati.com/ 网易公开课:https://open.163.com/ted/ 网易云课堂:https://study.163.com/ 中国大学MOOC:www.icourse163.org 网易云课堂:study.163.com 哔哩哔哩弹幕网:www.bilibili.com 我要自学网:www.51zxw
爬虫福利二 之 妹子图网MM批量下载
爬虫福利一:27报网MM批量下载    点击 看了本文,相信大家对爬虫一定会产生强烈的兴趣,激励自己去学习爬虫,在这里提前祝:大家学有所成! 目标网站:妹子图网 环境:Python3.x 相关第三方模块:requests、beautifulsoup4 Re:各位在测试时只需要将代码里的变量 path 指定为你当前系统要保存的路径,使用 python xxx.py 或IDE运行即可。
字节跳动视频编解码面经
引言 本文主要是记录一下面试字节跳动的经历。 三四月份投了字节跳动的实习(图形图像岗位),然后hr打电话过来问了一下会不会opengl,c++,shador,当时只会一点c++,其他两个都不会,也就直接被拒了。 七月初内推了字节跳动的提前批,因为内推没有具体的岗位,hr又打电话问要不要考虑一下图形图像岗,我说实习投过这个岗位不合适,不会opengl和shador,然后hr就说秋招更看重基础。我当时
开源一个功能完整的SpringBoot项目框架
福利来了,给大家带来一个福利。 最近想了解一下有关Spring Boot的开源项目,看了很多开源的框架,大多是一些demo或者是一个未成形的项目,基本功能都不完整,尤其是用户权限和菜单方面几乎没有完整的。 想到我之前做的框架,里面通用模块有:用户模块,权限模块,菜单模块,功能模块也齐全了,每一个功能都是完整的。 打算把这个框架分享出来,供大家使用和学习。 为什么用框架? 框架可以学习整体
小白如何学习java?
在博主认为,对于入门级学习java的最佳学习方法莫过于视频+博客+书籍+总结,前三者博主将淋漓尽致地挥毫于这篇博客文章中,至于总结在于个人,实际上越到后面你会发现学习的最好方式就是阅读参考官方文档其次就是国内的书籍,博客次之,这又是一个层次了,这里暂时不提后面再谈。博主将为各位入门java保驾护航,各位只管冲鸭!!!上天是公平的,只要不辜负时间,时间自然不会辜负你。 何谓学习?博主所理解的学习,它
程序员必须掌握的核心算法有哪些?
由于我之前一直强调数据结构以及算法学习的重要性,所以就有一些读者经常问我,数据结构与算法应该要学习到哪个程度呢?,说实话,这个问题我不知道要怎么回答你,主要取决于你想学习到哪些程度,不过针对这个问题,我稍微总结一下我学过的算法知识点,以及我觉得值得学习的算法。这些算法与数据结构的学习大多数是零散的,并没有一本把他们全部覆盖的书籍。下面是我觉得值得学习的一些算法以及数据结构,当然,我也会整理一些看过
比特币原理详解
一、什么是比特币 比特币是一种电子货币,是一种基于密码学的货币,在2008年11月1日由中本聪发表比特币白皮书,文中提出了一种去中心化的电子记账系统,我们平时的电子现金是银行来记账,因为银行的背后是国家信用。去中心化电子记账系统是参与者共同记账。比特币可以防止主权危机、信用风险。其好处不多做赘述,这一层面介绍的文章很多,本文主要从更深层的技术原理角度进行介绍。 二、问题引入  假设现有4个人
【C++】C++11的std::array的详细剖析
当学习C++的时候,数组是最基本的结构之一,通常通过以下的方式来定义: int a[5]; int *b = new int[5]; 上面一句是在栈上定义了一个长度为5的数组,下面一句是在堆上定义了一个长度为5的数组,并用一个指针指向它。 在C++11中,引入了一种新的数组定义方式std::array。 std::array的特性 std::array是具有固定大小的数组。因此,它并不支持添加...
Python 基础(一):入门必备知识
目录1 标识符2 关键字3 引号4 编码5 输入输出6 缩进7 多行8 注释9 数据类型10 运算符10.1 常用运算符10.2 运算符优先级 1 标识符 标识符是编程时使用的名字,用于给变量、函数、语句块等命名,Python 中标识符由字母、数字、下划线组成,不能以数字开头,区分大小写。 以下划线开头的标识符有特殊含义,单下划线开头的标识符,如:_xxx ,表示不能直接访问的类属性,需通过类提供
程序员接私活怎样防止做完了不给钱?
首先跟大家说明一点,我们做 IT 类的外包开发,是非标品开发,所以很有可能在开发过程中会有这样那样的需求修改,而这种需求修改很容易造成扯皮,进而影响到费用支付,甚至出现做完了项目收不到钱的情况。 那么,怎么保证自己的薪酬安全呢? 我们在开工前,一定要做好一些证据方面的准备(也就是“讨薪”的理论依据),这其中最重要的就是需求文档和验收标准。一定要让需求方提供这两个文档资料作为开发的基础。之后开发
Python十大装B语法
Python 是一种代表简单思想的语言,其语法相对简单,很容易上手。不过,如果就此小视 Python 语法的精妙和深邃,那就大错特错了。本文精心筛选了最能展现 Python 语法之精妙的十个知识点,并附上详细的实例代码。如能在实战中融会贯通、灵活使用,必将使代码更为精炼、高效,同时也会极大提升代码B格,使之看上去更老练,读起来更优雅。 1. for - else 什么?不是 if 和 else 才
数据库优化 - SQL优化
前面一篇文章从实例的角度进行数据库优化,通过配置一些参数让数据库性能达到最优。但是一些“不好”的SQL也会导致数据库查询变慢,影响业务流程。本文从SQL角度进行数据库优化,提升SQL运行效率。 判断问题SQL 判断SQL是否有问题时可以通过两个表象进行判断: 系统级别表象 CPU消耗严重 IO等待严重 页面响应时间过长
2019年11月中国编程语言排行榜
2019年11月2日,我统计了某招聘网站,获得有效程序员招聘数据9万条。针对招聘信息,提取编程语言关键字,并统计如下: 编程语言比例 rank pl_ percentage 1 java 33.62% 2 c/c++ 16.42% 3 c_sharp 12.82% 4 javascript 12.31% 5 python 7.93% 6 go 7.25% 7
写了很久,这是一份最适合/贴切普通大众/科班/非科班的『学习路线』
说实话,对于学习路线这种文章我一般是不写的,大家看我的文章也知道,我是很少写建议别人怎么样怎么样的文章,更多的是,写自己的真实经历,然后供大家去参考,这样子,我内心也比较踏实,也不怕误导他人。 但是,最近好多人问我学习路线,而且很多大一大二的,说自己很迷茫,看到我那篇 普普通通,我的三年大学 之后很受激励,觉得自己也能行,(是的,别太浪,你一定能行)希望我能给他个学习路线,说
腾讯算法面试题:64匹马8个跑道需要多少轮才能选出最快的四匹?
昨天,有网友私信我,说去阿里面试,彻底的被打击到了。问了为什么网上大量使用ThreadLocal的源码都会加上private static?他被难住了,因为他从来都没有考虑过这个问题。无独有偶,今天笔者又发现有网友吐槽了一道腾讯的面试题,我们一起来看看。 腾讯算法面试题:64匹马8个跑道需要多少轮才能选出最快的四匹? 在互联网职场论坛,一名程序员发帖求助到。二面腾讯,其中一个算法题:64匹
面试官:你连RESTful都不知道我怎么敢要你?
面试官:了解RESTful吗? 我:听说过。 面试官:那什么是RESTful? 我:就是用起来很规范,挺好的 面试官:是RESTful挺好的,还是自我感觉挺好的 我:都挺好的。 面试官:… 把门关上。 我:… 要干嘛?先关上再说。 面试官:我说出去把门关上。 我:what ?,夺门而去 文章目录01 前言02 RESTful的来源03 RESTful6大原则1. C-S架构2. 无状态3.统一的接
为啥国人偏爱Mybatis,而老外喜欢Hibernate/JPA呢?
关于SQL和ORM的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行了一番讨论,感触还是有一些,于是就有了今天这篇文。 声明:本文不会下关于Mybatis和JPA两个持久层框架哪个更好这样的结论。只是摆事实,讲道理,所以,请各位看官勿喷。 一、事件起因 关于Mybatis和JPA孰优孰劣的问题,争论已经很多年了。一直也没有结论,毕竟每个人的喜好和习惯是大不相同的。我也看
SQL-小白最佳入门sql查询一
一 说明 如果是初学者,建议去网上寻找安装Mysql的文章安装,以及使用navicat连接数据库,以后的示例基本是使用mysql数据库管理系统; 二 准备前提 需要建立一张学生表,列分别是id,名称,年龄,学生信息;本示例中文章篇幅原因SQL注释略; 建表语句: CREATE TABLE `student` ( `id` int(11) NOT NULL AUTO_INCREMENT, `
项目中的if else太多了,该怎么重构?
介绍 最近跟着公司的大佬开发了一款IM系统,类似QQ和微信哈,就是聊天软件。我们有一部分业务逻辑是这样的 if (msgType = "文本") { // dosomething } else if(msgType = "图片") { // doshomething } else if(msgType = "视频") { // doshomething } else { // dosho
致 Python 初学者
文章目录1. 前言2. 明确学习目标,不急于求成,不好高骛远3. 在开始学习 Python 之前,你需要做一些准备2.1 Python 的各种发行版2.2 安装 Python2.3 选择一款趁手的开发工具3. 习惯使用IDLE,这是学习python最好的方式4. 严格遵从编码规范5. 代码的运行、调试5. 模块管理5.1 同时安装了py2/py35.2 使用Anaconda,或者通过IDE来安装模
“狗屁不通文章生成器”登顶GitHub热榜,分分钟写出万字形式主义大作
一、垃圾文字生成器介绍 最近在浏览GitHub的时候,发现了这样一个骨骼清奇的雷人项目,而且热度还特别高。 项目中文名:狗屁不通文章生成器 项目英文名:BullshitGenerator 根据作者的介绍,他是偶尔需要一些中文文字用于GUI开发时测试文本渲染,因此开发了这个废话生成器。但由于生成的废话实在是太过富于哲理,所以最近已经被小伙伴们给玩坏了。 他的文风可能是这样的: 你发现,
程序员:我终于知道post和get的区别
IT界知名的程序员曾说:对于那些月薪三万以下,自称IT工程师的码农们,其实我们从来没有把他们归为我们IT工程师的队伍。他们虽然总是以IT工程师自居,但只是他们一厢情愿罢了。 此话一出,不知激起了多少(码农)程序员的愤怒,却又无可奈何,于是码农问程序员。 码农:你知道get和post请求到底有什么区别? 程序员:你看这篇就知道了。 码农:你月薪三万了? 程序员:嗯。 码农:你是怎么做到的? 程序员:
羞,Java 字符串拼接竟然有这么多姿势
二哥,我今年大二,看你分享的《阿里巴巴 Java 开发手册》上有一段内容说:“循环体内,拼接字符串最好使用 StringBuilder 的 append 方法,而不是 + 号操作符。”到底为什么啊,我平常一直就用的‘+’号操作符啊!二哥有空的时候能否写一篇文章分析一下呢? 就在昨天,一位叫小菜的读者微信我说了上面这段话。 我当时看到这条微信的第一感觉是:小菜你也太菜了吧,这都不知道为啥啊!我估
"狗屁不通文章生成器"登顶GitHub热榜,分分钟写出万字形式主义大作
GitHub 被誉为全球最大的同性交友网站,……,陪伴我们已经走过 10+ 年时间,它托管了大量的软件代码,同时也承载了程序员无尽的欢乐。 万字申请,废话报告,魔幻形式主义大作怎么写?兄dei,狗屁不通文章生成器了解一下。这个富有灵魂的项目名吸引了众人的目光。项目仅仅诞生一周,便冲上了GitHub趋势榜榜首(Js中文网 -前端进阶资源教程)、是榜首哦
推荐几款比较实用的工具,网站
1.盘百度PanDownload   这个云盘工具是免费的,可以进行资源搜索,提速(偶尔会抽风......) 不要去某站买付费的......   PanDownload下载地址   2.BeJSON 这是一款拥有各种在线工具的网站,推荐它的主要原因是网站简洁,功能齐全,广告相比其他广告好太多了     bejson网站   3.二维码美化 这个网站的二维码美化很好看,网站界面
《程序人生》系列-这个程序员只用了20行代码就拿了冠军
你知道的越多,你不知道的越多 点赞再看,养成习惯GitHub上已经开源https://github.com/JavaFamily,有一线大厂面试点脑图,欢迎Star和完善 前言 这一期不算《吊打面试官》系列的,所有没前言我直接开始。 絮叨 本来应该是没有这期的,看过我上期的小伙伴应该是知道的嘛,双十一比较忙嘛,要值班又要去帮忙拍摄年会的视频素材,还得搞个程序员一天的Vlog,还要写BU
程序员把地府后台管理系统做出来了,还有3.0版本!12月7号最新消息:已在开发中有github地址
第一幕:缘起 听说阎王爷要做个生死簿后台管理系统,我们派去了一个程序员…… 996程序员做的梦: 第一场:团队招募 为了应对地府管理危机,阎王打算找“人”开发一套地府后台管理系统,于是就在地府总经办群中发了项目需求。 话说还是中国电信的信号好,地府都是满格,哈哈!!! 经常会有外行朋友问:看某网站做的不错,功能也简单,你帮忙做一下? 而这次,面对这样的需求,这个程序员
网易云6亿用户音乐推荐算法
网易云音乐是音乐爱好者的集聚地,云音乐推荐系统致力于通过 AI 算法的落地,实现用户千人千面的个性化推荐,为用户带来不一样的听歌体验。 本次分享重点介绍 AI 算法在音乐推荐中的应用实践,以及在算法落地过程中遇到的挑战和解决方案。 将从如下两个部分展开: AI 算法在音乐推荐中的应用 音乐场景下的 AI 思考 从 2013 年 4 月正式上线至今,网易云音乐平台持续提供着:乐屏社区、UGC
8年经验面试官详解 Java 面试秘诀
    作者 | 胡书敏 责编 | 刘静 出品 | CSDN(ID:CSDNnews) 本人目前在一家知名外企担任架构师,而且最近八年来,在多家外企和互联网公司担任Java技术面试官,前后累计面试了有两三百位候选人。在本文里,就将结合本人的面试经验,针对Java初学者、Java初级开发和Java开发,给出若干准备简历和准备面试的建议。   Java程序员准备和投递简历的实
面试官如何考察你的思维方式?
1.两种思维方式在求职面试中,经常会考察这种问题:北京有多少量特斯拉汽车? 某胡同口的煎饼摊一年能卖出多少个煎饼? 深圳有多少个产品经理? 一辆公交车里能装下多少个乒乓球? 一
相关热词 如何提升c#开发能力 矩阵乘法c# c#调用谷歌浏览器 c# 去空格去转义符 c#用户登录窗体代码 c# 流 c# linux 可视化 c# mvc 返回图片 c# 像素空间 c# 日期 最后一天
立即提问