SQLの窓

2017年12月20日


いまさらですが、『クリーンアップ』を管理者権限で起動して、Windows Update 関連やシステム関連の比較的大きなファイルを削除する

▼ 通常起動からも実行できますが、管理者権限で再起動するので二度手間です


通常起動では、Windows Update のクリーンアップは対象になりません。Windows の設定にもよるかもしれませんが、普通はそうです。そして、場合によったらギガ台に乗ってる巨大なファイルが必要も無いのにディスクに居座ってしまいます。しょっちゅうする必要も無い事ですが、実は管理者権限で実行するのは Windows7 と Windows 10 では違うようなので一応心に留めておく必要があると思います。

さらに、管理者権限の場合は『詳細オプション』というタブがあり、必要無いと思われる復元ポイント以前のリソースも削除できます(但し、トラブル時には復元ポイントが重要になるのでむやみに削除は禁物です )




Windows7 の場合



スタートメニューがあるので比較的簡単。メニューから『プログラムとファイルの検索』から『クリーン』と入力すればクリーンアップアプリが表示されて、CTRL+SHIFT+Enter で起動すると管理者権限による起動です。

地道にメニューから探すのであれば、アクセサリ > システムツール で『ディスク クリーンアップ』を右クリックしてポップアップメニューから『管理者として実行』すればいいです。近いうちにもう一回する予定があれば、そのまま右ドラッグしてショートカットをデスクトップに作成して、プロパティの詳細設定で『管理者として実行』にチェックしておけばいいです。

Windows10 の場合

Windows10 は、Creators Update がかかっていると、『コマンドプロンプト(管理者)』がメニューから消えています(設定で戻せます)。



かわりに Power Shell(管理者)があるので、その中で cmd と入力した後 cleanmgr と入力しましょう



あるいは、以下のように入力して、CTRL+SHIFT+Enter で管理者権限で実行できます


(clean だけでもいいですね)


で、いずれ(Windows 一般)にしても通常コマンドラインから実行したい場合(バッチファイルにしておけば簡単)は以下のようになります。
cmd "/c echo set o=CreateObject("Shell.Application"):o.ShellExecute "cleanmgr","","","runas",1 > %TEMP%\_.vbs & wscript.exe %TEMP%\_.vbs"




posted by lightbox at 2017-12-20 13:29 | Windows | このブログの読者になる | 更新情報をチェックする

2017年12月19日


Seesaa ブログの通常エディタで記事の先頭に Twitter カード用の meta 要素を挿入するブックマークレット

▼ ブックマークレットのリンク(ブックマークバーにドロップしてください)
Twitterカード用画像 : meta 要素挿入

Twitter カード用画像のリンクを propmpt で表示したダイアログに入力して実行します。キャンセルするとなにも実行されません。

リンクのコード
<a href="javascript:var%20a=prompt('画像URL','');if(a!=null){$('#article__body').val('&lt;meta name=&#34;twitter:image&#34; content=&#34;'+a+'&#34;&gt;'+&#34;\n&#34;+$('#article__body').val());}void(0);" onclick=" 
		alert('ブックマークバーにドロップしてください'); 
		if (window.navigator.appName.toLowerCase().indexOf('microsoft') > -1) { 
			event.returnValue = false; 
		} 
		event.preventDefault(); 
		event.stopPropagation();
	">Twitterカード用画像 : meta 要素挿入</a>

Seesaa 以外のブログシステムでも、jQuery が使用されておれば、$('#article__body') の部分を変更してどこでも使えると思います。

▼ Twitter の Card validator へのリンク





タグ:twitter
posted by lightbox at 2017-12-19 20:02 | ブックマークレット | このブログの読者になる | 更新情報をチェックする

2017年12月12日


Windows7(32ビット) が急にフリーズして、メモリ診断して OK だったけれど、結局メモリの障害だった経緯で行った事

デュアルブートの PC で、両方に Windows7(32ビット)をインストールしています。ある日その片側でフリーズしたのが始まりでしたが、とりあえずメモリ診断やったんですが、その時は異常ありませんでした。



その後、もう一方の Windows7 を立ち上げて Google Chrome の操作をしていると画面が乱れて固まりました。当然『電源長押し』で対処するしか無く、しかし BIOS の画面が表示されてエラー云々。標準の設定で保存して再起動しました。

