三流君のソースコード置き場

三流プログラマーが作成したコードが置いてあります。ブログに過去のソースコードをアップして、ブログの検索機能で利用してます(利用予定です)※古くさいコードが多いです・・・

挨拶・自己紹介:
失敗続きのAB型の変わり者 :三流プログラマー Ken3です
フリーのエンジニア・個人事業主です・・と書くと聞こえはイイが(それとなくカッコよく聞こえるが)、 現在は小さな案件の受注請負 と 短期派遣 で 日々つつましく?ほそぼそと暮らしてます。
(※詳細は[三流君 三流プログラマーとは?]を見てください)


広告:


[記事一覧、バックナンバーを見る]

ASP 削除データの選択 と SQL DELETE文の発行

元の三流解説は、
三流君ASP:いろいろな削除処理で遊んでみた(笑)
↑を見て、笑ってやってください。
ブログに過去のソースコードをアップして、ブログの検索機能で利用してます(利用予定です)
※古くさいコードが多いです・・・



ソースコード

<%@LANGUAGE=VBScript%>
<% Response.CacheControl = "no-cache" %>
<% Response.AddHeader "Pragma", "no-cache" %>
<% Response.Expires = -1 %>
<html>
<head><META HTTP-EQUIV="Content-Type" CONTENT="text/html; charset=x-sjis">
<title>ASP削除データの選択 と SQL DELETE文の発行</title>
</head>
<body>
<h1>ASP削除データの選択 と SQL DELETE文の発行</h1>
<%
  'ADO DB Connection オブジェクトを作成する、英文そのままじゃん
  Set db=Server.CreateObject("ADODB.Connection")

  'データアクセスにはJet.OLEDB.4.0を使うことを設定
  db.Provider = "Microsoft.Jet.OLEDB.4.0"

  '次に、接続DBの位置を渡すので、Server.MapPathで変換して渡す
  db.ConnectionString = Server.MapPath("db029.mdb")

  'やっとデータベースを開ける
  db.open

  'IDが送られてきたかチェックする
  If IsEmpty(Request.Form("DELETE_ID")) = False Then 'IDが在りの時
    'IDを条件にSQL DELETE文を作る
    strSQL = "DELETE From KANSOU "  '感想(KANSOU)テーブルを削除するので
    strSQL = strSQL & " Where ID=" & Request.Form("DELETE_ID")

    Response.Write "<hr>データ削除IDは" & Request.Form("DELETE_ID")
    'オマケで画面にデータ表示
    Response.Write "<br>発行する(した)SQL文は<br><B><font color='green'>"
    Response.Write strSQL & "</font></B><br>です<hr>"

    'SQL文の発行
    db.Execute(strSQL)
  End If

  '
  'データ表示と削除ボタン生成
  '

  '一覧表示用のSQL文を作る
  strSQL = "Select * From KANSOU "  '感想(KANSOU)テーブルから全項目(*)セレクト
  strSQL = strSQL & "ORDER BY WriteTime DESC"           '並べ替えは時間の降順

  'オマケで画面にデータ表示
  Response.Write "<hr>発行する(した)SQL文は<br><B><font color='green'>"
  Response.Write strSQL & "</font></B><br>です<hr>"

  'お約束のレコードセットの作成 SQL文の発行
  Set rs = db.Execute(strSQL)

  'データの表示をテーブルで行う
  Response.Write "<TABLE Border='1'>"

  '見出しをバカっぽく、そのまま書き込む
  Response.Write "<TR>"
  Response.Write "<TD>アクション</TD>"
  Response.Write "<TD>日付</TD>"
  Response.Write "<TD>区分</TD>"
  Response.Write "<TD>NO.</TD>"
  Response.Write "<TD>感想</TD>"
  Response.Write "</TR>"

  'お約束のEOFまでループは(データが無くなるまでループ)、
  Do While rs.EOF = False   'レコードセットの.EOFがFalseの間
    Response.Write "<TR>"   '内容を表示する、行開始のタグ<TR>
    'フォームを作成する ※ACTIONで自分自身を呼ぶ
    Response.Write "<TD><FORM ACTION='test047-1.asp' METHOD='POST'>"
       'IDを隠し項目(DELETE_ID)にする
    Response.Write "<INPUT type='hidden' NAME='DELETE_ID' VALUE='"
    Response.Write rs.Fields.Item("ID") & "'>" 
       'ボタンは普通に作成する
    Response.Write "<INPUT TYPE='submit' VALUE='削除'>"
    Response.Write "</FORM></TD>"
    '中身を表示
    Response.Write "<TD>" & rs.Fields.Item("WriteTime") & "</TD>"
    Response.Write "<TD>" & rs.Fields.Item("F_KUBUN") & "</TD>"
    If rs.Fields.Item("F_NO") = 0 Then '0の全体かチェック
      Response.Write "<TD>全体</TD>"
    Else
      Response.Write "<TD>" & rs.Fields.Item("F_NO") & "</TD>" 'NO表示
    End If
    Response.Write "<TD>" & rs.Fields.Item("F_MEMO") & "</TD>"
    Response.Write "</TR>"
    '次のレコードにポインタを移動する
    rs.MoveNext    'これを忘れると悲惨なことに、、、
  Loop

  Response.Write "</TABLE>"  'テーブルは終わりです

  rs.Close         '開いていたレコードセットを閉じる
  db.Close         'データベースも閉じようよ
  Set db = Nothing 'お行儀よくオブジェクトも開放しましょう

