asp中的InStr函数的改写

<script type="text/C#" runat="server">
    int? InStrCShape(string str1, string str2)
    {
        if (str1 == null || str2 == null)
            return null;
        return str1.IndexOf(str2)+1;
    }
    int? InStrCShape2(int? start, string str1, string str2, int? compare) {
        int? result = null;
        if (compare != null && start == null) {
            throw new Exception("If you assign compare type,you must set start index!");
        }
        if (start != null && start < 1) {
            throw new Exception("start index can not less than 1");
        }
        if (start == null){
            start = 1;
        }
        if (compare == null) {
            compare = 0;
        }
        if (str1 == null || str2==null ) {
            return null;
        }
        if (str1.Length == 0) {
            return 0;
        }
        if (str2.Length == 0) {
            return start;
        }
        if (start > 1) {
            str1 = str1.Substring(Convert.ToInt32(start));
        }
        int idx=str1.IndexOf(str2);
        if (compare == 1) {
            idx = str1.ToLower().IndexOf(str2.ToLower());
        }
        if (start > 1)
            result = idx == -1 ? 0 : start + idx + 1;
        else
            result = idx == -1 ? 0 : idx + 1;
        return result;
    }
</script>

<%
    string SearchString ="XXpXXpXXPXXP";
    string SearchChar = "P";

    int? l = 0;
    l = InStrCShape2(4, SearchString, SearchChar, 1);
    Response.Write(l);
    l = InStrCShape2(1, SearchString, SearchChar, 0);
    Response.Write(l);
    l = InStrCShape2(null, SearchString, SearchChar, null);
    Response.Write(l);
    l = InStrCShape2(null, SearchString, "W", null);
    Response.Write(l);
    l = InStrCShape(SearchString,"");
    Response.Write(l);
%>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MySQL的`INSTR`函数是一个内置函数,用于在一个字符串搜索指定的子字符串,并返回子字符串第一次出现的位置。如果子字符串不存在于原字符串,则返回0。该函数不区分大小写。 使用`INSTR`函数可以实现MySQL的模糊查询,类似于`LIKE`语句的用法。下面是`INSTR`函数的用法示例: 1. `INSTR(filed, str) > 0`:表示`filed`字段包含子字符串`str`,相当于`filed LIKE '%str%'`。 2. `INSTR(filed, str) = 1`:表示`filed`字段以子字符串`str`开头,相当于`filed LIKE 'str%'`。 3. `INSTR(filed, str) = 0`:表示`filed`字段不包含子字符串`str`,相当于`filed NOT LIKE '%str%'`。 例如,以下是使用`INSTR`函数和`LIKE`语句实现模糊查询的示例: 1. 使用`INSTR`函数:`SELECT id, name FROM test WHERE INSTR(name, #{name}) > 0`。 2. 使用`LIKE`语句:`SELECT id, name FROM test WHERE name LIKE CONCAT('%', #{name}, '%')`。 需要注意的是,`INSTR`函数返回的位置是从1开始计算的。如果子字符串不存在于原字符串,则返回0。 希望以上解答对您有帮助。 #### 引用[.reference_title] - *1* *2* [Mysql的instr()函数用法](https://blog.csdn.net/weixin_35790277/article/details/127061559)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [MySQL 的instr函数](https://blog.csdn.net/weixin_33854644/article/details/85864126)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值