2017年4月22日 星期六
Eclipse 開發 Windows GUI
安裝 WindowBuilder
到 Eclipse 官網 http://www.eclipse.org/windowbuilder/download.php
複製所屬 Eclipse 版本 link 上的 URL,貼上
2017年4月2日 星期日
Hibernate Query 用法
Hibernate Query examples (HQL)
出處: mkyong.com
https://www.mkyong.com/hibernate/hibernate-query-examples-hql/
HQL Select Query Example
Retrieve a stock data where stock code is “7277”.
Query query = session.createQuery("from Stock where stockCode = :code ");
query.setParameter("code", "7277");
List list = query.list();
Query query = session.createQuery("from Stock where stockCode = '7277' ");
List list = query.list();
2. HQL Update Query Example
Update a stock name to “DIALOG1” where stock code is “7277”.
Query query = session.createQuery("update Stock set stockName = :stockName" +
" where stockCode = :stockCode");
query.setParameter("stockName", "DIALOG1");
query.setParameter("stockCode", "7277");
int result = query.executeUpdate();
Query query = session.createQuery("update Stock set stockName = 'DIALOG2'" +
" where stockCode = '7277'");
int result = query.executeUpdate();
3. HQL Delete Query Example
Delete a stock where stock code is “7277”.
Query query = session.createQuery("delete Stock where stockCode = :stockCode");
query.setParameter("stockCode", "7277");
int result = query.executeUpdate();
Query query = session.createQuery("delete Stock where stockCode = '7277'");
int result = query.executeUpdate();
4. HQL Insert Query Example
In HQL, only the INSERT INTO … SELECT … is supported; there is no INSERT INTO … VALUES. HQL only support insert from another table. For example
"insert into Object (id, name) select oo.id, oo.name from OtherObject oo";
Insert a stock record from another backup_stock table. This can also called bulk-insert statement.
Query query = session.createQuery("insert into Stock(stock_code, stock_name)" +
"select stock_code, stock_name from backup_stock");
int result = query.executeUpdate();
The query.executeUpdate() will return how many number of record has been inserted, updated or deleted.
Reference
2017年4月1日 星期六
Linux 誤刪檔案解決辦法
首先先用 wget 下載 extundelete-0.2.0.tar.bz2 這個檔案,然後使用以下指令進行解壓縮
如下載至 /temp tar -xvf extundelete-0.2.0.tar.bz2 切換到解壓縮的目錄 /temp 執行 二次./configure ./configure ./configure執行 make 編譯原始碼 make compiler 好的 執行檔在 src 目錄中 執行救回誤刪檔案 ./src/extundelete /dev/sda1 –restore-all
參考文獻:風雲變色之 Linux 檔案誤刪救援
2017年3月29日 星期三
MySQL 如何找出 default Database 所在位置
Windows 版:
1.以 MS-DOS模式登入 MySQL
mysql -u root -p
2.輸入以下指令
1.以 MS-DOS模式登入 MySQL
mysql -u root -p
2.輸入以下指令
SHOW VARIABLES WHERE Variable_Name LIKE "%dir";
DataDir 就是 Database 所在位置
2017年3月26日 星期日
MS SQL 2008 儲存 Unicode 字元之解決
以 JSP + MS SQL 為例
將儲存欄位設定為 nchar 或 nvarchar 等 UNICODE 資料型態應該就可以了。
1.定義 DB 之SCHEMA 必須為 nvarchar
2.網頁編碼須為 utf-8
<%@ page language="java" import="java.util.*" contentType="text/html; charset=utf-8" pageEncoding="utf-8"%>
3.Database DAO 必須以 UTF-8 連線
<property name="connection.driver_class">com.microsoft.sqlserver.jdbc.SQLServerDriver</property>
<property name="hibernate.connection.url">jdbc:sqlserver://127.0.0.1:1433;databaseName=myDB2;useUnicode=true;characterEncoding=UTF-8;</property>
參考資料:
原文出處: 吳思融
http://rogercode.blogspot.tw/2015/07/sql-serversql-server.html
將儲存欄位設定為 nchar 或 nvarchar 等 UNICODE 資料型態應該就可以了。
1.定義 DB 之SCHEMA 必須為 nvarchar
2.網頁編碼須為 utf-8
<%@ page language="java" import="java.util.*" contentType="text/html; charset=utf-8" pageEncoding="utf-8"%>
3.Database DAO 必須以 UTF-8 連線
<property name="connection.driver_class">com.microsoft.sqlserver.jdbc.SQLServerDriver</property>
<property name="hibernate.connection.url">jdbc:sqlserver://127.0.0.1:1433;databaseName=myDB2;useUnicode=true;characterEncoding=UTF-8;</property>
參考資料:
原文出處: 吳思融
http://rogercode.blogspot.tw/2015/07/sql-serversql-server.html
[SQL Server]修改SQL Server資料庫字元編碼
目前網頁幾乎都用萬國碼UTF-8 and Unicode
若希望將資料庫的定序名稱更改為時,卻無法使用SQL Server Enterprise Manager直接修改,
可以使用下列語法修改:
ALTER DATABASE [DBName] SET SINGLE_USER WITH ROLLBACK IMMEDIATE
ALTER DATABASE [DBName] COLLATE SQL_Latin1_General_CP1_CI_AS
ALTER DATABASE [DBName] SET MULTI_USER WITH ROLLBACK IMMEDIATE
PS.[DBName]為您的資料庫名稱。
因為在改定序名稱時必須先鎖定資料庫
第一行要先將資料庫設定為SINGLE_USER(同一時間只能有一位使用者存取資料庫)
第二行修改定序名稱
第三行將資料庫改回 MULTI_USER
另外要執行這些指令值須先將所在的資料庫切換到master下。
註:
"Chinese_Taiwan_Stroke_CI_AS"為BIG5
"SQL_Latin1_General_CP1_CI_AS"為UTF8
若希望將資料庫的定序名稱更改為時,卻無法使用SQL Server Enterprise Manager直接修改,
可以使用下列語法修改:
ALTER DATABASE [DBName] SET SINGLE_USER WITH ROLLBACK IMMEDIATE
ALTER DATABASE [DBName] COLLATE SQL_Latin1_General_CP1_CI_AS
ALTER DATABASE [DBName] SET MULTI_USER WITH ROLLBACK IMMEDIATE
PS.[DBName]為您的資料庫名稱。
因為在改定序名稱時必須先鎖定資料庫
第一行要先將資料庫設定為SINGLE_USER(同一時間只能有一位使用者存取資料庫)
第二行修改定序名稱
第三行將資料庫改回 MULTI_USER
另外要執行這些指令值須先將所在的資料庫切換到master下。
註:
"Chinese_Taiwan_Stroke_CI_AS"為BIG5
"SQL_Latin1_General_CP1_CI_AS"為UTF8
Javascript 動態新增 input Element (不使用 Jquery)
圖例:
按新增作者後
<script>
function addinput(){
var obj_0 = document.getElementsByName("addmember");
var items="";
//保存原有值
for(i=0; i<obj_0.length ; i++){
if(items==""){
items = document.getElementsByName("addmember")[i].value;
}else{
items += ","+ document.getElementsByName("addmember")[i].value;
}
}
if( obj_0.length==0 ){
//第一次新增
var obj = document.getElementById("content");
obj.innerHTML = obj.innerHTML + "<br>作者:<input type='text' name='addmember' value='' />";
}else{
//第二次以後
//先清除原有input 項目,再重新新增
document.getElementById("content").innerHTML="";
var obj = document.getElementById("content");
if( items.indexOf(",")>0 ){
var ss =items.split(",");
for(i=0; i<ss.length ; i++){
var val = ss[i];
obj.innerHTML += "<br>作者:<input type='text' name='addmember' value='"+ val + "' />";
}
}else{
obj.innerHTML = "<br>作者:<input type='text' name='addmember' value='"+ items + "' />";
}
obj.innerHTML += "<br>作者:<input type='text' name='addmember' value='' />";
}
}
按新增作者後
<script>
function addinput(){
var obj_0 = document.getElementsByName("addmember");
var items="";
//保存原有值
for(i=0; i<obj_0.length ; i++){
if(items==""){
items = document.getElementsByName("addmember")[i].value;
}else{
items += ","+ document.getElementsByName("addmember")[i].value;
}
}
if( obj_0.length==0 ){
//第一次新增
var obj = document.getElementById("content");
obj.innerHTML = obj.innerHTML + "<br>作者:<input type='text' name='addmember' value='' />";
}else{
//第二次以後
//先清除原有input 項目,再重新新增
document.getElementById("content").innerHTML="";
var obj = document.getElementById("content");
if( items.indexOf(",")>0 ){
var ss =items.split(",");
for(i=0; i<ss.length ; i++){
var val = ss[i];
obj.innerHTML += "<br>作者:<input type='text' name='addmember' value='"+ val + "' />";
}
}else{
obj.innerHTML = "<br>作者:<input type='text' name='addmember' value='"+ items + "' />";
}
obj.innerHTML += "<br>作者:<input type='text' name='addmember' value='' />";
}
}
</script>
</head>
<body>
<form name="myForm">
<div id="myDiv" style="display:none">test</div><br/>
作者:<input type="text" name="member" /><input type='button' id="add" value="新增作者" onclick="addinput();" /><br/>
<span id="content"></span><br/>
</form>
</body>
2016年10月9日 星期日
訂閱:
文章 (Atom)
Java 不同編碼字串, 其字串長度大小計算
以 Java 開發專案, 在 DAO 寫入資料庫時, 常遇到JAVA 字串與資料庫編碼不一致, 有時會產生字串過長,導致無法寫入資料庫的情況. 這時就要在入庫前, 先驗證 JAVA 編碼字串是否超出資料庫欄位長度 JAVA 依 不同編碼, 其長度是不一樣的 如: ...
-
方法是: Tomcat 本身就提供了查看版本的指令: version 在 Tomcat 的安裝目錄的 x:\tomcat\ bin 子目錄下,有兩個檔: · version.bat for Windows · version.sh for...
-
以 Java 開發專案, 在 DAO 寫入資料庫時, 常遇到JAVA 字串與資料庫編碼不一致, 有時會產生字串過長,導致無法寫入資料庫的情況. 這時就要在入庫前, 先驗證 JAVA 編碼字串是否超出資料庫欄位長度 JAVA 依 不同編碼, 其長度是不一樣的 如: ...
-
以 JSP + MS SQL 為例 將儲存欄位設定為 nchar 或 nvarchar 等 UNICODE 資料型態應該就可以了。 1.定義 DB 之SCHEMA 必須為 nvarchar 2 .網頁編碼須為 utf-8 <%@ page langu...