%>

<HR>
終了です。<br>
<A href="test029-1.asp">データの登録(テストデータを増やす、消したら書いてね)</a><br>
</body>
</html>

↑をテスト実行する→ http://www.ken3.org/cgi-bin/test/test047-1.asp実行する



複数の削除データ選択 ソースコード

<%@LANGUAGE=VBScript%>
<% Response.CacheControl = "no-cache" %>
<% Response.AddHeader "Pragma", "no-cache" %>
<% Response.Expires = -1 %>
<html>
<head><META HTTP-EQUIV="Content-Type" CONTENT="text/html; charset=x-sjis">
<title>ASP 複数の削除データ選択 と SQL DELETE文の発行</title>
</head>
<body>
<h1>ASP 複数の削除データ選択 と SQL DELETE文の発行</h1>
<%
  'ADO DB Connection オブジェクトを作成する、英文そのままじゃん
  Set db=Server.CreateObject("ADODB.Connection")

  'データアクセスにはJet.OLEDB.4.0を使うことを設定
  db.Provider = "Microsoft.Jet.OLEDB.4.0"

  '次に、接続DBの位置を渡すので、Server.MapPathで変換して渡す
  db.ConnectionString = Server.MapPath("db029.mdb")

  'やっとデータベースを開ける
  db.open

  'IDが送られてきたかチェックする
  If IsEmpty(Request.Form("DELETE_ID")) = False Then 'IDが在りの時
    'IDを条件にSQL DELETE文を作る
    strSQL = "DELETE From KANSOU "  '感想(KANSOU)テーブルを削除するので
    '複数項目に対応するために、Where ID INを使用する
    strSQL = strSQL & " Where ID IN (" & Request.Form("DELETE_ID") & ")"

    Response.Write "<hr>データ削除IDは" & Request.Form("DELETE_ID")
    'オマケで画面にデータ表示
    Response.Write "<br>発行する(した)SQL文は<br><B><font color='green'>"
    Response.Write strSQL & "</font></B><br>です<hr>"

    'SQL文の発行
    db.Execute(strSQL)
  End If

  '
  'データ表示と削除ボタン生成
  '

  '一覧表示用のSQL文を作る
  strSQL = "Select * From KANSOU "  '感想(KANSOU)テーブルから全項目(*)セレクト
  strSQL = strSQL & "ORDER BY WriteTime DESC"           '並べ替えは時間の降順

  'オマケで画面にデータ表示
  Response.Write "<hr>発行する(した)SQL文は<br><B><font color='green'>"
  Response.Write strSQL & "</font></B><br>です<hr>"

  'お約束のレコードセットの作成 SQL文の発行
  Set rs = db.Execute(strSQL)

  'フォームを作成する ※ACTIONで自分自身を呼ぶ
  Response.Write "<TD><FORM ACTION='test047-2.asp' METHOD='POST'>"
  Response.Write "削除したいデータにチェックを入れ実行ボタンを押してください<br>"
  Response.Write "<INPUT TYPE='submit' VALUE='削除実行'>"

  'データの表示をテーブルで行う
  Response.Write "<TABLE Border='1'>"

  '見出しをバカっぽく、そのまま書き込む
  Response.Write "<TR>"
  Response.Write "<TD>アクション</TD>"
  Response.Write "<TD>日付</TD>"
  Response.Write "<TD>区分</TD>"
  Response.Write "<TD>NO.</TD>"
  Response.Write "<TD>感想</TD>"
  Response.Write "</TR>"

  'お約束のEOFまでループは(データが無くなるまでループ)、
  Do While rs.EOF = False   'レコードセットの.EOFがFalseの間
    Response.Write "<TR>"   '内容を表示する、行開始のタグ<TR>
       'CHECKBOX DELETE_ID 作成
    Response.Write "<TD><INPUT type='CHECKBOX' NAME='DELETE_ID' VALUE='"
    Response.Write rs.Fields.Item("ID") & "'></TD>" 
    'データの中身を表示
    Response.Write "<TD>" & rs.Fields.Item("WriteTime") & "</TD>"
    Response.Write "<TD>" & rs.Fields.Item("F_KUBUN") & "</TD>"
    If rs.Fields.Item("F_NO") = 0 Then '0の全体かチェック
      Response.Write "<TD>全体</TD>"
    Else
      Response.Write "<TD>" & rs.Fields.Item("F_NO") & "</TD>" 'NO表示
    End If
    Response.Write "<TD>" & rs.Fields.Item("F_MEMO") & "</TD>"
    Response.Write "</TR>"
    '次のレコードにポインタを移動する
    rs.MoveNext    'これを忘れると悲惨なことに、、、
  Loop

  Response.Write "</TABLE>"  'テーブルは終わりです
  Response.Write "<INPUT TYPE='submit' VALUE='削除実行'>"
  Response.Write "</FORM>"

  rs.Close         '開いていたレコードセットを閉じる
  db.Close         'データベースも閉じようよ
  Set db = Nothing 'お行儀よくオブジェクトも開放しましょう