同一 PC で二つの OS で同様のトラブルなので、共通するのはハード(特にメモリ)なんですが、一応『トレンドマイクロ オンラインスキャン』でウイルスチェックをしてみました。放置してしばらくして PC の前にやってくると PC は死んでました。

なんとかいろいろあって、再度立ち上げて再び『メモリ診断』すると、01% から動かず、放置して帰ってくるとまた死んでました。

もう、メモリが原因なのはほぼ決定と言う事でメモリ抜いてもう一度指しなおして再起動。しかし、反応せず(ディスプレイに信号が来ない)。そこで、たださし直すのでは無くかなり力を入れてグィっと差し込んで再起動してみました(一応表面のほこりと、マザーボード側のほこりはみみかきの綿部分で排除)。

すると正常に立ち上がり、すぐメモリ診断しましたが異常なし。でも、最初のメモリ診断でも問題なかったので、以下の処理を行いました。
1) 管理者権限のコマンドプロンプトで chkdsk /F
2) 管理者権限のコマンドプロンプトで SFC /SCANNOW
3) トレンドマイクロ オンラインスキャン
特に問題なく全て終了したので、裏側の Windows7 でも 1) と 2) を行いましたが、異常ありません。 この作業は二日にまたいでまして、その間あった事 一度、ブルースクリーンになったので、BlueScreenView というフリーソフトがある事を知りました。いつか使えるかもしれません。 気になって Windows Update 調べたら、たまたま Windows Update も死んでて、その対応にも追われました。 (Windows7 で Microsoft(Windows) Update ができなくなる状態の解消方法) Google Chrome も死亡してしまって、User Data を移動して再インストールしました。User Data の中のブックマークだけ戻して再運用してます
1) C:\Users\ユーザ\AppData\Local\Google\Chrome\User Data を適当な場所へ移動
2) Chroem アンインストール
3) Chroem インストール
4) 移動 User Data の中の Default\Bookmarks を新しい 場所へコピー
Google Chrome は以前からメモリを使いすぎると思ってたので、設定変更しました。 この PC は、以前も一度メモリがぶっ壊れて買い換えてます。その時は新品のぶっ壊れたメモリと同じものもらいましたが、怖いので違うものが今刺さってます。なので、こんどなんかあったら買い替えなれければと思っています。 しかし、メモリの抜き差しの2回目で改善するって、運がいいのか悪いのか...
タグ:トラブル
posted by lightbox at 2017-12-12 18:02 | Windows7 | このブログの読者になる | 更新情報をチェックする

2017年12月11日


Windows7 で Microsoft(Windows) Update ができなくなる状態の解消方法

wuauclt /ShowWU で表示される画面で以下のようになり、なにもできない状態です
( 2017 年 12 月 4 日 (月曜日) より発生との事 ) 

▼ Windows7 32ビット


▼ Windows7 64ビット


▼ Microsoft の対応解説ページ
Windows 7 / Windows Server 2008 R2 以前の環境において、Microsoft Update 実行時に 0x80248015 エラーが発生する

以下のバッチファイルを管理者として実行します
net stop wuauserv
net stop bits

ren %systemroot%\SoftwareDistribution SoftwareDistribution.old

del "%ALLUSERSPROFILE%\Application Data\Microsoft\Network\Downloader\qmgr0.dat"
del "%ALLUSERSPROFILE%\Application Data\Microsoft\Network\Downloader\qmgr1.dat"

net start bits
net start wuauserv

wuauclt /detectnow

BITS は、Background Intelligent Transfer Service で、wuauserv は Windows Update です


実行後、wuauclt /ShowWU 等で Windows Update の UI を表示させると、表示のおかしかった下部に正しい表示がされて、更新可能になります。






posted by lightbox at 2017-12-11 12:04 | Windows7 | このブログの読者になる | 更新情報をチェックする

2017年12月05日


jQuery Columns を使って、Picasa API より アルバム一覧を表示する

Google+ のユーザID は、ログインした状態で、ブラウザに https://get.google.com/albumarchive を入力して Enter すれば URL の最後に付加されます。Picasa 時代に作成されたアルバムは、以下のリンクから表示してサイズを自由に指定できる画像 URL を手に入れる事ができます。

リンク先でユーザID を入力して一覧表示します


▼ アルバムリンクからギャラリー(画像をクリックすると拡大表示)


▼ リンクをクリックすると、HTML 取得画面



