select * from v$sesstat s, v$statname n where s.statistic# = n.statistic# and n.name = 'opened cursors current' and s.sid in ( select sid from v$session where machine = '[my machine]' )
Rants and ravings of a semi-autistic developer who has a hard time remembering idiotic nonsense details. Why remember it, when you know where to find it.
Thursday, December 30, 2010
Oracle: what is the cursor count?
Wednesday, December 29, 2010
Oracle: Reading Table Locks And From Where
SELECT ALL ALL_OBJECTS.OWNER, ALL_OBJECTS.OBJECT_NAME, ALL_OBJECTS.OBJECT_TYPE, V$LOCKED_OBJECT.ORACLE_USERNAME, V$LOCKED_OBJECT.OS_USER_NAME, DECODE(V$LOCKED_OBJECT.LOCKED_MODE, 0, 'None', 1, 'Null', 2, 'Row-S (SS)', 3, 'Row-X (SX)', 4, 'Share', 5, 'S/Row-X (SSX)', 6, 'Exclusive', 'Unknown') LockMode, V$SESSION.MACHINE, V$SESSION.PROGRAM, V$SESSION.LOGON_TIME, V$SESSION.TERMINAL, V$SESSION.SID, V$SESSION.SERIAL# FROM V$LOCKED_OBJECT, ALL_OBJECTS, V$SESSION WHERE ((ALL_OBJECTS.OBJECT_ID=V$LOCKED_OBJECT.OBJECT_ID) AND (V$LOCKED_OBJECT.SESSION_ID=V$SESSION.SID));
Wednesday, November 10, 2010
SQLite Hibernate: Primary Keys and Foreign Keys on generated values
Here a little hint on defining the correct mapping for generated values and their relationships.
If the
When I generated the database table with
Here the tip of my configuration: just make sure your generated values are "integer" by using the columnDefinition and both "create" and "validate" settings for
If the
SQLiteDialect.class
is used for the Hibernate dialect and the identity column string returns "integer". When I generated the database table with
hibernate.hbm2ddl.auto=create
and then read it back with hibernate.hbm2ddl.auto=validate
I ended up with corrupt foreign key relationships.
Caused by: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sessionFactory' defined in class path resource [orm-layer.xml]: Invocation of init method failed; nested exception is org.hibernate.HibernateException: Wrong column type in APPLICATION for column APPLICATION_ID. Found: integer, expected: bigint
at Caused by: org.hibernate.HibernateException: Wrong column type in APPLICATION for column APPLICATION_ID. Found: integer, expected: bigint
at org.hibernate.mapping.Table.validateColumns(Table.java:284)
at org.hibernate.cfg.Configuration.validateSchema(Configuration.java:1130)
at org.hibernate.tool.hbm2ddl.SchemaValidator.validate(SchemaValidator.java:139)
at org.hibernate.impl.SessionFactoryImpl.(SessionFactoryImpl.java:359)
at org.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java:1341)
at
Here the tip of my configuration: just make sure your generated values are "integer" by using the columnDefinition and both "create" and "validate" settings for
hibernate.hbm2ddl.auto
.Thursday, October 21, 2010
JAXB Serializable Binding with Maven
Generating the classes from a xsd where the classes implement the java.io.Serializable interface for serialization between nodes.
The maven plugin configuration in the pom.xml
The content of the binding.xjb
The result:
. ---> pom.xml ./.settings ./src ./src/main ./src/main/binding ---> binding.xjb ./src/main/java ./src/main/java/com ./src/main/java/META-INF ./src/main/resources ---> my.xsd
The maven plugin configuration in the pom.xml
<plugins> <plugin> <groupid>org.jvnet.jaxb2.maven2</groupid> <artifactid>maven-jaxb2-plugin</artifactid> <version>0.7.4</version> <configuration> <extension>true</extension> <args> <arg>-Xfluent-api</arg> </args> <schemadirectory>src/main/resources</schemadirectory> <bindingdirectory>src/main/binding</bindingdirectory> <plugins> <plugin> <groupid>net.java.dev.jaxb2-commons</groupid> <artifactid>jaxb-fluent-api</artifactid> <version>2.1.8</version> </plugin> </plugins> </configuration> <executions> <execution> <goals> <goal>generate</goal> </goals> </execution> </executions> </plugin> </plugins>
The content of the binding.xjb
<jxb:bindings version="1.0" xmlns:jxb="http://java.sun.com/xml/ns/jaxb" xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xjc="http://java.sun.com/xml/ns/jaxb/xjc" jxb:extensionBindingPrefixes="xjc"> <jxb:bindings> <jxb:globalBindings> <xjc:serializable/> </jxb:globalBindings> </jxb:bindings> </jxb:bindings>
The result:
@XmlAccessorType(XmlAccessType.FIELD)
@XmlType(name = "application", propOrder = {
"name",
"version",
"state",
"serverName"
})
public class Application
implements Serializable
{
@XmlElement(required = true)
protected String name;
@XmlElement(required = true)
protected String version;
@XmlElement(required = true)
protected String state;
Wednesday, October 13, 2010
Displaying MANIFEST.MF of multiple jars in directory
Oneliner for bash to dump the MANIFEST.MF information per jar.
find . -name '*.jar' -type f | while read dir; do [ -f META-INF/MANIFEST.MF ] && rm -f META-INF/MANIFEST.MF;echo $dir; md5sum $dir;jar xfv $dir META-INF/MANIFEST.MF; cat META-INF/MANIFEST.MF; doneOn MacOSX the md5sum would be md5, and if you do not have the jar util... here the unzip version.. .
find . -name '*.jar' -type f | while read dir; do [ -f META-INF/MANIFEST.MF ] && rm -f META-INF/MANIFEST.MF;echo $dir; md5 $dir;unzip $dir META-INF/MANIFEST.MF; cat META-INF/MANIFEST.MF; done
Tuesday, September 21, 2010
Thursday, August 26, 2010
Tuesday, July 13, 2010
move extension on files
perl -e 'foreach my $r (glob("*.jad")) { $x=$r;$r=~ s/jad/java/;system("mv $x $r") unless(-f $r)}'
Saturday, June 19, 2010
Remove Non Printable Characters with sed
Took a while to find this and the exact syntax but here its, removing all non ascii chars.
$ sed 's/[^ -~]//g' < B2.java > BeanUtils.java
Thursday, June 17, 2010
SQLite Primary Keys and Hibernate
SQLite is a modern, compact and stable database. Using Hibernate on top of SQLite proved to be a challenge with Primary Keys.
Here the reason why the autoincrement does not work... even if we would specify it the table creation would mess you up with two primary key definitions. See the next pictures why and how...
So you need the following SQLiteDialect that is being found accross the web... here a copy.
Next set the dialect of the Hibernate mapping...
Here the reason why the autoincrement does not work... even if we would specify it the table creation would mess you up with two primary key definitions. See the next pictures why and how...
So you need the following SQLiteDialect that is being found accross the web... here a copy.
/** * */ package org.territory; import java.sql.Types; import org.hibernate.Hibernate; import org.hibernate.dialect.Dialect; import org.hibernate.dialect.function.SQLFunctionTemplate; import org.hibernate.dialect.function.StandardSQLFunction; import org.hibernate.dialect.function.VarArgsSQLFunction; /** * @author 751818 * */ public class SQLiteDialect extends Dialect { /** * */ public SQLiteDialect() { super(); registerColumnType(Types.BIT, "integer"); registerColumnType(Types.TINYINT, "tinyint"); registerColumnType(Types.SMALLINT, "smallint"); registerColumnType(Types.INTEGER, "integer"); registerColumnType(Types.BIGINT, "bigint"); registerColumnType(Types.FLOAT, "float"); registerColumnType(Types.REAL, "real"); registerColumnType(Types.DOUBLE, "double"); registerColumnType(Types.NUMERIC, "numeric"); registerColumnType(Types.DECIMAL, "decimal"); registerColumnType(Types.CHAR, "char"); registerColumnType(Types.VARCHAR, "varchar"); registerColumnType(Types.LONGVARCHAR, "longvarchar"); registerColumnType(Types.DATE, "date"); registerColumnType(Types.TIME, "time"); registerColumnType(Types.TIMESTAMP, "timestamp"); registerColumnType(Types.BINARY, "blob"); registerColumnType(Types.VARBINARY, "blob"); registerColumnType(Types.LONGVARBINARY, "blob"); // registerColumnType(Types.NULL, "null"); registerColumnType(Types.BLOB, "blob"); registerColumnType(Types.CLOB, "clob"); registerColumnType(Types.BOOLEAN, "integer"); registerFunction("concat", new VarArgsSQLFunction(Hibernate.STRING, "", "||", "")); registerFunction("mod", new SQLFunctionTemplate(Hibernate.INTEGER, "?1 % ?2")); registerFunction("substr", new StandardSQLFunction("substr", Hibernate.STRING)); registerFunction("substring", new StandardSQLFunction("substr", Hibernate.STRING)); } public boolean supportsIdentityColumns() { return true; } /* * public boolean supportsInsertSelectIdentity() { return true; // As * specify in NHibernate dialect } */ public boolean hasDataTypeInIdentityColumn() { return false; // As specify in NHibernate dialect } /* * public String appendIdentitySelectToInsert(String insertString) { return * new StringBuffer(insertString.length()+30). // As specify in NHibernate * dialect append(insertString). * append("; ").append(getIdentitySelectString()). toString(); } */ public String getIdentityColumnString() { return "INTEGER"; // return "integer"; } public String getIdentitySelectString() { return "select last_insert_rowid()"; } public boolean supportsLimit() { return true; } public String getLimitString(String query, boolean hasOffset) { return new StringBuffer(query.length() + 20).append(query).append( hasOffset ? " limit ? offset ?" : " limit ?").toString(); } public boolean supportsTemporaryTables() { return true; } public String getCreateTemporaryTableString() { return "create temporary table if not exists"; } public boolean dropTemporaryTableAfterUse() { return false; } public boolean supportsCurrentTimestampSelection() { return true; } public boolean isCurrentTimestampSelectStringCallable() { return false; } public String getCurrentTimestampSelectString() { return "select current_timestamp"; } public boolean supportsUnionAll() { return true; } public boolean hasAlterTable() { return false; // As specify in NHibernate dialect } public boolean dropConstraints() { return false; } public String getAddColumnString() { return "add column"; } public String getForUpdateString() { return ""; } public boolean supportsOuterJoinForUpdate() { return false; } public String getDropForeignKeyString() { throw new UnsupportedOperationException( "No drop foreign key syntax supported by SQLiteDialect"); } public String getAddForeignKeyConstraintString(String constraintName, String[] foreignKey, String referencedTable, String[] primaryKey, boolean referencesPrimaryKey) { throw new UnsupportedOperationException( "No add foreign key syntax supported by SQLiteDialect"); } public String getAddPrimaryKeyConstraintString(String constraintName) { throw new UnsupportedOperationException( "No add primary key syntax supported by SQLiteDialect"); } public boolean supportsIfExistsBeforeTableName() { return true; } public boolean supportsCascadeDelete() { return false; } /* * (non-Javadoc) * * @see org.hibernate.dialect.Dialect#getNativeIdentifierGeneratorClass() */ @Override public Class getNativeIdentifierGeneratorClass() { // TODO Auto-generated method stub return super.getNativeIdentifierGeneratorClass(); } }
Next set the dialect of the Hibernate mapping...
Next set the sequence generate for the ID's that you want AUTOINCREMENT'ed.
And that should give you an incremented value of your id....
Saturday, May 15, 2010
Monday, May 10, 2010
How to download ASL wt DVD script
#!/usr/bin/perl my $year = 2010; my $x = 0; for my $month ( 1 .. 12 ) { printf "downloading month %s", $month; for my $article ( 1 .. 6 ) { $file = sprintf "%s_%s_%04d%02d%02d_%02d.m4v", "w", "ASL", $year, $month, 15, $article; next if -e $file and -s $file < 16; $url = sprintf "http://download.jw.org/files/media_magazines/%s\n", $file; print $url, "\n"; system("curl -O $url"); $error=$_; print "$error\n"; system("rm $file") if $error =~ /No such/ or $error =~ /File not found/ or -s $file < 16; } }
Thursday, May 6, 2010
Linux Resource Troubleshooting Commands
Command that reveal the inner workings of our machine
ulimit free vmstat netstat sysstat mpstat iostat ping -c 1 traceroute sar What is the process consuming the most CPU ps -eo pcpu,pid,user,args | sort -k 1 -r | head -2 What is the memory usage after 16:30 ... sar -s 16:30:00 -r What is the disk paging after 16:30 .. sar -s 16:30:00 -B Another day on I/O and mem usage sar -f /var/log/sa/sa12 -u -n SOCK -B -r -s 15:30:00 -e 16:10:00 If you used previous versions of jvmstat you may be familiar with some of the older names... Here is a mapping of the old names to the new names: JDK 5.0 jvmps is now jps, sse docs jvmstat is now jstat perfagent is now jstatd jvmstat 3.0 visualgc is still visualgc
Thursday, April 8, 2010
jw.org download script
#!/usr/bin/perl our @GREEK_SCRIPTURES = qw/Mt Mr Lu Joh Ac Ro 1Co 2Co Ga Eph Php Col 1Th 2Th 1Ti 2Ti Tit Phm Heb Jas 1Pe 2Pe 1Jo 2Jo 3Jo Jude Re/; our @GREEK_CHAPTERS = qw/28 16 24 21 28 16 16 13 6 6 4 3 5 3 6 4 3 1 13 5 5 3 5 3 1 1 22/; my $i = 40; my $x = 0; foreach my $abbrev (@GREEK_SCRIPTURES) { for ( 1 .. $GREEK_CHAPTERS[$x] ) { if ($ARGV[0]) { next unless ($ARGV[0] and $ARGV[0] =~ /$abbrev/); } $file = sprintf "%d_%s_ASL_%02d.m4v", $i, $abbrev, $_; next if -e $file; $url = sprintf "http://download.jw.org/files/media_bible/%s\n", $file; print $url, "\n"; #system("wget -nc $url"); system("curl -O $url"); system("rm $file") if $! =~ /No such/; } $x++; $i++; }
Saturday, March 6, 2010
I do not wish my screensaver to lock my computer
In Windows XP, it really annoys me when my computer idles for a few minutes and then the screen locks. I try to be careful not to leave my laptop lying around, so I prefer my screensaver not to be password-protected.
In order to make it so that your computer won’t lock itself after a few minutes, do this:
Run ‘regedit’ to edit your registry
Navigate down the tree to HKEY_CURRENT_USER > Software Policies > Microsoft > Windows > Control Panel > Desktop and look for an entry ScreenSaverIsSecure and ScreenSaveActive.
You want to make sure the value for ScreenSaverIsSecure and ScreenSaveActive is 0 (zero).
Exit regedit; you’re done!
[HKEY_CURRENT_USER \Software \Microsoft \Windows \CurrentVersion \Policies \System]
DisableLockWorkstation = 1
Ultimate lock down
In order to make it so that your computer won’t lock itself after a few minutes, do this:
Run ‘regedit’ to edit your registry
Navigate down the tree to HKEY_CURRENT_USER > Software Policies > Microsoft > Windows > Control Panel > Desktop and look for an entry ScreenSaverIsSecure and ScreenSaveActive.
You want to make sure the value for ScreenSaverIsSecure and ScreenSaveActive is 0 (zero).
Exit regedit; you’re done!
[HKEY_CURRENT_USER\Software\Policies\Microsoft\Windows\Control Panel\Desktop]
Delete the "ScreenSaverIsSecure" value.
If this comes back, you may have to use Group Policy Editor.
OR
Disable the lock workstation button
[HKEY_CURRENT_USER \Software \Microsoft \Windows \CurrentVersion \Policies \System]
DisableLockWorkstation = 1
Ultimate lock down
Windows Registry Editor Version 5.00 [HKEY_CURRENT_USER\Software\Policies\Microsoft\Windows\Control Panel\Desktop] "ScreenSaveActive"="1" "ScreenSaveTimeOut"="900" "SCRNSAVE.EXE"="(NONE)" "ScreenSaverIsSecure"="0" [HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\Policies\System] "NoDispScrSavPage"=dword:00000000 "DisableLockWorkstation"=dword:00000000 [HKEY_CURRENT_USER\Control Panel\Desktop] "ScreenSaverIsSecure"="0" "ScreenSaveTimeOut"="9000" "ScreenSaveActive"="1" "PowerOffActive"="1" "WaitToKillAppTimeout"="7000" "SCRNSAVE.EXE"="(NONE)"
Labels:
regedit,
screensaver,
xp
Wednesday, February 17, 2010
one line sorting hash perl
Onliner for Sorting a hash in perl
foreach (sort { $y{$a} <=> $y{$b}} keys %y) { printf "%60s %4d\n", $_, $y{$_}; }
Major Minor code of class files
Here a oneliner for finding out the bytecode version. Based on
http://en.wikipedia.org/wiki/Class_(file_format)
http://en.wikipedia.org/wiki/Class_(file_format)
perl -pe 'open(FILE,$_);binmode(FILE);sysread(FILE,$buf,2,6);close(FILE);@c=unpack("H*",$buf);foreach(@c){$s.=sprintf "%s",ord($_);};$_=$s'or
import java.io.*; public class ClassVersionChecker { public static void main(String[] args) throws IOException { for (int i = 0; i < args.length; i++) checkClassVersion(args[i]); } private static void checkClassVersion(String filename) throws IOException { DataInputStream in = new DataInputStream (new FileInputStream(filename)); int magic = in.readInt(); if(magic != 0xcafebabe) { System.out.println(filename + " is not a valid class!");; } int minor = in.readUnsignedShort(); int major = in.readUnsignedShort(); System.out.println(filename + ": " + major + " . " + minor); in.close(); } }
Aliasing and passing arguments in Bash
rssh() { xargs -i\{} -t ssh {} $@; }
Usage after setting the function:
$ cat list | rssh 'command'
Thursday, February 11, 2010
bash PS1 setup
export PS1="\h \W$"
\w - absolute path
\u - user
\v - version of bash
\s - shell environment
\w - absolute path
\u - user
\v - version of bash
\s - shell environment
Friday, January 8, 2010
running scripts from an open wsadmin session
I would like to execute individual scripts from my local library, but rather than executing each individual script with the WebSphere overhead (i.e.
wsadmin -f myscript.py).
The test file test.py
def main(args):
print AdminControl.queryNames('*')
print args
#enddef
# main method
main()
Next running the test script from an open session
$ wsadmin -port 8081 -host myhost -username memyselfandi
WASX7209I: Connected to process "WasPAdmgr" on node wasdpAdmrNode using SOAP connector; The type of process is: DeploymentManager
WASX8011W: AdminTask object is not available.
WASX7031I: For help, enter: "print Help.help()"
wsadmin>execfile('test.py')
# # This script can be included in the wsadmin command invocation like this:
# # wsadmin -lang jython -f test.py serverX nodeY c:/applicationZ myapp
# #
# # or the script can be execfiled from the wsadmin command line like this:
# # wsadmin> execfile ("test.py") or execfile("test.py")
# # wsadmin> test("serverX", "nodeY", "c:/applicationZ", "myapp")
Subscribe to:
Posts (Atom)