%>

<HR>
終了です。<br>
<A href="test029-1.asp">データの登録(テストデータを増やす、消したら書いてね)</a><br>
</body>
</html>

↑をテスト実行する→ http://www.ken3.org/cgi-bin/test/test047-2.asp実行する


三流君ASPでフォーム関係の解説とサンプル
三流君ASPでADO MDB接続関係の解説とサンプル
三流君ASPでADO Excel接続関係の解説ページとサンプル
三流君ASPでADO CSV接続関係の解説ページとサンプル
三流君ASPでテキストファイル関係の解説とサンプルページ
三流君ASP VBScript関数の解説とサンプル



三流君ASPで遊ぶ、失敗する

SQL文 SELECT WHERE句でIN演算子を使用して複数条件を選択する

元の三流解説は、
三流君ASP:SQL文 SELECT WHERE句でIN演算子を使用して複数条件を選択する
↑を見て、笑ってやってください。
ブログに過去のソースコードをアップして、ブログの検索機能で利用してます(利用予定です)
※古くさいコードが多いです・・・



ソースコード

<%@LANGUAGE=VBScript%>
<html>
<head><META HTTP-EQUIV="Content-Type" CONTENT="text/html; charset=x-sjis">
<title>SQL SELECT文で WHERE句 条件をOrでつなげ複数にしてみた</title>
</head>
<body>
<h1>SQL SELECT文で WHERE句 条件をOrでつなげ複数にしてみた</h1>
test046-1.asp<br>
<hr>
<FORM ACTION="test046-1.asp" METHOD="GET">
<font color="blue">表示させたい区分をチェック(選択)して下さい</font><br>
<INPUT TYPE="CHECKBOX" NAME="ASP">ASP系へのご意見を表示<BR>
<INPUT TYPE="CHECKBOX" NAME="VBA">VBA系へのご意見を表示<BR>
<INPUT TYPE="CHECKBOX" NAME="GUCHI">愚痴系へのご意見を表示<BR>
<INPUT TYPE="CHECKBOX" NAME="24H">コンビニ系へのご意見を表示<BR>
<INPUT TYPE="submit" VALUE="送信">←チェック後送信ボタンを押してください
</FORM>
<hr>
<%  '頭で、入力パラメーターの文字数をチェックする
  strWHERE = "Where "
  If Request.QueryString("ASP") = "on" Then
     strWHERE = strWHERE & "F_KUBUN = 'ASP' "
  End If
  If Request.QueryString("VBA") = "on" Then
     If strWHERE <> "Where " Then strWHERE = strWHERE & " OR "  '2個目~
     strWHERE = strWHERE & "F_KUBUN = 'VBA' "
  End If
  If Request.QueryString("GUCHI") = "on" Then
     If strWHERE <> "Where " Then strWHERE = strWHERE & " OR "  '2個目~
     strWHERE = strWHERE & "F_KUBUN = 'GUCHI' "
  End If
  If Request.QueryString("24H") = "on" Then
     If strWHERE <> "Where " Then strWHERE = strWHERE & " OR "  '2個目~
     strWHERE = strWHERE & "F_KUBUN = '24H' "
  End If

  'Where文が生成されたかチェックする
  If strWHERE = "Where " Then  'そのままだったら条件文を消す
     Response.Write "<b>条件がありませんでした</b><hr>"
     strWHERE = ""             '条件無しに強引にする
  Else
     Response.Write "作成した条件[<b>" & strWHERE & "</b>]<hr>"
  End If
  '表示の関数を呼ぶ(外側に出したかったので)
  Call DATA_PRINT(strWHERE)