▼ PHP


▼ Shadowbox



▼ 以下、ブログ内でアルバムIDの一覧の表示
columns プラグインの環境の都合で、右下矢印画像が出ていませんが、動作に支障はありません

以下のフィールドにユーザID を入力して読み込みボタンを押すだけですが、ユーザID には数字以外の人も居るようでしたが、それでもちゃんと取得できました。

呼び出した JSON を読むには、整形が必要なので JSONLint を使用しました


<script src="//ajax.googleapis.com/ajax/libs/jquery/2.1.4/jquery.min.js"></script>

<script src="http://winofsql.jp/if_skeleton/basic_06_columns/columns/js/jquery.columns.min.js"></script>
<link rel="stylesheet" href="http://winofsql.jp/if_skeleton/basic_06_columns/columns/css/classic.css">

<input type="text" id="target_user" value="101280392108947207617">
<input type="button" value="読み込み" onclick="get_album()">
<div id="columns"></div>

<script>

var example = null;
function get_album() {

	var user_id = $("#target_user").val();
	if ( example != null ) {
		example.destroy();
	}

	$.ajax({
		url:'https://picasaweb.google.com/data/feed/api/user/' + user_id + '?alt=json',
		dataType: 'json', 
		success: function(json) { 

			var target = [];
			for( i = 0; i < json.feed.entry.length; i++ ) {
				if ( !json.feed.entry[i].gphoto$albumType ) {
					target.push( 
						{
							 'title' : json.feed.entry[i].title.$t,
							'numphotos':  json.feed.entry[i].gphoto$numphotos.$t,
							'albumid' : json.feed.entry[i].gphoto$id.$t
						}
					);
				}
			} 

			example = $('#columns').columns({
				data:target, 
				schema: [
					{"header":"タイトル", "key":"title", "template":"{{title}}"},
					{"header":"画像数", "key":"numphotos" },
					{"header":"アルバムID", "key":"albumid" }

				],
				size: 100,showRows: [50,100,200]

			}); 
		}
	}); 

}
</script>

関連する記事

Picasa が終了するので、Google フォトで登録した画像の URL を Picasa の API で取得する手順

jQuery プラグイン : Columns と PHP の連携と、ドキュメントには書かれていないカスタマイズ方法




posted by lightbox at 2017-12-05 20:30 | プラグイン:jQuery | このブログの読者になる | 更新情報をチェックする

jQuery プラグイン : Columns と PHP の連携と、ドキュメントには書かれていないカスタマイズ方法

デモページ


jQuery プラグインの Columns は、JSON データを読み込むだけで上のような至れり尽くせりのテーブル要素による一覧表示を可能にします。

問合せテーブルの特徴

1) ページ処理( ページとページ )
2) ページ毎の行数変更
3) テーブル上のデータのリアルタイム検索
4) 列のタイトルをクリックしてソート

※ 特別なオプションを設定しなければ、3) と 4) は全ての列が対象となります

とても簡単な PHP との連携

PHP 側では、JSON で行の配列を返せば良いので、データベースの読み込み処理は、一括で簡単です。列名やデータの表示方法は、JSON のデータで決定されるので、SQL を変更する事によって自由自在に表示を変更できます。
<?php
header( "Content-Type: application/json; Charset=utf-8" );
header( "Expires: Wed, 31 May 2000 14:59:58 GMT" );

require_once("dbsetting.php");

$query = <<<QUERY
-- ***********************************************
-- SQL 開始
-- ***********************************************
select 

SYAIN.社員コード,
SYAIN.氏名,
SYAIN.フリガナ,
SYAIN.所属,
A.名称 as 所属名,
-- SYAIN.性別,
B.名称 as 性別,
SYAIN.給与,
ifnull(SYAIN.手当,'') as 手当,
ifnull(SYAIN.管理者,'') as 管理者,
ifnull(SYAIN2.氏名,'') as 管理者名,
ifnull(DATE_FORMAT(SYAIN.生年月日,'%Y/%m/%d'),'') as 生年月日

from 

社員マスタ SYAIN
left outer join コード名称マスタ A
on SYAIN.所属 = A.コード

left outer join 社員マスタ SYAIN2
on SYAIN.管理者 = SYAIN2.社員コード

left outer join コード名称マスタ B
on SYAIN.性別 = B.コード