%>

<HR>
<FORM ACTION="test046-1.asp" METHOD="GET">
<font color="blue">表示させたい区分をチェック(選択)して下さい</font><br>
<INPUT TYPE="CHECKBOX" NAME="ASP">ASP系へのご意見を表示<BR>
<INPUT TYPE="CHECKBOX" NAME="VBA">VBA系へのご意見を表示<BR>
<INPUT TYPE="CHECKBOX" NAME="GUCHI">愚痴系へのご意見を表示<BR>
<INPUT TYPE="CHECKBOX" NAME="24H">コンビニ系へのご意見を表示<BR>
<INPUT TYPE="submit" VALUE="送信">←チェック後送信ボタンを押してください
</FORM>
<hr>
関連項目<br>
<A href="test029-1.asp">db029.mdbへデータ追加する</a><br>
</body>
</html>

<% 'パラメータを受け取り、SQLを発行
Sub DATA_PRINT(strWHERE)

  'ADO DB Connection オブジェクトを作成する、英文そのままじゃん
  Set db=Server.CreateObject("ADODB.Connection")

  '.Provider?プロバイダー?通信会社?じゃなくって
  'データアクセスにはJet.OLEDB.4.0を使うことを設定
  db.Provider = "Microsoft.Jet.OLEDB.4.0"

  '次に、接続DBの位置を渡すので、Server.MapPathで変換して渡す
  db.ConnectionString = Server.MapPath("db029.mdb")

  'やっとデータベースを開ける
  db.open

  'SQL文を作る
  strSQL = "Select * From KANSOU "  '感想(KANSOU)テーブルから全項目(*)セレクト
  strSQL = strSQL & strWHERE        '作成した条件を使用する
  strSQL = strSQL & "ORDER BY WriteTime DESC"    '並べ替えは時間の降順

  'オマケで画面にデータ表示
  Response.Write "<hr>発行する(した)SQL文は<br><B><font color='green'>"
  Response.Write strSQL & "</font></B><br>です<hr>"

  'お約束のレコードセットの作成 SQL文の発行
  Set rs = db.Execute(strSQL)

  'データの表示をテーブルで行う
  Response.Write "<TABLE Border='1'>"

  '見出しをバカっぽく、そのまま書き込む
  Response.Write "<TR>"
  Response.Write "<TD>日付</TD>"
  Response.Write "<TD>区分</TD>"
  Response.Write "<TD>NO.</TD>"
  Response.Write "<TD>感想</TD>"
  Response.Write "</TR>"

  'お約束のEOFまでループは(データが無くなるまでループ)、
  Do While rs.EOF = False   'レコードセットの.EOFがFalseの間
    Response.Write "<TR>"   '内容を表示する、行開始のタグ<TR>
    Response.Write "<TD>" & rs.Fields.Item("WriteTime") & "</TD>"
    Response.Write "<TD>" & rs.Fields.Item("F_KUBUN") & "</TD>"
    If rs.Fields.Item("F_NO") = 0 Then '0の全体かチェック
      Response.Write "<TD>全体</TD>"
    Else
      Response.Write "<TD>" & rs.Fields.Item("F_NO") & "</TD>" 'NO表示
    End If
    Response.Write "<TD>" & rs.Fields.Item("F_MEMO") & "</TD>"
    Response.Write "</TR>"
    '次のレコードにポインタを移動する
    rs.MoveNext    'これを忘れると悲惨なことに、、、
  Loop

  Response.Write "</TABLE>"  'テーブルは終わりです

  '開いていたレコードセットを閉じる
  rs.Close

  'データベースも閉じようよ
  db.Close

  'お行儀よくオブジェクトも開放しましょう(通常は自動的に解放されるけど)
  Set db = Nothing

End Sub
%>

↑をテスト実行する→ http://www.ken3.org/cgi-bin/test/test046-1.asp?ASP=on&GUCHI=on実行する



SQL WHERE句 複数条件作成で SplitとUBoundを使用 ソースコード

<%@LANGUAGE=VBScript%>
<html>
<head><META HTTP-EQUIV="Content-Type" CONTENT="text/html; charset=x-sjis">
<title>SQL WHERE句 複数条件作成で SplitとUBoundを使用</title>
</head>
<body>
<h1>SQL WHERE句 複数条件作成で SplitとUBoundを使用</h1>
test046-2.asp<br>
<hr>
Request.QueryString("KUBUN")=<%=Request.QueryString("KUBUN")%><br>
<%  '頭で、入力パラメーターをチェックする
  strWHERE = "Where "  '初期値の代入
  strBOX = Split(Request.QueryString("KUBUN"), ",")  'カンマで区切る
  Response.Write "UBound(strBOX)=" & UBound(strBOX) & "<br>"
  'ループでデータを作成する
  For i = 0 To UBound(strBOX)   'UBound使用インデックス最大値までループ
     Response.Write "strBOX(" & i & ")=" & strBOX(i) & "<br>"
     If strWHERE <> "Where " Then strWHERE = strWHERE & " OR "  '2個目~
     strWHERE = strWHERE & "F_KUBUN = '" & Trim(strBOX(i)) & "' "
  Next

  'Where文が生成されたかチェックする
  If strWHERE = "Where " Then  'そのままだったら条件文を消す
     Response.Write "<b>条件がありませんでした</b><hr>"
     strWHERE = ""             '条件無しに強引にする
  Else
     Response.Write "作成した条件[<b>" & strWHERE & "</b>]<hr>"
  End If
  '表示の関数を呼ぶ(外側に出したかったので)
  Call DATA_PRINT(strWHERE)
%>

<HR>
<FORM ACTION="test046-2.asp" METHOD="GET">
<font color="blue">表示させたい区分をチェック(選択)して下さい</font><br>
<INPUT TYPE="CHECKBOX" NAME="KUBUN" VALUE="ASP">ASP系へのご意見を表示<BR>
<INPUT TYPE="CHECKBOX" NAME="KUBUN" VALUE="VBA">VBA系へのご意見を表示<BR>
<INPUT TYPE="CHECKBOX" NAME="KUBUN" VALUE="GUCHI">愚痴系へのご意見を表示<BR>
<INPUT TYPE="CHECKBOX" NAME="KUBUN" VALUE="24H">コンビニ系へのご意見を表示<BR>
<INPUT TYPE="submit" VALUE="送信">←チェック後送信ボタンを押してください
</FORM>
<hr>
関連項目<br>
<A href="test029-1.asp">db029.mdbへデータ追加する</a><br>
</body>
</html>

<% 'パラメータを受け取り、SQLを発行
Sub DATA_PRINT(strWHERE)

  'ADO DB Connection オブジェクトを作成する、英文そのままじゃん
  Set db=Server.CreateObject("ADODB.Connection")

  '.Provider?プロバイダー?通信会社?じゃなくって
  'データアクセスにはJet.OLEDB.4.0を使うことを設定
  db.Provider = "Microsoft.Jet.OLEDB.4.0"

  '次に、接続DBの位置を渡すので、Server.MapPathで変換して渡す
  db.ConnectionString = Server.MapPath("db029.mdb")

  'やっとデータベースを開ける
  db.open

  'SQL文を作る
  strSQL = "Select * From KANSOU "  '感想(KANSOU)テーブルから全項目(*)セレクト
  strSQL = strSQL & strWHERE        '作成した条件を使用する
  strSQL = strSQL & "ORDER BY WriteTime DESC"    '並べ替えは時間の降順

  'オマケで画面にデータ表示
  Response.Write "<hr>発行する(した)SQL文は<br><B><font color='green'>"
  Response.Write strSQL & "</font></B><br>です<hr>"

  'お約束のレコードセットの作成 SQL文の発行
  Set rs = db.Execute(strSQL)

  'データの表示をテーブルで行う
  Response.Write "<TABLE Border='1'>"

  '見出しをバカっぽく、そのまま書き込む
  Response.Write "<TR>"
  Response.Write "<TD>日付</TD>"
  Response.Write "<TD>区分</TD>"
  Response.Write "<TD>NO.</TD>"
  Response.Write "<TD>感想</TD>"
  Response.Write "</TR>"

  'お約束のEOFまでループは(データが無くなるまでループ)、
  Do While rs.EOF = False   'レコードセットの.EOFがFalseの間
    Response.Write "<TR>"   '内容を表示する、行開始のタグ<TR>
    Response.Write "<TD>" & rs.Fields.Item("WriteTime") & "</TD>"
    Response.Write "<TD>" & rs.Fields.Item("F_KUBUN") & "</TD>"
    If rs.Fields.Item("F_NO") = 0 Then '0の全体かチェック
      Response.Write "<TD>全体</TD>"
    Else
      Response.Write "<TD>" & rs.Fields.Item("F_NO") & "</TD>" 'NO表示
    End If
    Response.Write "<TD>" & rs.Fields.Item("F_MEMO") & "</TD>"
    Response.Write "</TR>"
    '次のレコードにポインタを移動する
    rs.MoveNext    'これを忘れると悲惨なことに、、、
  Loop

  Response.Write "</TABLE>"  'テーブルは終わりです

  '開いていたレコードセットを閉じる
  rs.Close

  'データベースも閉じようよ
  db.Close

  'お行儀よくオブジェクトも開放しましょう(通常は自動的に解放されるけど)
  Set db = Nothing