where A.区分 = 2 and B.区分 = 1	and SYAIN.削除区分 is NULL
and SYAIN.氏名 like '%{$_GET['cond']}%'

order by SYAIN.社員コード

-- ***********************************************
-- SQL 終了
-- ***********************************************
QUERY;

$result = $connect->query($query); 
$row = $result->fetch_all(MYSQLI_ASSOC);

print json_encode($row);

?>

mysqli_result::fetch_all

ドキュメントにはっきり書かれていないカスタマイズ

ソースコードを読まないと解りませんが、『問合せテーブルの特徴』での4つの処理毎にイベントが用意されています。これらのイベントが発生すると、テーブルの表示が書き換わるのですが、HTML そのものを再構築するので外部からカスタマイズするには無理があります。そこで、以下の4つの定義済みイベントが必要になります。
1) pageHandler
2) sizeHandler
3) searchHandler
4) sortHandler
これらのイベントは、他のオプションプロパティと同じ部分で定義されているので、設定時のプロパティとして無名関数を定義する事によって、外部から処理する事が可能になります。 しかし、この中に書く処理には、デフォルトの処理があるので、外部で定義する場合もその処理は記述しなければなりのません。そして、そのデフォルトの処理は、ソースコードを読まないと具体的に知る事ができません。 ▼ 以下がその処理を含めた、デモ用の初期設定です。
$(function() {

	$.get("syain.php?cond=" , function(data){

		$('#columns').columns({
			data: data, 
			templateFile: 'columns/templates/custom.mst',
			showRows: [10, 20, 50],
			size: 10,
			sortableFields: ['社員コード','氏名'],
			searchableFields: ['所属'],
			pageHandler: function(){
				this.create();
				customTable();
			},
			sortHandler: function() {
				this.page = 1;
				this.create();
				customTable();
			},
			searchHandler: function(event) { 
				if(this.liveSearch) {
					this.create();
				} else {
					if(event.keyCode == '13') {
						this.create();
					}
				}
				customTable();
			},
			sizeHandler: function() {
				this.create();
				customTable();
			}
		
		});

		// プラグイン実装後の1回きりの処理
		customTable();

	});



});


this.create() がテーブルの再構築処理です。ですから、カスタマイズするのは、this.create() の後ろに自分の処理を行う必要があります。( this.create() の前に行う処理の場合は、オプションや内部データを直接変更する処理になると思います )

ここで行った『あとから CSS で右よせにしてカンマ編集』

テーブルなので、jQuery の find を使う事によって結構単純に目的の列の情報を変更する事ができます。以下の customTable 関数では、TH 部分と TD 部分を個別に設定しています
function customTable() {

		// 給与と手当
		$("table").find("th").eq(6).css("text-align", "right");
		$("table").find("th").eq(7).css("text-align", "right");

		$("table").find("tr").each( function(){
			// 給与と手当
			$(this).find("td").eq(6).css("text-align", "right");
			$(this).find("td").eq(7).css("text-align", "right");

			var kyuyo = $(this).find("td").eq(6).text();
			kyuyo = parseInt(kyuyo,10);
			// カンマ編集
			kyuyo = kyuyo.toLocaleString();
			$(this).find("td").eq(6).text(kyuyo);

			var teate = $(this).find("td").eq(7).text();
			if ( teate != "" ) {
				teate = parseInt(teate,10);
				// カンマ編集
				teate = teate.toLocaleString();
			}
			$(this).find("td").eq(7).text(teate);

		} );
}



説明不十分なテンプレート使用方法

デフォルトのテンプレートは、ソースコードに埋め込まれてしまっています。ですから、テンプレートをカスタマイズするには、templateFile プロパティを使用する必要があります。外部ファイルに用意されたテンプレートファイルは、以下の二つです。

custom.mst
default.mst

ソースに埋め込まれているものが、default.mst のようなので、custom.mst を使ってみると、どうやらバグのようで、カスタマイズされたフィールド( ページジャンプ ) が、Plugin オプションを使わないと動作しないようですが、用意されている gotopage.js を使ってもちょっと動かないようです。

そもそも、Plugin に関する説明が全くありませんが、使うとすると内部から呼び出されるイベントとして動作します。但し、テーブル再構築後にしか呼ばれないようなので、利用範囲が限定されます。

Plugin 内のイベントは二つしか無く、init と create で、init は最初に一度だけ処理されます。create を使って、狙った要素にイベントを作成する事ができると思いますが、通常のイベントオプションを使ったほうが汎用性があるように思います。