End Sub
%>

↑をテスト実行する→ http://www.ken3.org/cgi-bin/test/test046-2.asp?KUBUN=VBA&KUBUN=GUCHI実行する



SQL文 SELECT WHERE IN演算子を使用する ソースコード

<%@LANGUAGE=VBScript%>
<html>
<head><META HTTP-EQUIV="Content-Type" CONTENT="text/html; charset=x-sjis">
<title>SQL文 SELECT WHERE IN演算子を使用する</title>
</head>
<body>
<h1>SQL文 SELECT WHERE IN演算子を使用する</h1>
test046-3.asp<br>
<hr>
Request.QueryString("KUBUN")で<%=Request.QueryString("KUBUN")%><br>
と、パラメータをもらったら<br>
WHERE IN演算子を使用して、SQL文を作成してます<br>
※文字列フィールドなので、Replace関数で細工してますが、<br>
  複数項目を選択する場合は便利です<br>
<hr>
<%  '頭で、入力パラメーターをチェックする
  If IsEmpty(Request.QueryString("KUBUN")) = True Then  '条件無し
     Response.Write "<b>条件がありませんでした</b><hr>"
     strWHERE = ""             '条件無しに強引にする
  Else
     'WHERE INを作成する
     strKUBUN = Replace(Request.QueryString("KUBUN"), ", ", "', '") 
     strWHERE = "WHERE F_KUBUN IN ('" & strKUBUN & "') "
     Response.Write "作成した条件[<b>" & strWHERE & "</b>]<hr>"
  End If
  '表示の関数を呼ぶ(外側に出したかったので)
  Call DATA_PRINT(strWHERE)
%>

<HR>
<FORM ACTION="test046-3.asp" METHOD="GET">
<font color="blue">表示させたい区分をチェック(選択)して下さい</font><br>
<INPUT TYPE="CHECKBOX" NAME="KUBUN" VALUE="ASP">ASP系へのご意見を表示<BR>
<INPUT TYPE="CHECKBOX" NAME="KUBUN" VALUE="VBA">VBA系へのご意見を表示<BR>
<INPUT TYPE="CHECKBOX" NAME="KUBUN" VALUE="GUCHI">愚痴系へのご意見を表示<BR>
<INPUT TYPE="CHECKBOX" NAME="KUBUN" VALUE="24H">コンビニ系へのご意見を表示<BR>
<INPUT TYPE="submit" VALUE="送信">←チェック後送信ボタンを押してください
</FORM>
<hr>
関連項目<br>
<A href="test029-1.asp">db029.mdbへデータ追加する</a><br>
</body>
</html>

<% 'パラメータを受け取り、SQLを発行
Sub DATA_PRINT(strWHERE)

  'ADO DB Connection オブジェクトを作成する、英文そのままじゃん
  Set db=Server.CreateObject("ADODB.Connection")

  '.Provider?プロバイダー?通信会社?じゃなくって
  'データアクセスにはJet.OLEDB.4.0を使うことを設定
  db.Provider = "Microsoft.Jet.OLEDB.4.0"

  '次に、接続DBの位置を渡すので、Server.MapPathで変換して渡す
  db.ConnectionString = Server.MapPath("db029.mdb")

  'やっとデータベースを開ける
  db.open

  'SQL文を作る
  strSQL = "Select * From KANSOU "  '感想(KANSOU)テーブルから全項目(*)セレクト
  strSQL = strSQL & strWHERE        '作成した条件を使用する
  strSQL = strSQL & "ORDER BY WriteTime DESC"    '並べ替えは時間の降順

  'オマケで画面にデータ表示
  Response.Write "<hr>発行する(した)SQL文は<br><B><font color='green'>"
  Response.Write strSQL & "</font></B><br>です<hr>"

  'お約束のレコードセットの作成 SQL文の発行
  Set rs = db.Execute(strSQL)

  'データの表示をテーブルで行う
  Response.Write "<TABLE Border='1'>"

  '見出しをバカっぽく、そのまま書き込む
  Response.Write "<TR>"
  Response.Write "<TD>日付</TD>"
  Response.Write "<TD>区分</TD>"
  Response.Write "<TD>NO.</TD>"
  Response.Write "<TD>感想</TD>"
  Response.Write "</TR>"

  'お約束のEOFまでループは(データが無くなるまでループ)、
  Do While rs.EOF = False   'レコードセットの.EOFがFalseの間
    Response.Write "<TR>"   '内容を表示する、行開始のタグ<TR>
    Response.Write "<TD>" & rs.Fields.Item("WriteTime") & "</TD>"
    Response.Write "<TD>" & rs.Fields.Item("F_KUBUN") & "</TD>"
    If rs.Fields.Item("F_NO") = 0 Then '0の全体かチェック
      Response.Write "<TD>全体</TD>"
    Else
      Response.Write "<TD>" & rs.Fields.Item("F_NO") & "</TD>" 'NO表示
    End If
    Response.Write "<TD>" & rs.Fields.Item("F_MEMO") & "</TD>"
    Response.Write "</TR>"
    '次のレコードにポインタを移動する
    rs.MoveNext    'これを忘れると悲惨なことに、、、
  Loop

  Response.Write "</TABLE>"  'テーブルは終わりです

  '開いていたレコードセットを閉じる
  rs.Close

  'データベースも閉じようよ
  db.Close

  'お行儀よくオブジェクトも開放しましょう(通常は自動的に解放されるけど)
  Set db = Nothing

End Sub
%>

↑をテスト実行する→ http://www.ken3.org/cgi-bin/test/test046-3.asp?KUBUN=ASP&KUBUN=24H実行する


三流君ASPでフォーム関係の解説とサンプル
三流君ASPでADO MDB接続関係の解説とサンプル
三流君ASPでADO Excel接続関係の解説ページとサンプル
三流君ASPでADO CSV接続関係の解説ページとサンプル
三流君ASPでテキストファイル関係の解説とサンプルページ
三流君ASP VBScript関数の解説とサンプル



三流君ASPで遊ぶ、失敗する

HTML FORM INPUT TYPE="CHECKBOX" チェックボックスの入力テスト

元の三流解説は、
三流君ASP:HTML FORM INPUT TYPE="CHECKBOX" チェックボックスの入力
↑を見て、笑ってやってください。
ブログに過去のソースコードをアップして、ブログの検索機能で利用してます(利用予定です)
※古くさいコードが多いです・・・



ソースコード

<%@LANGUAGE=VBScript%>
<html>
<head><META HTTP-EQUIV="Content-Type" CONTENT="text/html; charset=x-sjis">
<title>HTML FORM INPUT TYPE="CHECKBOX" チェックボックスの入力テスト</title>
</head>
<body>
<h2>HTML FORM INPUT TYPE="CHECKBOX" チェックボックスの入力テスト</h2>
<hr>
<b>フォームから送られて来た値を表示します</b><br>
<font color="blue">For Each で 値を表示する</font><br>
<%
  'データの表示をテーブルで行う
  Response.Write "<TABLE Border='1'>"
  Response.Write "<TR><TD>項目名</TD><TD>値</TD></TR>"  'タイトル行

  'For Each で Request.Formの値を取出す
  For Each RF In Request.Form
    Response.Write "<TR><TD>" & RF & "</TD>"  '名称表示
    Response.Write "<TD>" & Request.Form(RF) & "</TD></TR>" '値の表示
  Next

  Response.Write "</TABLE>"