ただ、サンプルとして付加されている、ajaxpaging.js は、プラグイン内で イベントオプション を使用しており、『必要な時に必要だけデータを取得して表示』するという処理を実現しているように見えます。

テンプレートと画像の扱い

ページ処理用の画像が、テンプレートに直接パスが埋め込まれているので、実行中のページの中に images フォルダが必要である事になっています。images の場所が違う場合は、テンプレート内を直接変更する必要があります。

サーチ用の画像は CSS 内で使用されているので、CSS があるフォルダからの相対パスが正しければ表示されます

ドキュメント内の誤記

size のデフォルトが 10 と書かれていますが、実際は 5 です

oddRowClass のデフォルトが 'ui-table-rows-even' となっていますが、完全な誤りです。実際は(あたりまえですが)、ui-table-rows-odd になります。

even と odd は、偶数・奇数です。行の背景色を交互に変える為に一般的に使用される手法です

デモで使用しているテーブルの仕様

▼ 社員マスタ
列名 型名 最大桁 NULL 主キー
1 社員コード varchar 4 N 1
2 氏名 varchar 50    
3 フリガナ varchar 50    
4 所属 varchar 4    
5 性別 int      
6 作成日 datetime      
7 更新日 datetime      
8 給与 int      
9 手当 int      
10 管理者 varchar 4    
11 生年月日 date      
12 削除区分 varchar 1    

▼ コード名称マスタ
列名 型名 最大桁 NULL 主キー
1 区分 int   N 1
2 コード varchar 10 N 2
3 名称 varchar 50    
4 数値1 int      
5 数値2 int      
6 作成日 datetime      
7 更新日 datetime      

関連する記事

イラストAC 用 : 前日ダウンロード数を一覧表示する為のブックマークレット : jQuery プラグイン使用

イラストACの管理画面に、イラスト毎の前日ダウンロード項目が追加されたので、前日にダウンロードされたイラストのみをテーブルで表示するブックマークレットを作成しました。

jQuery Columns を使って、Picasa API より アルバム一覧を表示する




posted by lightbox at 2017-12-05 20:24 | IFRAME パッケージ | このブログの読者になる | 更新情報をチェックする
Seesaa の各ページの表示について
Seesaa の 記事がたまに全く表示されない場合があります。その場合は、設定> 詳細設定> ブログ設定 で 最新の情報に更新の『実行ボタン』で記事やアーカイブが最新にビルドされます。

Seesaa のページで、アーカイブとタグページは要注意です。タグページはコンテンツが全く無い状態になりますし、アーカイブページも歯抜けページはコンテンツが存在しないのにページが表示されてしまいます。

また、カテゴリページもそういう意味では完全ではありません。『カテゴリID-番号』というフォーマットで表示されるページですが、実際存在するより大きな番号でも表示されてしまいます。

※ インデックスページのみ、実際の記事数を超えたページを指定しても最後のページが表示されるようです

対処としては、このようなヘルプ的な情報を固定でページの最後に表示するようにするといいでしょう。具体的には、メインの記事コンテンツの下に『自由形式』を追加し、アーカイブとカテゴリページでのみ表示するように設定し、コンテンツを用意するといいと思います。


※ エキスパートモードで表示しています

アーカイブとカテゴリページはこのように簡単に設定できますが、タグページは HTML 設定を直接変更して、以下の『タグページでのみ表示される内容』の記述方法で設定する必要があります

<% if:page_name eq 'archive' -%>
アーカイブページでのみ表示される内容
<% /if %>

<% if:page_name eq 'category' -%>
カテゴリページでのみ表示される内容
<% /if %>

<% if:page_name eq 'tag' -%>
タグページでのみ表示される内容
<% /if %>
この記述は、以下の場所で使用します
container 終わり



フリーフォントで簡単ロゴ作成
フリーフォントでボタン素材作成
フリーフォントで吹き出し画像作成
フリーフォントではんこ画像作成
ほぼ自由に利用できるフリーフォント
フリーフォントの書体見本とサンプル
画像を大きく見る為のウインドウを開くボタンの作成

CSS ドロップシャドウの参考デモ
イラストAC
ぱくたそ
写真素材 足成
フリーフォント一覧
utf8 文字ツール
右サイド 終わり
base 終わり