%>
<hr>
<h3>INPUT TYPE="CHECKBOX" VALUEの値をイジル</h3>
<PRE><!-- ↓入力に使ったHTML -->
↓入力に使うHTML
&lt;INPUT TYPE=&quot;CHECKBOX&quot; NAME=&quot;c1&quot;&gt;HTMLから詳しく丁寧に&lt;BR&gt;
&lt;INPUT TYPE=&quot;CHECKBOX&quot; NAME=&quot;c2&quot; VALUE=&quot;VBScript&quot;&gt;VBScriptをもっと詳しく&lt;BR&gt;
&lt;INPUT TYPE=&quot;CHECKBOX&quot; NAME=&quot;c3&quot; VALUE=&quot;GAME&quot;&gt;ゲーム作ろうよ&lt;BR&gt;
VALUE無しのパターン と VALUEの値を指定(VBScript,GAME)してみた
</PRE>
<FORM ACTION="test045-1.asp" METHOD="POST">
<font color="blue">TYPE="CHECKBOX" チェックボックスの入力テスト</font><br>
このメルマガでやってほしいことにチェックを入れてください<br>
<INPUT TYPE="CHECKBOX" NAME="c1">HTMLから詳しく丁寧に<BR>
<INPUT TYPE="CHECKBOX" NAME="c2" VALUE="VBScript">VBScriptをもっと詳しく<BR>
<INPUT TYPE="CHECKBOX" NAME="c3" VALUE="GAME">ゲーム作ろうよ<BR>
<INPUT TYPE="submit" NAME="btn1" VALUE="送信">
</FORM>

<hr>
<h3>INPUT TYPE="CHECKBOX" NAME=の値が同一の場合</h3>
<PRE><!-- ↓入力に使ったHTML -->
↓入力に使うHTML
&lt;INPUT TYPE=&quot;CHECKBOX&quot; NAME=&quot;kibou&quot; VALUE=&quot;HTML&quot;&gt;HTMLから詳しく丁寧に&lt;BR&gt;
&lt;INPUT TYPE=&quot;CHECKBOX&quot; NAME=&quot;kibou&quot; VALUE=&quot;VBScript&quot;&gt;VBScriptをもっと詳しく&lt;BR&gt;
&lt;INPUT TYPE=&quot;CHECKBOX&quot; NAME=&quot;kibou&quot; VALUE=&quot;GAME&quot;&gt;ゲーム作ろうよ&lt;BR&gt;
<b>NAME=kibou と NAMEの値を同一にしてみた。</b>
</PRE>
<FORM ACTION="test045-1.asp" METHOD="POST">
<font color="blue">TYPE="CHECKBOX" チェックボックスの入力テスト</font><br>
このメルマガでやってほしいことにチェックを入れてください<br>
<INPUT TYPE="CHECKBOX" NAME="kibou" VALUE="HTML">HTMLから詳しく丁寧に<BR>
<INPUT TYPE="CHECKBOX" NAME="kibou" VALUE="VBScript">VBScriptをもっと詳しく<BR>
<INPUT TYPE="CHECKBOX" NAME="kibou" VALUE="GAME">ゲーム作ろうよ<BR>
<INPUT TYPE="submit" NAME="btn2" VALUE="送信">
</FORM>
<br>
</body>
</html>

↑をテスト実行する→ http://www.ken3.org/cgi-bin/test/test045-1.asp実行する


三流君ASPでフォーム関係の解説とサンプル
三流君ASPでADO MDB接続関係の解説とサンプル
三流君ASPでADO Excel接続関係の解説ページとサンプル
三流君ASPでADO CSV接続関係の解説ページとサンプル
三流君ASPでテキストファイル関係の解説とサンプルページ
三流君ASP VBScript関数の解説とサンプル



三流君ASPで遊ぶ、失敗する



三流君へ メッセージを送る

全ての質問に答えることはできませんが、
ダメもとで、気軽に質問、感想、メッセージを送ってくださいね・・・

感想や質問・要望・苦情など 三流君へメッセージを送る。
下記のフォームからメッセージを送ることができます。


あなたのお名前(ニックネーム):さん
返信は?:

アドレス:に返事をもらいたい
感想や質問↓:


(感想や質問・要望・苦情はHPで記事に載せることがあります。)
例:[XXXXさんへ回答例]←みたいに回答していたり...


Ken3 ホームページ 目次

分類:HPを大きく分けると4つの柱(分類)です。
・[Excel/Access VBA]の解説
・[ASP(Active Server Pages)]の解説。
・[元コンビニ店長時代の話]が弟に巻き込まれ、失敗した脱サラ、畑違い?の仕事で失敗。
・[プログラマーの愚痴]では、あまり見せたくない三流プログラマーの内面かな。
三流君を踏み台にする
主に上記4つの分類でHP作成やメルマガの発行を行ってます。
※更新頻度が落ちていて情報の鮮度が悪いです。

三流解説動画の再生リスト
https://www.youtube.com/user/ken3video/playlists

本当に三流なんです(笑):たまにスゴイですねなんて言われることもありますが、
真実は→ [三流君の真実は...] ←を初めに見てくださるとわかると思います。
(からくりは、成功例↑しか載せてなくて ヒドイ失敗例はお蔵入り迷宮入りが多かったりします)